Vue 条件渲染 与 列表渲染

目录

一、条件渲染

        1.简介 : 

        2.v-if实例 : 

        3.v-show实例 : 

        4.v-if与v-show的区别 : 

二、列表渲染

        1.基本用法 : 

            1.1 v-for遍历数组 

            1.2 v-for遍历对象 

        2.应用实例 : 


一、条件渲染

        1.简介 : 

        (1) Vue提供了v-if 和 v-show条件指令来完成条件渲染/控制。

        v-if指令用于条件性地渲染一块内容。这块内容只会在指令的表达式返回truthy值的时候被渲染,也可以用v-else添加一个"else块"。

        PS : v-else和v-else-if 必须紧跟在带 v-if 或者 v-else-if 的元素之后,否则它们不会被识别。

<h1 v-if="awesome">Vue is awesome!</h1>
<h1 v-else>Oh no 😢</h1>

        (2) v-show指令是另一个用于根据条件展示元素的选项。eg:

<h1 v-show="ok">Hello!</h1>

        不同的是带有 v-show 的元素始终会被渲染并保留在 DOM 中。v-show 只是简单地切换元素的 CSS property display注意,v-show 不支持 <template> 元素,也不支持 v-else

        2.v-if实例 : 

                以“勾选复选框引起展示内容的变化”为例,vue_if.html代码如下 : 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>v-if demonstration</title><script type="text/javascript" src="../vue.js"></script>
</head>
<body><div id="app"><!--对checkbox类型的input标签使用v-model数据双向渲染,当checkbox被勾选时,point属性的值为true.--><input type="checkbox" v-model="point"/> 你是不是OP?<!--v-if会自动去挂载的Vue实例中的data数据池中寻找对应的属性。--><h2 v-if="point">👴就是OP怎么啦,怎么啦,op怎么你啦?</h2><h2 v-else>我才不是OP呢!</h2></div><script type="text/javascript">let vm = new Vue({el:"#app",data:{point:false,}})</script>
</body>
</html>

                运行效果 : (如下GIF图)

        3.v-show实例 : 

                仍然以“勾选复选框引起展示内容的变化”为例,vue_show.html代码如下 : 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>v-show demonstration</title><script type="text/javascript" src="../vue.js"></script>
</head>
<body>
<div id="app"><input type="checkbox" v-model="agreement"/> 你喜不喜欢吃好吃的?<h2 v-show="agreement">海星</h2><!--v-show不支持v-else--><h2 v-show="!agreement">喜欢不了一点</h2></div>
<script type="text/javascript">let vm = new Vue({el:"#app",data:{agreement:false,}})
</script>
</body>
</html>

                运行效果 : (如下GIF图)

        4.v-if与v-show的区别 : 

        (1) v-if会确保在切换过程中,条件块内的事件监听器和子组件真正地销毁和重建;而v-show机制相对简单,无论初始条件如何,条件块总是会被渲染并保留在DOM中,但只是对CSS样式的切换。
        (2) 由于v-if会真正的销毁和重建组件,因此v-if开销更大。若组件需要频繁地切换,建议使用v-show;若运行时条件很少改变,可以考虑使用v-if条件渲染.

                测试v-if条件渲染,在调试界面输出vm对象(创建的Vue实例),可以在挂载到的元素的childNodes属性中,找到有且仅有一个h2标签。如下图所示 : 

                测试v-show条件渲染,在调试界面输出vm对象(创建的Vue实例),可以在挂载到的元素的childNodes属性中,找到有两个h2标签。如下图所示 : 


二、列表渲染

        1.基本用法 : 

            1.1 v-for遍历数组 

        可以用 v-for 指令基于一个数组来渲染一个列表。v-for 指令需要使用 item in items 形式的特殊语法,其中 items 是源数据数组(位于data数据池中),而 item 则是被迭代的数组元素的别名。(数组及数组元素的名称可以手动定义

<ul id="example-1"><li v-for="item in items" :key="item.message">{{ item.message }}</li>
</ul>
var example1 = new Vue({el: '#example-1',data: {items: [{ message: 'Foo' },{ message: 'Bar' }]}
})

            1.2 v-for遍历对象 

        也可以用 v-for 来遍历一个对象的 property(对象中定义的属性)格式为——v-for="value in object",该用法只可以取出property的值value。

<ul id="v-for-object" class="demo"><li v-for="value in object">{{ value }}</li>
</ul>
new Vue({el: '#v-for-object',data: {object: {title: 'How to do lists in Vue',author: 'Jane Doe',publishedAt: '2016-04-10'}}
})

        若想同时遍历property的键名,需要提供第二个参数作为property的键名,如下 : 

<div v-for="(value, name) in object">{{ name }}: {{ value }}
</div>

        还可以用第三个参数作为索引(注意v-for格式中小括号的使用),如下 : 

<div v-for="(value, name, index) in object">{{ index }}. {{ name }}: {{ value }}
</div>

        2.应用实例 : 

                vue_for.html代码如下 : 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>v-for demonstration</title><script type="text/javascript" src="../vue.js"></script>
</head>
<body><div id="app"><h3>(1) 渲染一个简单的无序列表(不是来自data数据池)</h3><ul><!-- 名称可以自主定义 --><li v-for="(i,index) in 3">第{{index}}个元素---{{i}}</li></ul><h3>(2) v-for迭代数组</h3><ul><li v-for="stu in students">{{stu}}</li></ul><h3>(3) v-for迭代对象</h3><ul><li v-for="(value,name,index) in blogger">{{index}} -- {{name}} -- {{value}}</li></ul></div><script type="text/javascript">let vm = new Vue({el: "#app",data: {students: [{id: 1, name: "Cyan", score: 450},{id: 2, name: "Eisen", score: 446},{id: 3, name: "Five", score: 439}],blogger: {name: "Cyan",symbol: "RA9",age: 21}}})</script>
</body>
</html>

                运行结果 : 

        System.out.println("END-----------------------------------------------------------------------");

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/160425.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2.8 CSS 伸缩盒模型

1.模型简介 传统布局是指:基于传统盒状模型&#xff0c;主要靠: display 属性 position 属性float 属性。2009年&#xff0c;w3C提出了一种新的盒子模型——Flexible Box(伸缩盒模型&#xff0c;又称:弹性盒子)。它可以轻松的控制:元素分布方式、元素对齐方式、元素视觉顺序..…

人们常常下定决心“不改变”

"因为我的性格很悲观" 有的人会觉得一些事情发生&#xff0c;是自己性格使然&#xff0c;改变不了。 但其实性格是可以改变的。 这听起来似乎不太现实&#xff0c;自己的性格就是这样&#xff0c;怎么会改变&#xff1f; 那换种表达&#xff0c;我们看待世界的方式可…

【leetcode】17.04 消失的数字

目录 1. 思路2. 代码 题目链接&#xff1a;leetcode 17.04.消失的数字 题目描述&#xff1a; 1. 思路 要求算法复杂度为O(n)&#xff0c;有两种方式&#xff1a; &#xff08;1&#xff09;利用异或交换律 与nums所有元素异或一遍&#xff1b;与0-n的值异或&#xff0c;n…

吴恩达《机器学习》5-6:向量化

在深度学习和数值计算中&#xff0c;效率和性能是至关重要的。一个有效的方法是使用向量化技术&#xff0c;它可以显著提高计算速度&#xff0c;减少代码的复杂性。接下来将介绍向量化的概念以及如何在不同编程语言和工具中应用它&#xff0c;包括 Octave、MATLAB、Python、Num…

【wp】2023鹏城杯初赛 Web web1(反序列化漏洞)

考点&#xff1a; 常规的PHP反序列化漏洞双写绕过waf 签到题 源码&#xff1a; <?php show_source(__FILE__); error_reporting(0); class Hacker{private $exp;private $cmd;public function __toString(){call_user_func(system, "cat /flag");} }class A {p…

SpringCloudTencent(上)

SpringCloudTencent 1.PolarisMesh介绍2.北极星具备的功能3.北极星包含的组件4.功能特性1.服务管理1.服务注册2.服务发现3.健康检查 2.配置管理 5.代码实战1.环境准备2.服务注册与发现3.远程调用 1.PolarisMesh介绍 1.北极星是腾讯开源的服务治理平台&#xff0c;致力于解决分…

高速缓存--直接映射

某高速缓存大小 256 字节&#xff0c;直接映射&#xff0c;块大小为 16 字节。定义 L 为数据装载命令&#xff0c;S 为存储&#xff0c;M 为数据修改。若每一数据装载(L)或存储(S)操作可引发最多 1次缓存缺失(miss)&#xff1b;数据修改操作(M)可认为是同一地址上 1 次装载后跟…

半导体芯片制造行业MES系统解决方案

半导体产业作为现代电子科技的重要支柱&#xff0c;驱动着电子设备和通信技术的飞速发展。随着技术不断演进&#xff0c;半导体制造企业面临着越来越多的挑战&#xff0c;如高度复杂的工艺流程、全球化的竞争、质量控制的要求以及能源效率等问题。 为了应对这些挑战&#xff0…

错误页 模板

下载链接&#xff1a;https://ext.dcloud.net.cn/plugin?id15229 http://下载链接&#xff1a;https://ext.dcloud.net.cn/plugin?id15229 如有问题可添加下方名片

JVM字节码文件浅谈

文章目录 版权声明java虚拟机的组成字节码文件打开字节码文件的姿势字节码文件的组成魔数&#xff08;基本信息&#xff09;主副版本号&#xff08;基本信息&#xff09;主版本号不兼容的错误解决方法基本信息常量池方法 字节码文件的常用工具javap -v命令jclasslib插件阿里art…

JsonPath 数据快速查找和提取工具

常用语法 表达式说明$表示根元素$.key选择根元素下的指定键名的值$.*选择根元素下的所有属性值$.array[*]选择根元素中的数组的所有元素$.key[subkey]选择根元素中的键名为key&#xff0c;子键名为subkey的值$.key[*].subkey选择根元素中的键名为key的所有元素的子键名为subke…

4 sql语法基础

1、DISTINCT 相同值只会出现一次。它作用于所有列&#xff0c;也就是说所有列的值都相同才算相同。 2、LIMIT 限制返回的行数。可以有两个参数&#xff0c;第一个参数为起始行&#xff0c;从 0 开始&#xff1b;第二个参数为返回的总行数。 返回前 5 行: SELECT * FROM myt…