v-html、v-text、v-show、v-if、v-else、v-else-if、v-for、v-bind、v-on、v-model等等。
不常用的指令
v-pre 令vue语法失效
v-once 元素只渲染一次
v - if:真正意义上的条件渲染,对dom树发生改变。为true是渲染(dom存在),为false时不存在(dom不存在)。
v-show:是通过控制display属性来进行dom的显示与隐藏
性能区别:
1、v-if有更高的切换开销,v-show有更高的初始渲染开销。
如果需要频繁的切换,使用v-show比较好,如果运行条件很少改变,使用v-if比较好。
2、v-show比v-if性能更高,因为v-show只能动态的改变样式,不需要增删DOM元素。所以当程序不是很大时候,v-if和v-show区别都不大,如果项目很大,推荐多用v-show,较少浏览器后期操作的性能。
3、需要多种条件场景,比如id=1,=2,=3…时候,因为只有v-if,可以和v-else等连用,这种比较适合用v-if。
4、v-show不支持语法。
5、v-if切换时候回实时的销毁和重建内部的事件、钩子函数等,v-show只会初始化渲染时候执行,再切换时候不会执行生命后期的过程
必须的。
使用v-for循环一个list,当list发生更新时,v-for默认使用 就地更新策略进行渲染,即根据 key 值去判断某个数据是否修改,如果修改了就重新渲染,不然就复用之前的元素。
方案一:使用index作为key,不推荐
1.在list最后添加一条数据,此时用 index 作为 key,没有任何问题,
2.在list中间插入一条数据,此时用 index 作为 key,很多条数据的index会发生改变,因此v-for会渲染多条数据,降低效率,因此不推荐的。
方案二:使用id(list数据中具有唯一性的值)作为key,推荐
多数情况只会渲染一条数据,相比之下效率更高一些。
在源码中,v-for优先与v-if被解析,也就是说v-for优先级更高。
常遇到的问题:
同时使用两者是,每次v-for循环,都会执行一次v-if,假设有个容量为1000的数组,那么v-if会被执行1000次,会十分消耗性能,降低代码质量。
怎么处理这种问题?这要根据判断调试是否和循环的内容有关系,分为两种情况:
1.在v-if不依赖v-for中某个值的前提下:可以在循环的外层添加template标签,在template中做v-if判断,这样可以让v-if的判断优先。
<template v-if="isShowList">
<div v-for="(item)in list" :key="item.id">
<span>{{item.name}}</span>
</div>
</template>
...
isShowList:true,
list: [
{ id: 0, name: '张三' },
{ id: 1, name: '李四' },
{ id: 2, name: '王五' }
]
...
2.当v-if的判断条件依赖于v-for的内容时:可以在computed计算属性里先做好判断,过滤出符合条件的元素重新组成新的数组,在dom中循环这个新的数组。这样就不需要加v-if判断了。要知道,在computed里过滤的成本远比v-if低的多。
<div v-for="(item) in newlist" :key="item.id">
<span>{{item.name}}</span>
</div>
...
list: [
{ id: 0, name: '张三', isShow: true },
{ id: 1, name: '李四', isShow: false },
{ id: 2, name: '王五', isShow: true }
]
...
computed: {
newlist() {
return this.list.filter(v => v.isShow)
}
},
...