当前位置: 首页 > news >正文

做视频网站资质广告公司起什么名字好

做视频网站资质,广告公司起什么名字好,营销咨询公司收费标准,php网站开发专业v-if和v-for v-if 用来显示和隐藏元素 flag为true时&#xff0c;dom元素会被删除达到隐藏效果 <div class"boxIf" v-if"flag"></div>v-for用来进行遍历&#xff0c;可以遍历数字对象数组&#xff0c;会将整个元素遍历指定次数 <!-- 遍…

v-if和v-for

  • v-if 用来显示和隐藏元素
    flag为true时,dom元素会被删除达到隐藏效果
    <div class="boxIf" v-if="flag"></div>
  • v-for用来进行遍历,可以遍历数字对象数组,会将整个元素遍历指定次数
<!--    遍历数字--><div v-for="num in 5" :key="num">{{ num }}</div>
<!--    遍历对象--><div v-for="(value,key) in obj" :key="key">{{value}}</div>
<!--    遍历数组--><div v-for="(item,index) in list" :key="index">{{item}}</div>

如果将遍历元素v-for和删除元素v-if连用,会发生什么?

v-if和v-for的优先级

首先,在vue官网中是不建议v-for和v-if连用
在这里插入图片描述

  • 在Vue 2中,v-for的优先级比v-if高,因此在连用的时候会先进行v-for将所有元素渲染到页面上之后,再进行v-if判断删除元素,这样会导致性能的浪费(每次先渲染元素再进行判断删除)
    官网上给了一个例子,可以简单理解一下。在这个例子中会先将用户进行遍历渲染(v-for),再去判断用户是否为活跃用于(v-if)。在这里只需要活跃用户渲染,但是由于v-for的优先级更高,因此无论是否为活跃用户都会渲染,这样会造成资源的浪费。
<ul><liv-for="user in users"v-if="user.isActive":key="user.id">{{ user.name }}</li>
</ul>
  • 在Vue 3中,v-if的优先级比v-for高
    看看官网上给的例子,给一个用户列表,遍历活跃用户(user.isActive为true)。
<ul><liv-for="user in users"v-if="user.isActive":key="user.id">{{ user.name }}</li>
</ul>

Will throw an error, because the v-if directive will be evaluated first and the iteration variable user does not exist at this moment.(将抛出一个错误,因为v-if指令将首先求值,并且迭代变量user此时不存在。)

由官网给的解释可以看出,直接将v-if和v-for连用可能会出现报错,因此不建议在同一节点中连用

解决方案

vue2提供的解决方案

1.添加一个属性。将 users 替换为一个计算属性 (比如 activeUsers),让其返回过滤后的列表。
2.将 v-if 移动至外层容器元素上。

activeUsers过滤出满足条件的用户,将遍历的users改为activeUsers

computed: {activeUsers: function () {return this.users.filter(function (user) {return user.isActive})}
}
<ul><liv-for="user in activeUsers":key="user.id">{{ user.name }}</li>
</ul>

或者使用嵌套关系,将v-if添加到外层元素上。先判断是否要展示用户信息,满足条件再进行渲染。

<ul v-if="shouldShowUsers"><liv-for="user in users":key="user.id">{{ user.name }}</li>
</ul>

Vue2风格指南相关部分

Vue3提供的解决方案

1.添加一个属性。将 users 替换为一个计算属性 (比如 activeUsers),让其返回过滤后的列表。(与Vue2相同)
2.将 v-for移动至外层容器元素上。

第一个方法与vue2相同,不过多进行解释。
第二个方法:嵌套。与vue2不同的是,在vue3中,将v-for移动至外层的元素上

<ul><template v-for="user in users" :key="user.id"><li v-if="user.isActive">{{ user.name }}</li></template>
</ul>

Vue3风格指南相关部分

总结

在Vue2中,v-for的优先级更高。在Vue3中,v-if的优先级更高。
无论哪个优先级更高,都不建议在同一节点连用v-if和v-for。

http://www.yayakq.cn/news/526544/

相关文章:

  • 百度网站排名提升工具黑河企业网站建设公司
  • 综合门户网站开发北京网站制作哪家好
  • 义乌外贸网站建设公司网络编程培训
  • 东莞网站建设方案托管泉州市新濠网络科技有限公司
  • 苏州公司网站建设报价沙井做网站
  • 河南快速网站备案宝塔网站建设教程
  • 巴中自助网站建设网站建设与网络编辑综合实训课程指导手册pdf
  • dede查看网站源码莱芜一中谭苗苗事件
  • 北京做网站找哪家好深圳网站建设空间
  • 网站开发必须要做前端吗自媒体135网站
  • 电商型网站鹤壁网站制作
  • 南昌网站建设效果怎么做页眉页脚
  • 网站建设需要机房服务器长沙正规网站建设价格
  • 东莞外贸模板建站网站开发实训基本要求
  • 聊城做网站的公司精英柳州建设厅官方网站
  • 推荐好的设计网站怎样咨询网络服务商
  • p2p网站制作流程上海公司注册查询
  • 网站流量检测建设网站要什么手续
  • 佛山百度网站快速排名台州关键词优化服务
  • 导航网站怎么做seo凡科建站下载
  • 做汽车配件网站的公司保定知名网站建设公司
  • 汽车门户网站程序wordpress留言区
  • 在网站做博客网站制作与建设
  • 高州网站建设公司有什么网站有小学生做的题目
  • 什么东西可以做网站wordpress连不上数据库
  • 贵州软件开发 网站开发深圳龙岗网络推广公司
  • 怎样做移动端网站在线图片编辑器精简版
  • 陕西因酷网站建设wordpress调用标签搜索结果出图
  • 网站代码怎么改wordpress slug
  • 可以做t恤的网站深圳城市更新或提速