这篇文章主要讲解了“怎么用Vue实现动画效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用Vue实现动画效果”吧!
创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、成都网站建设、蒲县网络推广、小程序开发、蒲县网络营销、蒲县企业策划、蒲县品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联公司为所有大学生创业者提供蒲县建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com
1.哪些元素/那些组件适合在那些条件下实现动画效果
条件渲染 (使用 v-if)
条件展示 (使用 v-show)
动态组件
组件根节点
简单经典例子:(文字隐藏到显示效果)
<div> <button @click="show = !show">show toggle</button> <transition name="fade"> //fade 自定义名称 <p v-if="show">hello</p> </transition> </div> <style> .fade-enter-active{ transition: opacity .5s; //类名:隐藏到显示过程所需要的时间 } .fade-enter { // 类名:初始化状态 opacity: 0; } </style>
css动画
<div> <button @click="show = !show">show toggle</button> <transition name="fade"> //fade 自定义名称 <p v-if="show">hello</p> </transition> </div> <style> .fade-enter-active { //类名:隐藏到显示过程所需要的时间 animation: bounce-in .5s; } .fade-leave-active { //类名:显示到隐藏过程所需要的时间 animation: bounce-in .5s reverse; //reverse表示和隐藏到显示动画相反 } @keyframes bounce-in { 0% { transform: scale(0); } 50% { transform: scale(1.5); } 100% { transform: scale(1); } } </style>
我们也可以自定义类名
<div> <button @click="show = !show">show toggle</button> <transition enter-class="fadeEnter" enter-active-class="fadeActive" > //fade 自定义名称 <p v-if="show">hello</p> </transition> </div> <style> .fadeActive{ transition: opacity .5s; //类名:隐藏到显示过程所需要的时间 } .fadeEnter { // 类名:初始化状态 opacity: 0; } </style>
学到这里,我们其实也可以可以引用第三方库来实现这效果,Animate.css
// 在index.html文件下引入Animate.css <link href="https://cdn.jsdelivr.net/npm/animate.css@3.5.1" rel="external nofollow" rel="stylesheet" type="text/css"> // 在组件内 <div> <button @click="show = !show">show toggle</button> <transition enter-active-class="animated tada" leave-active-class="animated bounceOutRight" > <p v-if="show">hello</p> </transition> </div>
感谢各位的阅读,以上就是“怎么用Vue实现动画效果”的内容了,经过本文的学习后,相信大家对怎么用Vue实现动画效果这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!
网页标题:怎么用Vue实现动画效果
网站地址:https://www.cdcxhl.com/article2/pdiioc.html
成都网站建设公司_创新互联,为您提供服务器托管、动态网站、网站维护、自适应网站、网站设计、营销型网站建设
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联