vue 控制组件是否显示

在Vue中,控制组件的显示通常使用v-ifv-else-ifv-elsev-show指令。

1.v-if:条件性地渲染元素,如果条件为假,元素甚至不会被渲染到DOM中。

html 复制代码
<template>
  <div>
    <MyComponent v-if="showMyComponent" />
  </div>
</template>
 
<script>
export default {
  data() {
    return {
      showMyComponent: true
    };
  }
};
</script>

2.v-show:通过改变CSS的display属性来控制元素的显示和隐藏。

html 复制代码
<template>
  <div>
    <MyComponent v-show="showMyComponent" />
  </div>
</template>
 
<script>
export default {
  data() {
    return {
      showMyComponent: true
    };
  }
};
</script>

3.v-if与v-show的区别:v-if是真正的条件渲染,因为它会确保条件块内的事件监听器和子组件会适当地被销毁和重建;v-show则简单地通过CSS切换元素的可见性。

4.v-if有更高的切换消耗,而v-show有更高的初始渲染消耗。选择哪个取决于你的场景。

以上代码展示了如何在Vue组件中使用v-if来控制另一个组件MyComponent的显示。通过改变showMyComponent的值,你可以动态地控制MyComponent的渲染。

相关推荐
橙子家5 小时前
浏览器缓存之【身份与会话管理】:Cookies 和 Private state tokens
前端
To_OC6 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
最新资讯动态6 小时前
HDC 2026 | 对话鲸鸿动能:存量时代,品牌如何夺回营销“主动权”?
前端
最新资讯动态6 小时前
游戏出海,从产品走向体系
前端
最新资讯动态6 小时前
20人团队跑出百万DAU、大厂也来抢量:谁在鸿蒙生态跑出加速度
前端
最新资讯动态7 小时前
千万开发者背后,鸿蒙商业化的B面
前端
爱勇宝8 小时前
AI 时代:智商决定起点,情商决定走多远
前端·ai编程
kyriewen9 小时前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
IT_陈寒10 小时前
Vite的静态资源打包让我熬夜到三点,这坑千万别跳
前端·人工智能·后端
山河木马10 小时前
矩阵专题0-webGL中的矩阵
javascript·webgl·计算机图形学