我们先来说说两者的核心差异;
v-if : DOM 区域没有生成,没有插入文档…等条件成立的时候才动态插入到页面!有些需要遍历的数组对象或者值,最好用这货控制,等到拿到值才处理遍历,不然一些操作过快的情况会报错,比如数据还没请求到!
v-show: DOM 区域在组件渲染的时候同时渲染了,只是单纯用 css 隐藏了,对于下拉菜单,折叠菜单这些数据基本不怎么变动.用这个最合适了…而且可以改善用户体验,因为它不会导致页面的重绘,DOM 操作会!
简言之:
DOM结构不怎么变化的用v-show, 数据需要改动很大或者布局改动的用v-if