vue2知识点:Vue封装的过度与动画

简介: vue2知识点:Vue封装的过度与动画

image.png

@[toc]

3.25Vue封装的过度与动画

3.25.1知识点总结

image.png
image.png

3.25.2案例

image.png


注意点1:
最好有css动画基础,再练习这块,但我只是了解所以原封不动拷贝看效果就是,当了解即可。

【动画/过度】使用方式:


1)
定义【动画/过度】样式名称

2)
用标签包裹起来要实现动画的元素

> 使用动画方式:

java <transition name="hello" appear> <h1 v-show="isShow">你好啊!</h1> </transition> <style scoped> h1{ background-color: orange; } .hello-enter-active{ animation: atguigu 0.5s linear; } .hello-leave-active{ animation: atguigu 0.5s linear reverse; } @keyframes atguigu { from{ transform: translateX(-100%); } to{ transform: translateX(0px); } } </style>

> 使用过度方式:

java <style scoped> h1{ background-color: orange; } /* 进入的起点、离开的终点 */ .hello-enter,.hello-leave-to{ transform: translateX(-100%); } .hello-enter-active,.hello-leave-active{ transition: 0.5s linear; } /* 进入的终点、离开的起点 */ .hello-enter-to,.hello-leave{ transform: translateX(0); } </style>
注意点2:动画效果来和去只写一个就行,另一个效果直接反转动画就是

注意点3:vue要求你想让谁实现动画效果,你就用标签把它包裹起来

java <transition name="hello" appear> <h1 v-show="isShow">你好啊!</h1> </transition>
注意点4:这个和标签效果一样,最终页面都不会显示这个标签,它只作为包裹作用使用
image.png

注意点5:每个过度可以取名字,如果\定义了name属性值,那么class的样式名称前缀也得改名,不然无法自动识别,比如未定义name属性,那么类名叫.v-enter-active和.v-leave-active,如果定义了name属性name="hello",那么类名叫.hello-enter-active和.hello-leave-active,(即vue不跟动画进行对话,而是跟样式的名称进行对话。)

java <transition name="hello" appear> <h1 v-show="isShow">你好啊!</h1> </transition> <style scoped> h1{ background-color: orange; } .hello-enter-active{ animation: atguigu 0.5s linear; } .hello-leave-active{ animation: atguigu 0.5s linear reverse; } @keyframes atguigu { from{ transform: translateX(-100%); } to{ transform: translateX(0px); } } </style>
注意点6:

问题:想实现多个元素产生相同过度效果时,错误代码如下,运行发生了报错如图

<transition>
    <h1 v-show="!isShow" key="1">你好啊!</h1>
    <h1 v-show="isShow" key="2">尚硅谷!</h1>
</transition-group>

image.png

答案:报错说明\标签只能用于一个元素,如果想实现多个元素相同效果,请使用\标签。

问题:如果改成使用\标签后,运行还是报错了,感觉更严重了,下面两个过度一个都没显示,且还报错了。

答案:正确写法就是必须指定key值,这块在讲解v-for的时候着重强调要定义key的属性。
image.png

注意点7:Test3.vue使用第三方库animate.css,所以需要额外安装animate.css

使用步骤:

1)安装 npm install --save animate.css

2)引入 import 'animate.css'

3)使用3个标签即可实现【动画/过度】效果,发别是name、enter-active-class、leave-active-class,使用第三方库比较方便,就不用像Test1.vue和Test2.vue中定义一堆动画或过度\

目录
相关文章
|
10月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
777 2
|
9月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
647 137
|
12月前
|
人工智能 JSON JavaScript
VTJ.PRO 首发 MasterGo 设计智能识别引擎,秒级生成 Vue 代码
VTJ.PRO发布「AI MasterGo设计稿识别引擎」,成为全球首个支持解析MasterGo原生JSON文件并自动生成Vue组件的AI工具。通过双引擎架构,实现设计到代码全流程自动化,效率提升300%,助力企业降本增效,引领“设计即生产”新时代。
804 1
|
12月前
|
JavaScript 安全
在 Vue 中,如何在回调函数中正确使用 this?
在 Vue 中,如何在回调函数中正确使用 this?
559 0
|
前端开发 JavaScript
初识 Vue(24)---(Vue 中同时使用过渡和动画)
Vue 中同时使用过渡和动画 在上篇博客 《Vue 中使用 animate.css 库》基础上开始这篇博客 在上篇博客中,完成了 引入 animate.
1370 0
|
前端开发 内存技术
Vue_同时使用过渡和动画
在上一节我们用animate动画库,在刷新页面时没有动画 如何解决第一次就显示动画内容呢? 在transform 上加上appear 和appear-active-class <transition name='fade' appear enter-active-class='animate.
1778 0
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
1236 0
|
JavaScript
vue实现任务周期cron表达式选择组件
vue实现任务周期cron表达式选择组件
1511 4
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
1776 78

热门文章

最新文章