解决vue的过渡动画无法正常实现问题


Posted in Javascript onOctober 31, 2019

前记:最近在写vue的一个项目要实现过渡的效果,虽然vue动画不是强项,库也多,但是基本的坑还是得踩扎实;

建议:先学习vue官方文档的进入/离开 & 列表过渡章节,那么我们来看bug;

首先上出现问题的代码

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <style type="text/css">
    .haha-leave-active {
     transition: opacity .5s;
    }
    .haha-leave-to /* .fade-leave-active below version 2.1.8 */ {
     opacity: 0;
    }
    #demo{
     position: relative;
     width: 200px;
     height: 200px;
     margin: auto;
     top: 100px;
    }
    .bug{
     position: relative;
     opacity: 1;
    }
  </style>
<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
</head>
<body>
  <div id="demo">
   <button v-on:click="show = !show">点击</button>
   <transition name="haha">
     <div class="bug" v-if="show">你好</div>
   </transition>
  </div>
  <script type="text/javascript">
    new Vue({
     el: '#demo',
     data: {
      show: true
     }
    })
  </script>
</body>
</html>

以上代码看起起来真的没有什么问题,但是复制粘贴发现过渡怎么变成了延迟,仔细阅读官方文档找不同,连连看;

我们要过度的属性是opacity,相对于官方文档我们在要过渡的div里多加了一个opacitry的属性值为1,这就导致其实整个动画过程中opacitry的值都为1而不会出现动画中由1到0的过渡;

导致这个问题的根本原因是因为css优先级的问题,div的css优先级远大于动画中css属性的优先级,所以opacity的值始终都是div中的值并不发生过渡变化;

那么解决的办法其一当然是去掉在div中的opacitry的值,从而使得只存在动画中的opacitry从而实现动画;

但是当div中的属性需要存在我们又需要过渡动画的时候,我们需要!important这尊大神去改变css的优先级;!important是使当前css的优先级达到最高当然important就是优先级最低;

来! 上正确的代码

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <style type="text/css">
    .haha-leave-active {
     transition: opacity .5s;
    }
    .haha-leave-to /* .fade-leave-active below version 2.1.8 */ {
     opacity: 0;
    }
    #demo{
     position: relative;
     width: 200px;
     height: 200px;
     margin: auto;
     top: 100px;
    }
    .bug{
     position: relative;
     opacity: 1 important;
    }
  </style>
<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
</head>
<body>
  <div id="demo">
   <button v-on:click="show = !show">点击</button>
   <transition name="haha">
     <div class="bug" v-if="show">你好</div>
   </transition>
  </div>
  <script type="text/javascript">
    new Vue({
     el: '#demo',
     data: {
      show: true
     }
    })
  </script>
</body>
</html>

这样就既可以实现过渡效果也不拆去div中优先级较高的css属性

以上这篇解决vue的过渡动画无法正常实现问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 隔行换色函数代码
Oct 24 Javascript
eclipse导入jquery包后报错的解决方法
Feb 17 Javascript
jquery插件推荐浏览器嗅探userAgent
Nov 09 Javascript
Javascript中3个需要注意的运算符
Apr 02 Javascript
Bootstrap 手风琴菜单的实现代码
Jan 20 Javascript
webpack学习--webpack经典7分钟入门教程
Jun 28 Javascript
vue.js组件vue-waterfall-easy实现瀑布流效果
Aug 22 Javascript
EasyUI创建人员树的实例代码
Sep 15 Javascript
JS动态添加的div点击跳转到另一页面实现代码
Sep 30 Javascript
详解解决使用axios发送json后台接收不到的问题
Jun 27 Javascript
分享5个顶级的JavaScript Ajax组件库
Sep 16 Javascript
Vue 实现CLI 3.0 + momentjs + lodash打包时优化
Nov 13 Javascript
VUE单页面切换动画代码(全网最好的切换效果)
Oct 31 #Javascript
js new Date()实例测试
Oct 31 #Javascript
一起写一个即插即用的Vue Loading插件实现
Oct 31 #Javascript
Vue 使用beforeEach实现登录状态检查功能
Oct 31 #Javascript
vue路由切换之淡入淡出的简单实现
Oct 31 #Javascript
vue-router之实现导航切换过渡动画效果
Oct 31 #Javascript
使用vue-router切换页面时实现设置过渡动画
Oct 31 #Javascript
You might like
PHP生成便于打印的网页
2006/10/09 PHP
记录PHP错误日志 display_errors与log_errors的区别
2012/10/09 PHP
PHP中基于ts与nts版本- vc6和vc9编译版本的区别详解
2013/04/26 PHP
PHP使用GIFEncoder类生成的GIF动态图片验证码
2014/07/01 PHP
yii的CURD操作实例详解
2014/12/04 PHP
php实现与python进行socket通信的方法示例
2017/08/30 PHP
thinkphp5.0整合phpsocketio完整攻略(绕坑)
2018/10/12 PHP
详解PHP多个进程配合redis的有序集合实现大文件去重
2019/03/06 PHP
js 页面执行时间计算代码
2009/03/04 Javascript
Javascript 页面模板化很多人没有使用过的方法
2012/06/05 Javascript
node.js操作mongoDB数据库示例分享
2014/11/26 Javascript
JS+CSS实现可以凹陷显示选中单元格的方法
2015/03/02 Javascript
js获取及判断键盘按键的方法
2015/12/01 Javascript
Bootstrap的fileinput插件实现多文件上传的方法
2016/09/05 Javascript
jQuery命名空间与闭包用法示例
2017/01/12 Javascript
详解微信小程序入门五: wxml文件引用、模版、生命周期
2017/01/20 Javascript
ES6中新增的Object.assign()方法详解
2017/09/22 Javascript
Vue的H5页面唤起支付宝支付功能
2019/04/18 Javascript
解决vue初始化项目一直停在downloading template的问题
2020/11/09 Javascript
[01:31:02]TNC vs VG 2019国际邀请赛淘汰赛 胜者组赛BO3 第一场
2019/08/22 DOTA
Python 序列化 pickle/cPickle模块使用介绍
2014/11/30 Python
利用Python写一个爬妹子的爬虫
2018/06/08 Python
Django 视图层(view)的使用
2018/11/09 Python
Python实现将通信达.day文件读取为DataFrame
2018/12/22 Python
解决django中form表单设置action后无法回到原页面的问题
2020/03/13 Python
python不到50行代码完成了多张excel合并的实现示例
2020/05/28 Python
基于HTML5的齿轮动画特效
2016/02/29 HTML / CSS
英国知名的皮手套品牌:Dents
2016/11/13 全球购物
UNIONBAY官网:美国青少年服装品牌
2019/03/26 全球购物
英国最大最好的无人机商店:Drones Direct
2019/07/12 全球购物
我有一个char * 型指针正巧指向一些int 型变量, 我想跳过它们。 为什么如下的代码((int *)p)++; 不行?
2013/05/09 面试题
SQL Server面试题
2013/04/04 面试题
EJB的角色和三个对象
2015/12/31 面试题
三八红旗手事迹材料
2014/12/26 职场文书
vue3如何优雅的实现移动端登录注册模块
2021/03/29 Vue.js
python爬取豆瓣电影TOP250数据
2021/05/23 Python