相同点:都是显示隐藏
不同点:
v-if:通过创建或删除dom节点来实现显示或隐藏 浪费性能 适合筛选元素和初次渲染
v-show:通过display属性来实现控制元素的显示或隐藏 适合显示隐藏
本质的区别
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,它不会在页面中显示。