总所周知,vue中的transition标签能够方便得进行动画过渡,使用的方法也很简单。css
<transition name="你要的名字"> 过渡的元素... </transition>
这里须要主要一点的是:过渡的元素只能是如下之一:html
条件渲染 (使用 v-if) 条件展现 (使用 v-show) 动态组件 组件根节点
经常使用的过渡名称有fade等
你能够这样用vue
<transition name="fade"> 过渡的元素... </transition>
实现的效果就是淡入淡出。
若是须要自定义过渡动画的,记得在css中修改如下的类名:ide
你要的名字-enter 进入前效果 你要的名字-enter-active 进入的过渡时间和函数 你要的名字-enter-to 进入后效果 你要的名字-leave 离开前效果 你要的名字-leave-active 离开的过渡时间和函数 你要的名字-leave-to 离开后效果
写到这里相信你们都已经会简单地使用transition了。
请阅读如下的代码:函数
<transition name="fade"> <div v-if="show"> <div class="item-box"></div> </div> <div v-else> <span>暂无更多</span> </div> </transition>
结果是彻底没有淡入淡出的效果,那这是什么缘由致使transition不起做用呢?
缘由在这里:动画
当有相同标签名的元素切换时,须要经过 key 特性设置惟一的值来标记以让 Vue 区分它们,不然 Vue
为了效率只会替换相同标签内部的内容。即便在技术上没有必要,给在 <transition> 组件中的多个元素设置 key 是一个更好的实践。
因此须要这样写:ui
<transition name="fade"> <div v-if="show" key="box1"> <div class="item-box"></div> </div> <div v-else key="box2"> <span>暂无更多</span> </div> </transition>
刷新运行,完美实现效果~~~~spa
参考资料:https://cn.vuejs.org/v2/guide...code