v-if与v-show切换

<div id="app">
  <input type="button" value="toggle" @click="flag=!flag"/>
  <h3 v-if="flag">使用v-if</h3>
  <h3 v-if="flag">使用v-show</h3>
</div>

//script
<script>
  var vm = new Vue({
    el:'app',
    data:{
      flag:true
    },
    methods:{
    //methods中定义了当前vue实例中所有可用的方法
      
    }
  })
</script>

v-if的特点:每次都会重新删除或者创建元素

v-show的特点:每次不会进行dom的删除和创建操作,只是切换了元素的display样式

一般来讲,v-if有更高的切换消耗,而v-show有更高的初始渲染消耗,因此如果需要频繁切换v-show较好,如果在运行时条件不大可能改变v-if比较好

### Vue.js 中 v-show v-if 的区别及使用场景 #### 1. **定义基本行为** `v-show` `v-if` 都是用来控制 DOM 元素的显示隐藏,但两者的实现方式完全不同。`v-show` 是通过修改 CSS 属性 `display` 来控制元素的可见性[^3],而 `v-if` 则是根据条件动态地创建或销毁 DOM 元素[^1]。 #### 2. **性能表现** - **`v-show`**:无论初始条件是什么,DOM 元素始终会被渲染出来,并且只是简单地调整其 `display` 样式属性。因此,当需要频繁切换显示状态时,`v-show` 更加高效[^2]。 - **`v-if`**:只有在条件成立时才会渲染对应的模板内容到真实 DOM 上。如果条件为假,则该部分完全不存在于 DOM 结构中。这意味着首次渲染可能会稍微慢一些,但对于那些很少甚至只会出现一次的组件而言,这种方式能够节省内存开销[^1]。 #### 3. **初始化阶段的表现** - 使用 `v-if` 渲染出来的节点,在第一次满足条件之前是不会存在于虚拟 DOM 树中的;相反地,即使一开始就被设置成不可见(`false`) ,采用 `v-show` 方式的节点依旧会出现在最终生成的真实 HTML 文档里面。 #### 4. **适用场景** - 如果某些 UI 组件的状态经常发生变化(即频繁地从可见变为不可见),那么应该选择使用 `v-show` 指令来提高效率[^2]。 - 对于那种只会偶尔出现或者消失不见的情况——比如模态框、错误提示信息等——则更适合运用 `v-if` 进行按需加载[^1]。 #### 5. **注意事项** - 不建议在同一时间点既用到了循环又涉及到条件判断语句(如同时用了 `v-for` `v-if`),因为这可能导致难以预测的行为以及潜在的性能瓶颈问题[^2]。 - 当利用 `ref` 或者原生 JavaScript 方法去查找特定 DOM 节点的时候,请记住只有经过了 `v-if` 处理后的实例才有可能返回 null 值,而对于已经应用过 `v-show` 的情况来说总是可以获得对应对象引用。 ```vue <template> <div> <!-- 使用 v-if --> <p v-if="isVisible">This is visible with v-if.</p> <!-- 使用 v-show --> <p v-show="isShown">This is shown/hidden via v-show.</p> </div> </template> <script> export default { data() { return { isVisible: true, isShown: false, }; }, }; </script> ``` --- ### 总结 综上所述,虽然 `v-show` `v-if` 在表面上看起来非常相似,但实际上它们背后的工作机制大相径庭。合理选用这两个指令取决于具体的应用需求以及预期的操作频率等因素。牢记各自的特点可以帮助我们写出更加优化易于维护的代码[^1][^2]. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值