关于vue状态过渡transition不起作用的原因解决


Posted in Javascript onApril 09, 2019

总所周知,vue中的transition标签可以方便得进行动画过渡,使用的方法也很简单。

<transition name="你要的名字">
  过渡的元素...
</transition>

这里需要主要一点的是:过渡的元素只能是以下之一:

条件渲染 (使用 v-if)
条件展示 (使用 v-show)
动态组件
组件根节点

常用的过渡名称有fade等

你可以这样用

<transition name="fade">
  过渡的元素...
</transition>

实现的效果就是淡入淡出。

如果需要自定义过渡动画的,记得在css中修改以下的类名:

你要的名字-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 是一个更好的实践。

所以需要这样写:

<transition name="fade">
   <div v-if="show" key="box1">
     <div class="item-box"></div>
   </div>
   <div v-else key="box2">
     <span>暂无更多</span>
   </div>
</transition>

刷新运行,完美实现效果~~~~

参考资料:https://cn.vuejs.org/v2/guide/transitions.html

补充:

问题1:不同类型的组件之间切换,有过渡效果,而相同组件(不同内容)切换则没有过渡效果

vue官网的描述:当有相同标签名的元素切换时,需要通过 key 特性设置唯一的值来标记以让 Vue 区分它们,否则 Vue 为了效率只会替换相同标签内部的内容。即使在技术上没有必要,给在 组件中的多个元素设置 key 是一个更好的实践。

改进后代码

<transition :name="slide">
 <keep-alive>
  <component 
   :is="questionMap[currentQuestion.type]"
   :key="index"
   :currentQuestion="currentQuestion"
   :index="index">
  </component>
 </keep-alive>
</transition>

给组件添加了key=”index”了之后,不管任何类型都有过渡效果了,因为此时vue将每一个组件区分为不同的组件

问题2:前一个组件滑动出去后,后一个组件没有滑动效果,而是直接显示了

过渡模式有一个问题:一个离开过渡的时候另一个开始进入过渡。这是 的默认行为 - 进入和离开同时发生,因为这样也导致了两个卡片的过渡不太复合需求,我们需要的是一个先离开后另一个再进入。

同时生效的进入和离开的过渡不能满足所有要求,所以 Vue 提供了 过渡模式

  • in-out:新元素先进行过渡,完成之后当前元素过渡离开。
  • out-in:当前元素先进行过渡,完成之后新元素过渡进入。

因此我们需要在transition标签中添加mode来达成效果:

<transition :name="slide" mode="out-in">
 <keep-alive>
  <component 
   :is="questionMap[currentQuestion.type]"
   :key="index"
   :currentQuestion="currentQuestion"
   :index="index">
  </component>
 </keep-alive>
</transition>

如果要使用列表排序的话,需要使用transition-group,下面是一个简单的例子

<div id="list-demo" class="demo">
 <button v-on:click="add">Add</button>
 <button v-on:click="remove">Remove</button>
 <transition-group name="list" tag="p">
  <span v-for="item in items" v-bind:key="item" class="list-item">
   {{ item }}
  </span>
 </transition-group>
</div>
new Vue({
 el: '#list-demo',
 data: {
  items: [1,2,3,4,5,6,7,8,9],
  nextNum: 10
 },
 methods: {
  randomIndex: function () {
   return Math.floor(Math.random() * this.items.length)
  },
  add: function () {
   this.items.splice(this.randomIndex(), 0, this.nextNum++)
  },
  remove: function () {
   this.items.splice(this.randomIndex(), 1)
  },
 }
})
.list-item {
 display: inline-block;
 margin-right: 10px;
}
.list-enter-active, .list-leave-active {
 transition: all 1s;
}
.list-enter, .list-leave-to
/* .list-leave-active for below version 2.1.8 */ {
 opacity: 0;
 transform: translateY(30px);
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
基于jquery实现的类似百度搜索的输入框自动完成功能
Aug 23 Javascript
jquery插件制作 表单验证实现代码
Aug 17 Javascript
JavaScript的常见兼容问题及相关解决方法(chrome/IE/firefox)
Dec 31 Javascript
一款由jquery实现的整屏切换特效
Sep 15 Javascript
jquery实现相册一下滑动两次的方法
Feb 09 Javascript
webpack中引用jquery的简单实现
Jun 08 Javascript
利用jQuery.Validate异步验证用户名是否存在(推荐)
Dec 09 Javascript
bootstrap3使用bootstrap datetimepicker日期插件
May 24 Javascript
Angular 2.0+ 的数据绑定的实现示例
Aug 09 Javascript
小程序实现层叠卡片滑动效果
Aug 26 Javascript
vue 指令和过滤器的基本使用(品牌管理案例)
Nov 04 Javascript
详解Vue.js 响应接口
Jul 04 Javascript
vue实现文字横向无缝走马灯组件效果的实例代码
Apr 09 #Javascript
Angular脚手架开发的实现步骤
Apr 09 #Javascript
详解vue 自定义marquee无缝滚动组件
Apr 09 #Javascript
javascript实现手动点赞效果
Apr 09 #Javascript
实例分析Array.from(arr)与[...arr]到底有何不同
Apr 09 #Javascript
浅谈Vue.js组件(二)
Apr 09 #Javascript
4 种滚动吸顶实现方式的比较
Apr 09 #Javascript
You might like
《忧国的莫里亚蒂》先导宣传图与STAFF公开
2020/03/04 日漫
PHP+javascript制作带提示的验证码源码分享
2014/05/28 PHP
PHP中捕获超时事件的方法实例
2015/02/12 PHP
php实现简单的上传进度条
2015/11/17 PHP
Yii框架中jquery表单验证插件用法示例
2016/10/18 PHP
基于jQuery的烟花效果(运动相关)点击屏幕出烟花
2012/06/14 Javascript
jquery获得页面元素的坐标值实现思路及代码
2013/04/15 Javascript
js判断字符长度以及中英文数字等
2013/12/31 Javascript
JavaScript数值数组排序示例分享
2014/05/27 Javascript
JavaScript导出Excel实例详解
2014/11/25 Javascript
JS实现简单的键盘打字的效果
2015/04/24 Javascript
js仿iphone秒表功能 计算平均数
2017/01/11 Javascript
关于AngularJs数据的本地存储详解
2017/01/20 Javascript
jQuery滚动监听实现商城楼梯式导航效果
2017/03/06 Javascript
React Native预设占位placeholder的使用
2017/09/28 Javascript
Vue自定义过滤器格式化数字三位加一逗号实现代码
2018/03/23 Javascript
详解基于vue的服务端渲染框架NUXT
2018/06/20 Javascript
在vue项目中使用sass语法问题
2019/07/18 Javascript
Vue 3.0 前瞻Vue Function API新特性体验
2019/08/12 Javascript
Vue根据条件添加click事件的方式
2019/11/09 Javascript
[48:31]完美世界DOTA2联赛PWL S3 DLG vs Phoenix 第二场 12.17
2020/12/19 DOTA
python中常用的九种预处理方法分享
2016/09/11 Python
python搭建服务器实现两个Android客户端间收发消息
2018/04/12 Python
python utc datetime转换为时间戳的方法
2019/01/15 Python
浅谈sklearn中predict与predict_proba区别
2020/06/28 Python
如何基于Python Matplotlib实现网格动画
2020/07/20 Python
Python 使用Opencv实现目标检测与识别的示例代码
2020/09/08 Python
会计电算化专业个人的自我评价
2013/11/24 职场文书
物理教师自荐信范文
2013/12/28 职场文书
考试不及格的检讨书
2014/01/22 职场文书
青年志愿者活动总结
2014/04/26 职场文书
2014年母亲节演讲稿范文
2014/05/07 职场文书
社区服务活动小结
2014/07/08 职场文书
研究生毕业登记表的自我鉴定范文
2019/07/15 职场文书
Python实现学生管理系统并生成exe可执行文件详解流程
2022/01/22 Python
Python的property属性详细讲解
2022/04/11 Python