【Vue教程十】过渡 和 动画

一、使用过渡类名:

step1:将需要实现动画的元素用<transition>标签包起来:

<transition name="fade">
   <div v-show="isshow">动画哦</div>
</transition>

step2:定义一组过渡样式:

上图可以看出,v-enter 和 v-leave-to 样式是一样的,v-enter-active 和v-leave-active 定义的是动画持续时间等。

/* 定义进入过渡的开始状态 和 离开过渡的结束状态 */
.v-enter,
.v-leave-to {
    opacity: 0;
    transform: translateX(150px)
}

/* 定义进入和离开时候的过渡状态 */
.v-enter-active,
.v-leave-active {
    transition: all .5s ease;
}

如果你使用一个没有名字(没有name属性)的 <transition>,则 v- 是这些类名的默认前缀。如果你使用了 <transition name="my-transition">,那么 v-enter 会替换为 my-transition-enter

 

二、使用第三方CSS动画库

第三方效果链接:https://daneden.github.io/animate.css/

step1:下载 animate.css 并引用:

<link rel="stylesheet" href="./css/animate.css" />

step2:定义 transition 及属性:

<transition
    enter-active-class="fadeInRight"
    leave-active-class="fadeOutRight"
    :duration="{ enter: 500, leave: 800 }">
    <div class="animated" v-show="isshow">动画哦</div>
</transition>

注:class中需要加animated,不然动画没效果;fadeInRight 和 fadeOutRight 是动画库中的样式效果,直接拿就好。

 

三、使用动画钩子函数,可实现半场动画

step1: 定义 transition 组件以及三个钩子函数

<transition 
    v-on:before-enter="beforeEnter"
    v-on:enter="enter"
    v-on:after-enter="afterEnter">
        <div class="ball" v-show="flag"></div>
</transition>

step2:定义三个 methods 钩子方法:

methods: {
    beforeEnter(el) {
        el.style.transform = "translate(0,0)"
    },
    // done,也就是afterEnter这个函数的引用
    enter(el, done) {
        el.offsetWidth
        el.style.transform = "translate(150px,450px)"
        el.style.transition = 'all 1s ease';
        done();
    },
    afterEnter(el) {
        console.log("ok")
        this.flag = false;//隐藏小球
    },
}

 

四、列表过渡

step1:定义一组过渡样式

.v-enter,
.v-leave-to {
    opacity: 0;
    transform: translateY(150px)
}

.v-enter-active,
.v-leave-active {
    transition: all .5s ease;
}

step2:定义DOM结构,其中,需要使用 transition-group 组件把v-for循环的列表包裹起来:

<!-- <ul> -->
    <!-- 如果要为v-for创建的元素设置动画,必须设置key,不能使用transition,要用transition-group -->
    <!-- 添加appear,是为了添加入场动画效果 -->
    <!-- 通过设置tag属性,渲染为指定的元素,不设置的话,默认是span标签 -->
    <transition-group appear tag='ul'>
        <li v-for='item in items' :key='item.id' @click='del(item.id)'>{{item.id}}----{{item.name}}</li>
    </transition-group>
<!-- </ul> -->

列表的排序过渡

`v-move` 和 `v-leave-active` 结合使用,能够让列表的过渡更加平缓柔和:

.v-move{
  transition: all 0.8s ease;
}
.v-leave-active{
  position: absolute;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue提供了过渡动画的内置支持,可以通过Vue的transition组件来实现过渡动画。在transition组件中,可以定义进入动画、离开动画过渡模式等。同时,CSS也提供了丰富的动画效果,可以通过CSS的transition属性来实现过渡动画。 下面是一个使用Vue和CSS实现过渡动画的示例: ```html <template> <div> <button @click="show = !show">Toggle</button> <transition name="fade"> <p v-if="show">Hello, World!</p> </transition> </div> </template> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.5s; } .fade-enter, .fade-leave-to { opacity: 0; } </style> <script> export default { data() { return { show: false }; } }; </script> ``` 在上面的示例中,我们定义了一个按钮和一个包裹着文本的transition组件。文本的显示与隐藏通过控制show属性来实现。同时,我们也定义了一个名为"fade"的transition,它定义了进入和离开动画的方式。 在CSS中,我们定义了两个类名为"fade-enter-active"和"fade-leave-active",它们分别表示进入和离开动画的状态。这里我们使用了CSS的transition属性,它指定了过渡的属性和时长。在这个例子中,我们使用opacity属性和0.5秒的时长来实现淡入淡出的效果。 同时,我们也定义了类名为"fade-enter"和"fade-leave-to",它们分别表示进入和离开动画的初始和结束状态。在这个例子中,我们将opacity属性的值设置为0,表示文本初始时是透明的,离开时也是透明的。 通过这样的方式,我们就可以使用Vue和CSS来实现过渡动画了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值