亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

微信小程序實現多折疊展開酷炫菜單

作者:AddOneG 原文地址
背景
在这篇文章《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里设置了两个变量isShow和isShowing来判断菜单是否展开或者正在展开,来控制点击事件,差不多像这样

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

在动画完成后对isShow和isShowing进行修改即可

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

點擊查看更多內容
1人點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消