vue v-if transition不起作用

<transition name="动画名"></transition>

ps:过渡的元素只能是以下之一:
条件渲染 (使用 v-if)
条件展示 (使用 v-show)
动态组件
组件根节点

自定义过渡动画的,记得在css中修改以下的类名:
动画名-enter 进入前效果
动画名-enter-active 进入的过渡时间和函数
动画名-enter-to 进入后效果
动画名-leave 离开前效果
动画名-leave-active 离开的过渡时间和函数
动画名-leave-to 离开后效果

例如:

/*fade-transform*/
.fade-transform-leave-active, .fade-transform-enter-active{ 
  transition all 0.4s
}
.fade-transform-enter{ 
  opacity 0
  transform translateX(-30px)
}
.fade-transform-leave-to{ 
  opacity 0
  transform translateX(30px)
}
<transition name="fade-transform">
   <div v-if="isShow">
     <div class=""></div>
   </div>
   <div v-else>
     <span>暂无更多</span>
   </div>
</transition>

这样写完全没有淡入淡出的效果,那是什么原因导致transition不起作用呢?
原因在这里:
当有相同标签名的元素切换时,需要通过 key 特性设置唯一的值来标记以让 Vue 区分它们,否则 Vue为了效率只会替换相同标签内部的内容。
所以需要这样写:

<transition name="fade-transform">
   <div v-if="show" key="box1">
     <div class=""></div>
   </div>
   <div v-else key="box2">
     <span>暂无更多</span>
   </div>
</transition>
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值