当只用 JavaScript 过渡的时候,在 enter 和 leave 中必须使用 done 进行回调。否则,它们将被同步调用,过渡会立即完成。
推荐对于仅使用 JavaScript 过渡的元素添加 v-bind:css="false",Vue 会跳过 CSS 的检测。这也可以避免过渡过程中 CSS 的影响。
一个js动画的简单 例子:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Vue 动画</title>
<script src="./vue.js"></script>
<link href="https://cdn.jsdelivr.net/npm/animate.css@3.5.1" rel="stylesheet" type="text/css">
<!--Velocity 和 jQuery.animate 的工作方式类似,也是用来实现 JavaScript 动画的一个很棒的选择-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.3/velocity.min.js"></script>
<style>
</style>
</head>
<body>
<div id="root">
<transition name="fade" @before-enter="handleBeforeEnter" @enter="handlerEnter" @after-enter="handleAfterEnter">
<h1 v-show="show">Hello World</h1>
</transition>
<button @click="handleClick">toggle</button>
</div>
<script>
var app = new Vue({
el: " #root ",
data: {
show: true
},
methods: {
handleClick: function() {
this.show = !this.show;
},
handleBeforeEnter: function(el) { //el指动画包裹的div标签
console.log('beforeEnter');
el.style.color = 'red';
},
handlerEnter: function(el, done) { //done是回调函数
setTimeout(() => { //2s green
el.style.color = "green"
}, 2000)
setTimeout(() => { //再2s后 black
el.style.color = "black"
}, 4000)
},
handleAfterEnter: function(el) {
el.style.color = "#000"
},
}
})
</script>
</body>
</html>
几个钩子名称:
before-enter,enter,after-enter,before-leave,leave,after-leave
一使用 Velocity.js 的简单例子:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Vue 动画</title>
<script src="./vue.js"></script>
<link href="https://cdn.jsdelivr.net/npm/animate.css@3.5.1" rel="stylesheet" type="text/css">
<!--Velocity 和 jQuery.animate 的工作方式类似,也是用来实现 JavaScript 动画的一个很棒的选择-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.3/velocity.min.js"></script>
<style>
</style>
</head>
<body>
<div id="root">
<transition name="fade" @before-enter="handleBeforeEnter" @enter="handlerEnter" @after-enter="handleAfterEnter">
<h1 v-show="show">Hello World</h1>
</transition>
<button @click="handleClick">toggle</button>
</div>
<script>
var app = new Vue({
el: " #root ",
data: {
show: true
},
methods: {
handleClick: function() {
this.show = !this.show;
},
handleBeforeEnter: function(el) { //el指动画包裹的div标签
el.style.opacity = 0;
},
handlerEnter: function(el, done) { //done是回调函数
Velocity(el, {
opacity: 1
}, { //complete:done 当执行动画之后,done回调会被执行
duration: 1000,
complete: done
})
},
handleAfterEnter: function(el) {
alert("动画结束")
},
}
})
</script>
</body>
</html>
本文介绍了如何在Vue.js中使用JavaScript实现过渡效果和动画。通过示例代码详细展示了使用回调函数控制动画流程的方法,并提供了使用Velocity.js简化动画实现的具体步骤。
296

被折叠的 条评论
为什么被折叠?



