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的渲染。

相关推荐
掘金安东尼4 小时前
让 JavaScript 更容易「善后」的新能力
前端·javascript·面试
掘金安东尼4 小时前
用 HTMX 为 React Data Grid 加速实时更新
前端·javascript·面试
灵感__idea6 小时前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
yinuo6 小时前
轻松接入大语言模型API -04
前端
袋鼠云数栈UED团队7 小时前
基于 Lexical 实现变量输入编辑器
前端·javascript·架构
cipher7 小时前
ERC-4626 通胀攻击:DeFi 金库的"捐款陷阱"
前端·后端·安全
UrbanJazzerati7 小时前
非常友好的Vue 3 生命周期详解
前端·面试
AAA阿giao7 小时前
从零构建一个现代登录页:深入解析 Tailwind CSS + Vite + Lucide React 的完整技术栈
前端·css·react.js
亦妤7 小时前
JS执行机制、作用域及作用域链
javascript
兆子龙8 小时前
像 React Hook 一样「自动触发」:用 Git Hook 拦住忘删的测试代码与其它翻车现场
前端·架构