v-show和v-if的区别与联系

一、v-show和v-if的共同点

1、v-show和v-if都能控制元素的显示和隐藏

2、当两者均需要控制多个元素的显示与隐藏时,都可以使用HTML5新增的<template>元素来包裹需要切换显示与隐藏的多个元素。

注意:在最终的的渲染结果中是不会包含<template>元素的,实际上<template>元素是被当作一个不可见的包裹元素,主要用于分组条件的判断和列表渲染。

二、v-show和v-if的区别

1、控制元素显示与隐藏的方式

  • 使用v-show指令,元素本身是要被渲染的,元素的显示与隐藏,是通过CSS样式中的display属性来进行控制的。当v-show中相关的表达式为false时,则设置其相关的样式为:“display: none;”。
  • v-if指令是根据表达式的值的真假来生成或删除一个元素。当表达式的值计算为false时,v-if指令不会创建该元素或将该已存在的元素进行删除;当表达式的值为true时,v-if指令会创建该元素。

2、开销方式的不同

  • v-show有更高的初始渲染开销。
  • v-if有更高的切换开销。

3、使用场景不同

  • 如果需要非常频繁地切换元素的显示或隐藏,则使用v-show比较好。
  • 如果在运行时条件很少改变,则使用v-if比较好。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值