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

小编推荐:Fundebug专注于JavaScript、微信小程序、微信小游戏,Node.js和Java线上bug实时监控。真的是一个很好用的bug监控服务,众多大佬公司都在使用。

背景

在这篇文章《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 = 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里设置了两个变量isShowisShowing来判断菜单是否展开或者正在展开,来控制点击事件,差不多像这样

handleClick(){
  if(this.data.isShowing)
    return;
  else if(!this.data.isShow)
    this.showMenu()
  else
    this.hideMenu()
}

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


作者:AddOneG
链接:https://juejin.im/post/5ac9c177f265da23884d5442

 

 

 

 

Fundebug提供JavaScript监控,支持所有主流前端框架,微信小程序监控,微信小游戏监控,后端Node.js监控。

 

您可能感兴趣的

  1. 详解1000+项目数据分析出来的10大JavaScript错误
  2. 10个用Console来Debug的高级技巧
  3. Fundebug支持区分Source Map版本
  4. Debug前端HTML/CSS
  5. Fundebug:小程序的运维中心

Fundebug专注于JavaScript、微信小程序、微信小游戏、支付宝小程序、React Native、Node.js和Java实时BUG监控。
自从2016年双十一正式上线,Fundebug累计处理了6亿+错误事件,得到了Google、360、金山软件等众多知名用户的认可。欢迎免费试用!

  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值