商城系統(tǒng) 注冊(cè)

小程序?qū)崿F(xiàn)多折疊展開(kāi)菜單

2020-09-27|HiShop
導(dǎo)讀:小程序?qū)崿F(xiàn)多折疊展開(kāi)菜單非常常見(jiàn),想實(shí)現(xiàn)也非常簡(jiǎn)單,下面為大家介紹如何實(shí)現(xiàn)的方式...

小程序?qū)崿F(xiàn)多折疊展開(kāi)菜單非常常見(jiàn),想實(shí)現(xiàn)也非常簡(jiǎn)單,下面為大家介紹如何實(shí)現(xiàn)的方式

小程序?qū)崿F(xiàn)多折疊展開(kāi)菜單效果展示:

小程序?qū)崿F(xiàn)多折疊展開(kāi)菜單

  開(kāi)始正題

  上方Nav

  基本 flex 布局再加個(gè) padding 不需要多講吧?

  提一下,微信小程序里input的placeholder樣式是寫(xiě)在 placeholder-style 里或使用 placeholder-class

  下方菜單

小程序?qū)崿F(xiàn)多折疊展開(kāi)菜單

  每個(gè)小卡片遵從 flex 布局,設(shè)置 width: 50% ,別忘了 flex-wrap: wrap

  每個(gè)小卡片內(nèi)部同為 flex 布局并設(shè)置垂直居中,想了想還是科普下:

  .main-view-item{

  display: flex;

  justify-content: center;

  align-items: center;

  width: 50%;

  }

  動(dòng)畫(huà)

  微信小程序的動(dòng)畫(huà)只能用JS,常規(guī)手段不可用,來(lái)個(gè)頭腦風(fēng)暴hack起來(lái)

  觀察每個(gè)卡片的折疊方向后,為每個(gè)卡片添加初始 rotate 使其反向折疊,我在這里定義了兩個(gè)Class

  .rotateX90{

  transform: rotateX(-90deg);

  }

  .rotateY90{

  transform: rotateY(-90deg);

  }

  好了這樣就看不到卡片了,然后給菜單按鈕添加點(diǎn)擊事件改變卡片的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 來(lái)控制折疊方向,對(duì)于后面的卡片在 createAnimation 中添加 delay 字段即可(差為 duration 的等差數(shù)列)

  是不是很簡(jiǎn)單嗯?

  至于菜單的收回,代碼和展開(kāi)差不多,就是反過(guò)來(lái)而已,不過(guò)有些展開(kāi)的順序和 transformOrigin 需要注意,這里還是貼一個(gè)代碼吧:

  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è)置了兩個(gè)變量 isShow 和 isShowing 來(lái)判斷菜單是否展開(kāi)或者正在展開(kāi),來(lái)控制點(diǎn)擊事件,具體實(shí)現(xiàn)這里就不講了

HiShop小程序工具提供多類(lèi)型商城/門(mén)店小程序制作,可視化編輯 1秒生成5步上線。通過(guò)拖拽、拼接模塊布局小程序商城頁(yè)面,所看即所得,只需要美工就能做出精美商城。

更多小程序開(kāi)發(fā)案例,盡在:http://westcoastpropertyservices.com/xiaocx/kaifa.html 

電話咨詢(xún) 預(yù)約演示 0元開(kāi)店