微信小程序动画组件使用解析,类似vue,且更强大
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了微信小程序动画组件使用解析,类似vue,且更强大,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3105字,纯文字阅读大概需要5分钟。
内容图文
演示
演示1
演示2
演示3
一、功能描述
1、预设过渡
- 支持区分enter、leave
- 支持预设过渡的组合
- 特别强调:支持元素展开、闭合的过渡。name=='slide'或['slide'[,]],即可实现,无需外部传height
- 支持外部传类来过渡或动画
/* 预留过渡 */ /** *1、fade *2、移动:up,right,down,left四个方向 *3、scale缩放:默认是从0->1,还预设了一个从1->1.2的 *4、rotate旋转。顺时针旋转。角度用以上方向来指示。如果逆时针中间加上reserve。 如rotate-right表示选择180度,rotate-down-reserve表示逆时针旋转90度。 预设了,90,180,270,360;-90.-180,-270,-360角度的旋转 *5、slide:内容块张开还是隐藏。 √ *说明:以上是整体过渡的单元:传name的时候,可以多个组合,形成更加复杂的过渡。 *如果这些组合,还不够你的使用,可以部分或全部过渡通过外部传类来实现。 */
2、蒙层相关功能
- 无蒙层:mask:0。//此时过渡元素为卡槽
- 透明蒙层1:mask:1。//此时过渡元素为卡槽。如:左移100%,只是移动卡槽宽度的100%
- 透明蒙层2:mask:2。//此时过渡元素为蒙层。如:左移100%,则是移动蒙层宽度的100%
- 半透明蒙层3:mask:3。///此时过渡元素为蒙层。如:弹窗上移,则是蒙层上移。
- 半透明蒙层4:mask:4。///此时过渡元素为卡槽。如:弹窗上移,则是蒙层自身是缩放。卡槽上移
3、卡槽样式完美设置
- 由以上可知。蒙层由多种情况。但
- 完美支持百分比设置:外部传custom-class即可
4、其它细节
- 完美支持自定义top、tab导航情况
- 蒙层(包括透明蒙层)下,预设5个布局位置:结合方向等,可实现左右抽屉、上下弹出、中间淡入淡出等效果
- 支持leave动画结束后,通知父节点:可实现多节点联动。如:手风琴效果
5、支持所有的节点。包括组件作为卡槽内容
- 对需要动画的元素/组件套上这个组件即可实现过渡动画
- 其实整个小程序页面做进入过渡,也挺炫酷的。类似支付宝页面进蚂蚁森林
二、可传属性(可配置项)
过渡相关类
externalClasses: [ 'enter-class', 'enter-active-class', 'enter-to-class', 'leave-class', 'leave-active-class', 'leave-to-class', ],
内容(卡槽)样式
externalClasses:[ 'custom-class', ]
说明:完美支持像素、百分比、或者absolute的设置
配置项
properties: { name: { type: [String,Object,Array],//支持区分enter、leave过渡 value:{ enter:{ type:[String,Array], value:['up','fade'],//支持传数组,即内设的过渡,可组合 }, leave:"fade" } }, show: { type: Boolean, value: false }, duration: { //run Time ms type: [String,Number,Object],//`过渡时间,支持区分enter、leave。如果enter不需要过渡,enter:0即可` value:{ enter:300, leave:300, } }, //leave过渡之后状态是否保留。而不是display:none //带有mask,避免影响页面操作。这边强制禁止保留状态。适用于非mask的情况。mask:0和1、2(1、2是全透明的,设置了属性虽然不会影响页面操作。建议不宜保留) retain:{ type:Boolean, value:false }, mask: { //`支持选蒙层类型:预设5中类型` 以下四个个是配套的,针对mask的配置 type: [String,Number],//如果为0,表示没有蒙层。1、2:全透明蒙层 value: '0', }, //顶部的margin。如果没有自定义navBar或tabBar则,fixed区域为中间的可视区域。否则为中间可视区域+自定义bar区域。 //因此为了兼容,如果自定义了bar,则要传值进来修正蒙层的区域。 margin:{//记得带上单位哦。 type: Object, value:{ top:'0px', bottom:'0px',} }, position: { //`支持卡槽位置:top、right、bottom、left、center`如果有mask,则mask中的卡槽位置是哪里。如果要再偏移,则外部卡槽使用margin来实现即可 type: String, value: "right", }, close: { //如果有mask,点击Mask是否关闭蒙层 type: Boolean, value: false }
三、完整代码(demo)
git代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
内容总结
以上是互联网集市为您收集整理的微信小程序动画组件使用解析,类似vue,且更强大全部内容,希望文章能够帮你解决微信小程序动画组件使用解析,类似vue,且更强大所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。