在另一篇文章《2018年設(shè)計趨勢指南》中發(fā)現(xiàn)一款菜單不錯,就想著用微信小程序?qū)崿F(xiàn)
基本 flex 布局再加個 padding 不需要多講吧?
提一下,微信小程序里input的placeholder樣式是寫在 placeholder-style 里或使用 placeholder-class
.main-view-item{ display: flex; justify-content: center; align-items: center; width: 50%; }
flex真他娘的好用
至于里面的圖片是從iconfont上拿的,調(diào)這幾個配色的時間是我布局時間的幾十倍....
微信小程序的動畫只能用JS,常規(guī)手段不可用,來個頭腦風(fēng)暴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' })
這里注意調(diào)整 transformOrigin 來控制折疊方向,對于后面的卡片在 createAnimation 中添加 delay 字段即可(差為 duration 的等差數(shù)列)
是不是很簡單嗯?
至于菜單的收回,代碼和展開差不多,就是反過來而已,不過有些展開的順序和 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 里設(shè)置了兩個變量 isShow 和 isShowing 來判斷菜單是否展開或者正在展開,來控制點擊事件,具體實現(xiàn)這里就不講了