03. Vue3 中的条件判断与循环

简介: 03. Vue3 中的条件判断与循环

在 Vue 中判断条件,咱可以用 v-if,意思就是「如果 xxx 的话,那就 xxx」。当满足条件,也就是条件返回 true 的时候,就可以做它要做的事情了。

案例 1

比如,我们想看一个「大靓仔」,代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Hello Vue</title>
    <!-- 其实,就一句即实现引入 Vue.js -->
    <script src="https://unpkg.com/vue@next"></script>
</head>
<body>
    <!-- 第六步,展示数据 -->
    <div id="root"></div>
</body>
<script>
    // 第一步,创建一个 Vue 的实例
    Vue.createApp({
        // 第二步,提供一个 data 选项
        // 提供 seen 来保存一个 bool 值
        data() {
            return {
                seen: true
            }
        },
        // 第四步,在 methods 中提供对应方法
        methods: {
            showAndHide(){
                // 切换 bool 值
                this.seen = !this.seen
            }
        },
        
        // 第三步,在页面提供一个标签和一个按钮
        // 按钮控制 seen 的值
        template:`
            <div>
                <span v-if="seen">我是一个「大靓仔」^_^</span>
            </div>
            <p>
            <div><button v-on:click="showAndHide">显示/隐藏靓仔</button></div>
            `
    }).mount('#root'); 
</script>
</html>

运行效果:

关于「条件判断」先做一个简单的了解,更多实战案例,后面拿更多案例来分析。

我们再来了解一下 Vue 中的「循环」,咱可以用 v-for来循环遍历出数组中的元素 。

案例 2

一个小案例,代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Hello Vue</title>
    <!-- 其实,就一句即实现引入 Vue.js -->
    <script src="https://unpkg.com/vue@next"></script>
</head>
<body>
    <!-- 展示数据 -->
    <div id="root"></div>
</body>
<script>
    // 第一步,创建一个 Vue 的实例
    Vue.createApp({
        // 第二步,提供一个 data 选项
        // 提供 poetry 数组来保存诗句内容,并返回
        data() {
            return {
                poetry : [
                    { text : '红豆生南国,'},
                    { text : '春来发几枝。'},
                    { text : '愿君多采撷,'},
                    { text : '此物最相思。'}
                ]
            }
        },
        
        // 第三步,在页面提供一个标签和一个列表
        // 其中列表用来展示诗句内容
        template:`
            <div>
                <span>你听过 王维 的《相思》吗?</span>
            </div>
            
            <ol>
                <li v-for="p in poetry">
                    {{ p.text }}
                </li>
            </ol>
            `
    }).mount('#root'); 
</script>
</html>

运行效果:

Vue 还提供了 v-model 指令,它能轻松实现表单输入和应用状态之间的双向绑定。比如,我们来写一个「花名登记册」吧。

案例 3

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Hello Vue</title>
    <!-- 其实,就一句即实现引入 Vue.js -->
    <script src="https://unpkg.com/vue@next"></script>
</head>
<body>
    <!-- 展示数据 -->
    <div id="root"></div>
</body>
<script>
    // 第一步,创建一个 Vue 的实例
    Vue.createApp({
        // 第二步,提供一个 data 选项
        // 提供 userName 用来获取输入的用户名
        // 提供 userNameList 数组用来收集所有输入的名字,循环展示
        data() {
            return {
                userName : '',
                userNameList:[]
            }
        },
        methods: {
            // 第四步,实现 RecordName() 方法,记录用户名
            RecordName(){
                this.userNameList.push(this.userName);
                this.userName = '';
            }
        },
        
        // 第三步,在页面提供一个输入框、一个按钮和一个列表
        // 输入框,用于接受用户输入的用户名,通过 v-model 能将表单输入的用户名与 data 中的 userName 双向绑定
        // 按钮,绑定 RecordName() 方法,将用户名保存至 userNameList 数组中,且再将输入框清空
        // 列表,用来展示所有用户名
        template:`
            <div>
                请输入用户名:<input v-model="userName" /> | 
                <button v-on:click="RecordName">登记用户名</button>
            </div>
            
            <ul>
                <li v-for="(name, index) in userNameList">
                    这是第 {{ index + 1 }} 名客户,名字是「 {{ name }}」
                </li>
            </ul>
            `
    }).mount('#root'); 
</script>
</html>

运行效果:

如果今天的分享,也能帮到你,点个赞,再关注一下呗,继续努力!

目录
相关文章
|
22天前
|
存储 JavaScript 前端开发
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
【10月更文挑战第21天】 vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
|
19天前
|
JavaScript 前端开发 开发者
Vue 3中的Proxy
【10月更文挑战第23天】Vue 3中的`Proxy`为响应式系统带来了更强大、更灵活的功能,解决了Vue 2中响应式系统的一些局限性,同时在性能方面也有一定的提升,为开发者提供了更好的开发体验和性能保障。
44 7
|
20天前
|
前端开发 数据库
芋道框架审批流如何实现(Cloud+Vue3)
芋道框架审批流如何实现(Cloud+Vue3)
39 3
|
19天前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
38 1
|
19天前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
40 1
|
21天前
|
前端开发 JavaScript
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
|
22天前
Vue3 项目的 setup 函数
【10月更文挑战第23天】setup` 函数是 Vue3 中非常重要的一个概念,掌握它的使用方法对于开发高效、灵活的 Vue3 组件至关重要。通过不断的实践和探索,你将能够更好地利用 `setup` 函数来构建优秀的 Vue3 项目。
|
25天前
|
JavaScript API
vue3知识点:ref函数
vue3知识点:ref函数
32 2
|
25天前
|
API
vue3知识点:reactive函数
vue3知识点:reactive函数
26 1
|
25天前
|
JavaScript 前端开发 API
vue3知识点:Vue3.0中的响应式原理和 vue2.x的响应式
vue3知识点:Vue3.0中的响应式原理和 vue2.x的响应式
24 0