发布网友 发布时间:2022-04-23 08:50
共2个回答
懂视网 时间:2022-04-22 14:50
在Vue中,我们可以使用v-if和v-show来控制元素或模板的渲染,而v-if和v-show也属于Vue的内部常用的指令(条件渲染)。
v-if和v-show都是通过判断绑定数据的truefalse来展示的
本质的区别
vue-show本质就是标签display设置为none,控制隐藏
vue-if是动态的向DOM树内添加或者删除DOM元素
编译的区别
v-show其实就是在控制css
v-if切换有一个局部编译/卸载的过程,切换过程中合适地销毁和重建内部的事件监听和子组件
编译的条件
v-show都会编译,初始值为false,只是将display设为none,但它也编译了。
v-if初始值为false,就不会编译了。
性能的区别
v-show只编译一次,后面其实就是控制css,而v-if不停的销毁和创建,故v-show性能更好一点。
用法的区别
v-if更适合于带有权限的操作,渲染时判断权限数据,有则展示该功能,没有则删除。v-show更适合于日常使用,可以减少数据的渲染,减少不必要的操作。
如果你的页面不想让其他程序员看到就用v-if,它不会在页面中显示。
【相关推荐:JavaScript教程】
热心网友 时间:2022-04-22 11:58
v-if 条件判断,不满足条件的话则不会出现在dom中
v-show 是否显示,不管满不满足条件均会在dom中,若不满足条件,则会设置成隐藏 display:none