欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 微信开发 > 微信小程序实现多折叠展开酷炫菜单

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:789

HTML5自适应律师工作室类网

2020-04-04   浏览:654

高端HTML5响应式企业通用网

2020-05-06   浏览:560

html5响应式外贸网站英文版

2020-05-08   浏览:545

HTML5影视传媒文化公司类网

2020-05-12   浏览:543

微信小程序实现多折叠展开酷炫菜单

发布时间:2020-10-27  

在另一篇文章《2018年设计趋势指南》中发现一款菜单不错,就想着用微信小程序实现

先把成果摆上来  

微信小程序实现多折叠展开酷炫菜单

开始正题 上方Nav

基本 flex 布局再加个 padding 不需要多讲吧?

提一下,微信小程序里input的placeholder样式是写在 placeholder-style 里或使用 placeholder-class

下方菜单

每个小卡片遵从 flex 布局,设置 width: 50% ,别忘了 flex-wrap: wrap

每个小卡片内部同为 flex 布局并设置垂直居中,想了想还是科普下:

.main-view-item{ display: flex; justify-content: center; align-items: center; width: 50%; }

flex真他娘的好用

至于里面的图片是从iconfont上拿的,调这几个配色的时间是我布局时间的几十倍....

动画

微信小程序的动画只能用JS,常规手段不可用,来个头脑风暴hack起来

观察每个卡片的折叠方向后,为每个卡片添加初始 rotate 使其反向折叠,我在这里定义了两个Class

.rotateX90{ transform: rotateX(-90deg); } .rotateY90{ transform: rotateY(-90deg); }

好了这样就看不到卡片了,然后给菜单按钮添加点击事件改变卡片的rotate就Ojbk啦

var duration = 150 var item1 = wx.createAnimation({ duration: duration, transformOrigin: '0 0 0' }) item1.rotateX(90).step() this.setData({ item1: item1, item1Style: 'item1Style' })

这里注意调整 transformOrigin 来控制折叠方向,对于后面的卡片在 createAnimation 中添加 delay 字段即可(差为 duration 的等差数列)

是不是很简单嗯?

至于菜单的收回,代码和展开差不多,就是反过来而已,不过有些展开的顺序和 transformOrigin 需要注意,这里还是贴一个代码吧:

var duration = 150 var item3 = wx.createAnimation({ duration: duration, transformOrigin: '100% 100% 0', delay: duration * 2 }) item1.rotateX(90).step() this.setData({ item3: item3, item3Style: '' })

另外我在 data 里设置了两个变量 isShow 和 isShowing 来判断菜单是否展开或者正在展开,来控制点击事件,具体实现这里就不讲了