Vue中 v-if 和v-else-if页面加载出现闪现的问题及解决方法
程序员文章站
2022-05-25 22:23:58
vue中v-if 和v-else-if在页面加载的时候,不满足条件的标签会加载然后再消失掉,如果要解决这个问题,案例如下:
vue html代码块:
vue中v-if 和v-else-if在页面加载的时候,不满足条件的标签会加载然后再消失掉,如果要解决这个问题,案例如下:
vue html代码块:
<div id="divapp"> <div v-if="type === 'a'" v-cloak> a </div> <div v-else-if="type === 'b'" v-cloak> b </div> <div v-else-if="type === 'c'" v-cloak> c </div> <div v-else v-cloak> not a/b/c </div> </div>
vue js代码块:
var divapp = new vue({ el: '#divapp', data: { isactive: true, haserror: false, type: 'a' }, // 在 `methods` 对象中定义方法 methods: { } } )
css 代码:
[v-cloak] { display:none; }
下面看下vue学习中v-if和v-show一起使用的问题
v-if和v-show一起使用
在开发项目过程中v-if
和v-show
一起使用时,接下面跟着的v-else
会在页面上面显示两次 。代码如下:
<tbody class="sortable" id="sorttable"> <tr v-show="items.length" v-for="(item,index) in items" :item="item"> <td :id="item.objectid">{{index+1}}</td> <td>{{item.number}}</td> </tr> <tr v-else> <td colspan='2'>暂无数据</td> </tr> </tbody>
原因其实很简单,根据vue的文档描述:
当它们都处于同一节点时,v-for 的优先级高于 v-if。这意味着,v-if 将分别在循环中的每次迭代上运行。
也就是v-if会判断两次。
当然这样用也有它的好处,当你只想将某些项渲染为节点时,这会非常有用,如下:(以上只渲染 todos 中未完成的项。)
<li v-for="todo in todos" v-if="!todo.iscomplete"> {{ todo }} </li>
如果你的意图与此相反,是根据条件跳过执行循环,可以将 v-if 放置于包裹元素上(或放置于
总结
以上所述是小编给大家介绍的vue中 v-if 和v-else-if页面加载出现闪现的问题及解决方法,希望对大家有所帮助
上一篇: php图片裁剪函数