微信小程序页面缩放式侧滑效果的实现代码
2019/6/26 23:21:31
本文主要是介绍微信小程序页面缩放式侧滑效果的实现代码,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
先给大家展示下效果图,大家感觉不错,请参考实现代码:
实现原理:点击按钮,往需要动画的div中添加或移除拥有动画效果的class。
由于微信小程序中不能操作page这个根节点,所以,只有用一个div(view)
来模仿page根节点。
1.结构
<view class='page {{isFix?"pageShow":"pageHide"}}' > <view class='header'> <view class='h-toggle iconfont icon-list' bindtap='pageBtn'></view> </view> </view> <view class='r-box {{isFix?"fixShow":"fixHide"}}' bindtap='fixHide'> <view class='r-list' catchtap='fixStopBu'> <view class='rl-close' catchtap='fixClose'> <text class='iconfont icon-close'></text> </view> </view> </view>
上面的是最主要的结构,其它的内容就不贴了。
(1) isFix是切换动画名的状态
(2) r-box设置了bindtap点击事件之后,r-list也设置了一个不冒泡的catchtap事件,是为了实现点击r-box的空白处时,不冒泡的效果。
2.样式
page { height: 100%; width: 100%; } .page { width: 100%; height: 100%; box-shadow: 0 0 10px rgba(26,26,26,.1); } .r-box { position: fixed; top: 0; right: 0; width: 100%; height: 100%; } .r-box .r-list { float: right; width: 66%; height: 100%; background: white; } .fixHide { transition: all .3s ease; transform: translateX(100%); } .fixShow { transition: all .3s ease; transform: translateX(0%); } .pageHide { transition: all .3s ease; transform: translateX(0) scaleY(1); } .pageShow { transition: all .3s ease; transform: translateX(-70%) scaleY(0.9); }
这些是最主要的样式:
(1) class为page的div(view),就是模拟整个page页面,所以宽高需要设为100%。
(2) r-box是右边侧滑的div(view)
(3) fixHide,fixShow这是侧滑栏的动画效果。
(4) pageHide,pageShow这是整个页面的动画效果
(5) 由于transform只能出现一次,所以当有两个即以上的动画效果时,只写在一个transform里,然后把不同的动画效果分开就行。
(6) 过渡效果的速度曲线我使用的是ease,如果用linear,在手机上会感觉很卡顿。
3.js
Page({ data:{ isFix:false,//右侧列表是否显示 }, // 右侧列表显示按钮 pageBtn:function(){ this.setData({ isFix:true }) }, //右侧列表空白点击 fixHide:function(){ this.setData({ isFix: false }) }, //右侧列表防冒泡,必须有,虽然没内容 fixStopBu: function () {}, //右侧列表关闭按钮 fixClose:function(){ this.setData({ isFix:false }) }, })
实现的过程大致就是这样。还是挺简单的。不知道用小程序的动画api做起来会不会简单一些或者更顺畅一点,这个就看自己勤不勤了。
总结
以上所述是小编给大家介绍的微信小程序页面缩放式侧滑效果的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对找一找教程网网站的支持!
这篇关于微信小程序页面缩放式侧滑效果的实现代码的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-30React Native常用组件-点击组件
- 2024-05-30uniapp+vue3+uv-ui手机端后台OA管理模板
- 2024-05-29Python网络爬虫的时候json=就是让你少写个json.dumps()
- 2024-05-27React Native常用组件-展示组件
- 2024-05-27React Native常用组件-列表组件
- 2024-05-09vue3开发前端表单缓存自定义指令,移动端h5必备插件
- 2024-05-09React Hooks在class组件中的使用方式
- 2024-03-30[OIDC in Action] 2. 基于OIDC(OpenID Connect)的SSO(纯JS客户端)
- 2024-03-29terraform jsonencode
- 2024-03-13vuex-persist