微信小程序沒有自帶的下拉菜單組件,因此我們需要自己需要寫一個
思路
利用列表來存儲菜單項,在外面套一個view元素作為外框,將其設置為overflow:hidden,使用CSS3動畫逐漸改變外層view元素的高度,當高度為0時,里面嵌套的列表元素被完全隱藏,相當于菜單關閉。而當view元素的高度大于列表元素的高度時,相當于菜單顯示。
效果圖
wxml
button按鈕用于觸發(fā)菜單的打開和關閉,first_click參數(shù)使用戶第一次點擊按鈕之前菜單不可見,state參數(shù)用于控制菜單的打開和關閉狀態(tài)
<view id="text_box"> <text decode='true'> 歷 史 記 錄</text> </view> <button id="slide" bindtap="toggle">▼</button> <view id="box" class="{{first_click?'show':'hide'}} {{state?'open':'close'}}"> <view id="item_list"> <view>111</view> <view>222</view> <view>333</view> </view> </view>
css
使用@keyframes動畫實現(xiàn)菜單的漸變打開和關閉動畫
#box{ width: 100%; border-top: 1px solid #ddd; overflow: hidden; height: 0; animation-fill-mode: forwards; } #item_list{ background-color: white; width: 100%; } #item_list view{ text-align: right; overflow: auto; white-space: nowrap; } @keyframes slidedown{ from { height: 0; } to { height: 240rpx; } } @keyframes slideup{ from { height: 240rpx; } to { height: 0; } } .open{ animation: slidedown 1s; } .close{ animation: slideup 1s; } .hide{ display: none; } .show{ display: block; }
js
頁面加載完成時,菜單初始狀態(tài)為隱藏和關閉,用戶一旦點擊按鈕,菜單就顯示,并逐漸打開
data: { state:false, first_click:false, }, toggle: function(){ var list_state = this.data.state, first_state = this.data.first_click; if (!first_state){ this.setData({ first_click: true }); } if (list_state){ this.setData({ state: false }); }else{ this.setData({ state: true }); } }
聲明:本網(wǎng)頁內容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com