• 注册
当前位置:1313e > 小程序 >正文

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

背景

在这篇文章《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(动态改变Class)就Ojbk啦,就像这样

<view class='main-view-item rotateX90 item1 {{item1Style}}' animation='{{item1}}'>view>
复制代码

实际情况应该用wx:for进行循环渲染

var duration = 150var 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 = 150var item3 = wx.createAnimation({duration: duration,transformOrigin: '100% 100% 0',delay: duration * 2
})item1.rotateX(90).step()this.setData({item3: item3,item3Style: ''
})
复制代码

另外我在data里设置了两个变量isShowisShowing来判断菜单是否展开或者正在展开,来控制点击事件,差不多像这样

handleClick(){if(this.data.isShowing)return;else if(!this.data.isShow)this.showMenu()elsethis.hideMenu()
}
复制代码

在动画完成后对isShowisShowing进行修改即可

欢迎有更好想法的朋友进行讨论~

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 162202241@qq.com 举报,一经查实,本站将立刻删除。

最新评论

欢迎您发表评论:

请登录之后再进行评论

登录