v-if 与 v-show的区别及对生命周期的影响

两者的区别

(1) v-if 的原理是根据判断条件来动态的进行增删DOM元素,只有v-if的值为true时,元素才会存在于html页面中;
     v-show是根据判断条件来动态的进行显示和隐藏元素,是通过修改DOM元素的display属性来实现的,无论v-show的值为true或者false,元素都会存在于html页面中。

(2) 只有v-if能和v-else连用进行分支判断,v-show是不能和v-else连用的,如果出现多种条件场景的情况下,可以使用v-if来进行判断

(3) 如果需要非常频繁地切换,使用v-show比较好,如果在运行时条件不会改变时,用v-if比较好

应用场景:频繁的进行增删DOM操作会影响页面加载速度和性能,由此:

  • 项目程序不是很大的时候,v-if和v-show都可以用来进行判断展示和隐藏(这种场景使用v-if只是影响不大,并不是没有影响);
  • 当项目程序比较大的时候,不推荐使用v-if来进行判断展示和隐藏,推荐使用v-show;    

 

对生命周期的影响

v-if - 初始渲染:

初始值为 false 组件不会渲染,生命周期钩子不会执行,v-if 的渲染是惰性的。
初始值为 true 时,组件会进行渲染,并依次执行 beforeCreate,created,beforeMount,mounted 钩子。

v-if - 切换:

false => true:依次执行 beforeCreate, created, beforeMount, mounted 钩子。
true => false:依次执行 beforeDestroy, destroyed 钩子。

v-show - 渲染:

无论初始状态,组件都会渲染,依次执行 beforeCreate, created, beforeMount, mounted 钩子,v-show 的渲染是非惰性的。

v-show - 切换:

对生命周期钩子无影响,切换时组件始终保持在 mounted 钩子。

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值