vuejs中v-if和v-show的区别以及v-show不起作用
2017-03-30 15:34
330 查看
1.官网概念描述
v-if是'真正的'条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建.
v-if
也是惰性的,如果在初始渲染时条件为假,那么什么都不做- - 直到条件第一次为真的时候才会开始渲染条件块,相比之下,v-show
就简单得多- - 不管初始条件是什么,元素总会被渲染,并且只是简单的基于css进行切换.
一般来说,v-if
有更高的切换开销,而 v-show 有更高的出事渲染开销.因此,如果需要非常频繁的切换,那么使用v-show好一点;如果在
运行时条件不太可能改变,则使用v-if
好点.
2.实践结果
摘录: 如果用v-if的话,整个dom结构压根就不会出现在页面上,如果是用v-show的话,要视后面的条件来定,如果是true,则显示,如果为false,则加上style=”display:none”. 所以呢,如果是组件之类的大块头,个人觉得用v-if更好一些,如果是一些暂时性隐藏,一会要显
示的,还是v-show更方便。对于v-style和v-show来比较,v-show相当于是v-style=”display:none”和v-style=”display:block”的快捷方式。
1. v-show不起作用问题
最近在用vue_element-ui开发多页面应用,其中遇到v-show不起作用问题.a.问题描述,如下图(预想达到的效果),其中表格数据是动态变化的,包括标题也会根据后台数据发生改变,如果后台返回的标题为
空,那么就不显示该列的内容.反之则显示该列的所有数据.
部分代码如下:
执行上图出现的效果图如下:
那么就会出现上图的效果,也就是v-show没能隐藏标题值为null的那列数据
b.解决方法:
将v-show改为v-if即可实现图一中的效果.
c.总结(个人见解):
由于el-table-column会生成多行标签元素,根据v-show是不支持template语法的,推断出v-show不能显示隐藏多个元素?不知是否
可以这样理解,望大神告知!所以这种情况下只能用v-if来实现.
另外补充,在渲染多个元素时候可以把一个<template>元素作为包装元素,并在上面使用v-if进行条件判断,最终的渲染并不会包含
这个元素.同时,v-show不支持<template>语法.
相关文章推荐
- 关于vuejs中v-if和v-show的区别及v-show不起作用问题
- angular中的ng-if和ng-show的区别以及ng-if的作用域问题
- 【转】ng-if与ng-show区别以及ng-if会创建子作用域问题
- vue中v-if和v-show区别
- Vue.js 中 v-if 和 v-show 的区别
- ng-if,ng-show,ng-hide的区别
- angular.js里的ng-show,ng-hide与ng-if的区别
- Vue.js 中 v-if 和 v-show 有什么区别?
- vue实现弹框遮罩点击其他区域弹框关闭及v-if与v-show的区别介绍
- ng-if和ng-show的区别
- v-if 和 v-show的区别
- sas条件判断语句where,if的区别,以及where选项
- v-if和v-show区别
- Mybatis的<if>和<choose>的区别 以及“=”判断
- v-if与v-show的区别?
- Expires / Cache-Control / Last-Modified / If-Modified-Since / ETag / If-None-Match 的区别以及使用详解
- ng-show和ng-if的区别
- v-show和v-if的区别
- Angular.js中ng-if、ng-show和ng-hide的区别介绍
- v-if 和v-show的用法和区别?