文章目录
-
- 01.条件渲染
-
- 1.1.v-if 使用场景
- 1.2.v-show使用场景
- 02.列表渲染
-
- 2.1.v-for的基本使用
- 2.2.v-for遍历时key的选择问题
01.条件渲染 Vue中的条件渲染指的是,我们可以在视图中
选择性的显示
一些内容,条件渲染的可以使用以下两种指令
来实现:v-if
:- 特点:不展示的DOM元素
直接被移除
,即动态的
向DOM树内添加或者删除DOM元素,注意,不是隐藏是销毁删除
。 - 适用于:切换频率较低的场景。
- 注意:
v-if
可以和v-else-if
、v-else
一起使用,但要求结构不能被打断
。
- 特点:不展示的DOM元素
v-show
- 特点:不展示的DOM元素
未被移除
,仅仅是使用样式隐藏掉 ,本质就是控制标签的display属性,来实现对标签的隐藏
和显示
,并且只编译一次。 - 适用于:切换频率较高的场景。
- 写法
:v-show="表达式"
- 特点:不展示的DOM元素
1.1.v-if 使用场景
条件渲染 v-if - 锐客网
type="text/javascript" src="https://www.it610.com/js/vue.js">
当前的n值是:{{n}}
欢迎你 {{name}}
欢迎你 {{name}}Angular
React
Vue
哈哈
你好
AISMALL
Java
type="text/javascript">
const vm = new Vue({
el:'#root',
data:{
name:'AISMALL',
n:0
}
})
1.2.v-show使用场景
条件渲染 v-show - 锐客网
type="text/javascript" src="https://www.it610.com/js/vue.js">
当前的n值是:{{n}}
欢迎你 {{name}}
欢迎你 {{name}}
type="text/javascript">
const vm = new Vue({
el:'#root',
data:{
name:'AISMALL',
n:0
}
})
02.列表渲染 Vue中的条件渲染指的是,获取列表中的各种数据,并将它展示出来,列表渲染一般使用
v-for
指令来实现,根据遍历数据(数组
、对象
、字符串
、指定次数
)的不同可进行分类:v-for遍历
数组
:- 方式一:
- {{item}}
- 语法解析:
- item:为标签内要填充的内容
- in:关键字
- list:待遍历的数组
- 方式二:
- {{item}} + '---' +{{index}}
- 【前端相关|02-Vue基础之条件渲染和列表渲染】语法解析:
- item:为标签内要填充的内容
- index:数组的索引
- in:关键字
- list:待遍历的数组
- 注意:key的作用是帮助Vue区分不同的元素,从而提高性能
对象
:- 方式一:
- 语法解析:
- value:对象的value
- key:代表对象的键
- 方式二:
- 语法解析:
- value:对象的value
- key:代表对象的键
- index:代表索引
- 注意:不推荐同时使用v-if和v-for,当v-if与v-for一起使用时,v-for具有比v-if更高的优先级。
2.1.v-for的基本使用
- 使用v-for指令遍历
数组
、对象
、字符串(用的很少)
、指定次数(用的很少)
。
列表渲染 - 锐客网
type="text/javascript" src="https://www.it610.com/js/vue.js">
人员列表(遍历数组)
-
{{p.name}}-{{p.age}}
汽车信息(遍历对象)
-
{{k}}-{{value}}
测试遍历字符串(用得少)
-
{{char}}-{{index}}
测试遍历指定次数(用得少)
-
{{index}}-{{number}}
type="text/javascript">
new Vue({
el:'#root',
data:{
persons:[
{id:'001',name:'张三',age:18},
{id:'002',name:'李四',age:19},
{id:'003',name:'王五',age:20}
],
car:{
name:'奥迪A8',
price:'70万',
color:'黑色'
},
str:'hello'
}
})
2.2.v-for遍历时key的选择问题
问题1:react、vue中的key有什么作用?(key的内部原理)
- key是虚拟DOM对象的标识,当数据发生变化时,Vue会根据
新数据
生成新的虚拟DOM
,随后Vue进行新虚拟DOM
与旧虚拟DOM
的差异比较,比较规则如下:
1、旧虚拟DOM中找到了与新虚拟DOM相同的key: - 若虚拟DOM中内容没变, 直接使用之前的真实DOM! - 若虚拟DOM中内容变了, 则生成新的真实DOM,随后替换掉页面中之前的真实DOM。2、旧虚拟DOM中未找到与新虚拟DOM相同的key - 创建新的真实DOM,随后渲染到到页面。
key的原理 - 锐客网 type="text/javascript" src="https://www.it610.com/js/vue.js">人员列表(遍历数组)type="text/javascript"> new Vue({ el:'#root', data:{ persons:[ {id:'001',name:'张三',age:18}, {id:'002',name:'李四',age:19}, {id:'003',name:'王五',age:20} ] }, methods: { add(){ const p = {id:'004',name:'老刘',age:40} this.persons.unshift(p) } }, })- {{p.name}}-{{p.age}}-{{index}}
- 1、 若对数据进行
逆序添加
、逆序删除
等破坏顺序操作,会产生没有必要的真实DOM更新(界面没问题),效率低。
- 2、如果结构中还包含输入类的DOM,会产生
错误DOM更新
( 界面有问题)。
key的原理 - 锐客网 type="text/javascript" src="https://www.it610.com/js/vue.js">使用默认的index作为key 人员列表(遍历数组):先在输入框中输入值,然后再点击添加按钮type="text/javascript"> new Vue({ el:'#root', data:{ persons:[ {id:'001',name:'张三',age:18}, {id:'002',name:'李四',age:19}, {id:'003',name:'王五',age:20} ] }, methods: { add(){ const p = {id:'004',name:'老刘',age:40} this.persons.unshift(p) } }, })- {{p.name}}-{{p.age}}-{{index}}
- 1、最好使用每条数据的唯一标识作为key, 比如id、手机号、身份证号、学号等唯一值。
- 2、如果不存在对数据的逆序添加、逆序删除等破坏顺序操作,仅用于渲染列表用于展示,使用index作为key是没有问题的。
key的原理 - 锐客网 type="text/javascript" src="https://www.it610.com/js/vue.js">唯一标识作为key:人员ID 人员列表(遍历数组):先在输入框中输入值,然后再点击添加按钮type="text/javascript"> new Vue({ el:'#root', data:{ persons:[ {id:'001',name:'张三',age:18}, {id:'002',name:'李四',age:19}, {id:'003',name:'王五',age:20} ] }, methods: { add(){ const p = {id:'004',name:'老刘',age:40} this.persons.unshift(p) } }, })- {{p.name}}-{{p.age}}-{{index}}
推荐阅读
- layui|layui--select show hide 选择显示隐藏
- vue后台管理项目|Vue后台管理系统项目(27)SPU管理内容的切换
- Web-Douglas|Vue学习基础版汇总V5.0.0
- # yyds干货盘点 # 一文带你解读?JavaScript中的变量作用域和内存问题
- 零基础学JavaScript|三,零基础学习JavaScript----词法结构
- 零基础JavaScript学习|零基础JavaScript学习【完结篇】
- Vue|Vue2.x 项目性能优化之代码优化
- 笔记|JavaScript JSON
- NodeJS和AngularJS之间有哪些区别()