摘要:本文将带你了解微信小程序开发之实现多折叠展开酷炫菜单,希望本文对大家学微信有所帮助
本文将带你了解微信小程序开发之实现多折叠展开酷炫菜单,希望本文对大家学微信有所帮助
正题上方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 来判断菜单是否展开或者正在展开,来控制点击事件,具体实现这里就不讲了
本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标移动开发之微信频道!
您输入的评论内容中包含违禁敏感词
我知道了
请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号