Vue | 显示切换(v-if与v-show,display,visibility与opacity)

本文介绍了Vue中实现显示切换的几种方式,包括v-if、v-show指令以及动态绑定display、visibility和opacity属性,并通过实例探讨它们的差异。建议在简单内容切换时使用,复杂业务组件切换推荐使用vue-router或动态组件。
摘要由CSDN通过智能技术生成


若有疑问,欢迎评论,我会尽快回复。

致读者(选读)

有些朋友是在搜索“v-show实现tab页切换”等需求时,访问到本文的。
通过改变CSS/DOM切换的思路可行,但繁琐且存在缺陷,可能会遇到页面走样,与生命周期不协调,传值麻烦等问题。
在现代前端开发中,针对tab切换类需求,更建议使用前端路由vue-router动态组件 v-bind:is来实现。
vue中的显示切换更适用于实现静态内容切换,而不适用于复杂业务组件的切换。

显示切换

在Vue中,实现显示切换,有以下几种手段:

  1. 使用v-if指令
  2. 使用v-show指令
  3. 动态绑定display
  4. 动态绑定visibility
  5. 动态绑定opacity

下面将通过案例对比它们的异同。

1.动绑display

动态绑定display,通过添加或删除“display:none”属性实现显示切换。
示例:
我们对.middle节点动态绑定display属性;
同时为.bedroom节点设置样式display: block,测试重写后代节点display属性的效果

<template>
  <div class="hello">
    <div class="top">3楼</div>
    <div class="middle" :style="display">
      <div class="bedroom room">2楼卧室</div>
      <div class="bathroom room">2楼洗手间</div>
    </div>
    <div class="bottom">Floor 3</div>
    <input type="button" @click="toggle()" value="切换">
  </div>
</template>

<script>
export default {
    
  name: "HelloWorld",
  data() {
    
    return {
    
      display: ""
    };
  },
  methods: {
    
    toggle() {
    
      if (this.display === "display:none"
  • 5
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值