微信小程序下拉菜單效果的實(shí)例代碼
//wcss /**DropDownMenu**/ /*總菜單容器*/ .menu { display: block; height: 28px; position: relative; } /*一級(jí)菜單*/ .menu dt { font-size: 15px; float: left; /*hack*/ width: 33%; height: 38px; border-right: 1px solid #d2d2d2; border-bottom: 1px solid #d2d2d2; text-align: center; background-color: #f4f4f4; color: #5a5a5a; line-height: 38px; z-index: 2; }
/*二級(jí)菜單外部容器樣式*/ .menu dd { position: absolute; width: 100%; margin-top: 40px; left: 0; z-index: -99; } /*二級(jí)菜單普通樣式*/ .menu li { font-size: 14px; line-height: 34px; color: #575757; height: 34px; display: block; padding-left: 8px; background-color: #fff; border-bottom: 1px solid #dbdbdb; } /*二級(jí)菜單高亮樣式*/ .menu li.highlight { background-color: #f4f4f4; color: #48c23d; } /* 顯示與隱藏 */ .show { /*display: block;*/ visibility: visible; } .hidden { /*display: none;*/ visibility: hidden; } //wxml <dl class="menu"> <block wx:for="{{reportData}}" wx:key="idMenu" wx:for-item="menuItem" wx:for-index="idMenu"> <dt data-index="{{idMenu}}" bindtap="tapMainMenu">{{menuItem.reportType}}</dt> <dd class="{{subMenuDisplay[idMenu]}}" animation="{{animationData[idMenu]}}"> <ul wx:for="{{menuItem.chilItem}}" wx:key="chilItem.ID" wx:for-item="chilItem" wx:for-index="idChil"> <li class="{{subMenuHighLight[idMenu][idChil]}}" bindtap="tapSubMenu" data-index="{{idMenu}}-{{idChil}}">{{chilItem.Name}}</li> </ul> <picker class="timePicker" mode="date" value="{{dateValue}}" bindchange="datePickerBindchange" start="1999-01-01" end="2999-12-12"> 時(shí)間:{{dateValue}}</picker> </dd> </block> </dl> //js //數(shù)據(jù)源 var ReportDataSync = [ { reportType: "日?qǐng)?bào)1", chilItem: [ { ID: 1, Name: "日?qǐng)?bào)1", ReportUrl: "DailyReport.aspx", Type: 1 }, { ID: 2, Name: "日?qǐng)?bào)2", ReportUrl: "DailyReport.aspx", Type: 1 }, { ID: 3, Name: "日?qǐng)?bào)3", ReportUrl: "DailyReport.aspx", Type: 1 }] }, { reportType: "目錄2", chilItem: [ { ID: 1, Name: "目錄1", ReportUrl: "DailyReport.aspx", Type: 2 }, { ID: 2, Name: "目錄2", ReportUrl: "DailyReport.aspx", Type: 2 }, { ID: 3, Name: "目錄3", ReportUrl: "DailyReport.aspx", Type: 2 }, { ID: 4, Name: "目錄4", ReportUrl: "DailyReport.aspx", Type: 2 }] }, { reportType: "月報(bào)3", chilItem: [ { ID: 1, Name: "月報(bào)1", ReportUrl: "DailyReport.aspx", Type: 1 }, { ID: 2, Name: "月報(bào)2", ReportUrl: "DailyReport.aspx", Type: 2 }] } ] //定義字段 var initSubMenuDisplay = [] var initSubMenuHighLight = [] var initAnimationData = [] /// 初始化DropDownMenu loadDropDownMenu() that.setData({ reportData: ReportDataSync,//菜單數(shù)據(jù) subMenuDisplay: initSubMenuDisplay, //一級(jí) subMenuHighLight: initSubMenuHighLight, //二級(jí) animationData: initAnimationData //動(dòng)畫(huà) }) //一級(jí)菜單點(diǎn)擊 tapMainMenu: function (e) { //獲取當(dāng)前一級(jí)菜單標(biāo)識(shí) var index = parseInt(e.currentTarget.dataset.index); //改變顯示狀態(tài) for (var i = 0; i < initSubMenuDisplay.length; i++) { if (i == index) { if (this.data.subMenuDisplay[index] == "show") { initSubMenuDisplay[index] = 'hidden' } else { initSubMenuDisplay[index] = 'show' } } else { initSubMenuDisplay[i] = 'hidden' } } this.setData({ subMenuDisplay: initSubMenuDisplay }) this.animation(index) }, //二級(jí)菜單點(diǎn)擊 tapSubMenu: function (e) { //隱藏所有一級(jí)菜單 //this.setData({ //subMenuDisplay: initSubMenuDisplay() //}); // 當(dāng)前二級(jí)菜單的標(biāo)識(shí) var indexArray = e.currentTarget.dataset.index.split('-'); // 刪除所在二級(jí)菜單樣式 for (var i = 0; i < initSubMenuHighLight.length; i++) { if (indexArray[0] == i) { for (var j = 0; j < initSubMenuHighLight[i].length; j++) { initSubMenuHighLight[i][j] = ''; } } } //給當(dāng)前二級(jí)菜單添加樣式 initSubMenuHighLight[indexArray[0]][indexArray[1]] = 'highlight'; //刷新樣式 this.setData({ subMenuHighLight: initSubMenuHighLight }); // 設(shè)置動(dòng)畫(huà) this.animation(indexArray[0]); }, //菜單動(dòng)畫(huà) animation: function (index) { // 定義一個(gè)動(dòng)畫(huà) var animation = wx.createAnimation({ duration: 400, timingFunction: 'linear', }) // 是顯示還是隱藏 var flag = this.data.subMenuDisplay[index] == 'show' ? 1 : -1; // 使之Y軸平移 animation.translateY(flag * ((initSubMenuHighLight[index].length + 1) * 38)).step(); // 導(dǎo)出到數(shù)據(jù),綁定給view屬性 var animationStr = animation.export(); // 原來(lái)的數(shù)據(jù) var animationData = this.data.animationData; animationData[index] = animationStr; this.setData({ animationData: animationData }); } /// <summary> /// 初始化DropDownMenu /// 1.一級(jí)目錄 initSubMenuDisplay :['hidden'] /// 2.二級(jí)目錄 initSubMenuHighLight :[['',''],['','','','']]] /// </summary> function loadDropDownMenu() { for (var i = 0; i < ReportDataSync.length; i++) { //一級(jí)目錄 initSubMenuDisplay.push('hidden') //二級(jí)目錄 var report = [] for (var j = 0; j < ReportDataSync[i].chilItem.length; j++) { report.push(['']) } initSubMenuHighLight.push(report) //動(dòng)畫(huà) initAnimationData.push("") } }
總結(jié)
以上所述是小編給大家介紹的微信小程序下拉菜單效果的實(shí)例代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
- 微信小程序?qū)崿F(xiàn)彈出菜單動(dòng)畫(huà)
- 微信小程序?qū)崿F(xiàn)單列下拉菜單效果
- 微信小程序基于picker實(shí)現(xiàn)級(jí)聯(lián)菜單
- 微信小程序?qū)崿F(xiàn)炫酷的彈出式菜單特效
- 微信小程序MUI側(cè)滑導(dǎo)航菜單示例(Popup彈出式,左側(cè)滑動(dòng),右側(cè)不動(dòng))
- 微信小程序?qū)崿F(xiàn)跟隨菜單效果和循環(huán)嵌套加載數(shù)據(jù)
- 微信小程序 action-sheet 反饋上拉菜單簡(jiǎn)單實(shí)例
- 微信小程序-可移動(dòng)菜單的實(shí)現(xiàn)過(guò)程詳解
相關(guān)文章
JavaScript實(shí)現(xiàn)的微信二維碼圖片生成器的示例
二維碼分享功能大多是由后端實(shí)現(xiàn)的,對(duì)服務(wù)器的負(fù)載較重,這里有一個(gè)前端實(shí)現(xiàn)的版本,本文介紹了JavaScript實(shí)現(xiàn)的微信二維碼圖片生成器的示例,有需要的可以了解一下。2016-10-10JS常見(jiàn)面試試題總結(jié)【去重、遍歷、閉包、繼承等】
這篇文章主要介紹了JS常見(jiàn)面試試題,總結(jié)分析了javascript去重、遍歷、閉包、繼等相關(guān)算法與操作技巧,需要的朋友可以參考下2019-08-08es6中的解構(gòu)賦值、擴(kuò)展運(yùn)算符和rest參數(shù)使用詳解
這篇文章分別給大家介紹了關(guān)于es6中解構(gòu)賦值、擴(kuò)展運(yùn)算符和rest參數(shù)使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09一文詳解如何在項(xiàng)目中和平時(shí)練習(xí)中應(yīng)用es6語(yǔ)法
ES6是JavaScript的一個(gè)版本,因?yàn)槲覀兦懊嬗玫降膙ue默認(rèn)使用ES6語(yǔ)法開(kāi)發(fā),所以我們?cè)谶@一節(jié)補(bǔ)充ES6的知識(shí)點(diǎn),下面這篇文章主要給大家介紹了關(guān)于如何在項(xiàng)目中和平時(shí)練習(xí)中應(yīng)用es6語(yǔ)法的相關(guān)資料,需要的朋友可以參考下2022-11-11javascript代碼簡(jiǎn)寫(xiě)的幾種常用方式匯總
任何一種編程語(yǔ)言的簡(jiǎn)寫(xiě)小技巧都是為了幫助你寫(xiě)出更簡(jiǎn)潔、更完善的代碼,讓你用更少的編碼實(shí)現(xiàn)你的需求,這篇文章主要給大家介紹了關(guān)于javascript代碼簡(jiǎn)寫(xiě)的幾種常用方式,需要的朋友可以參考下2021-08-08ajaxControlToolkit AutoCompleteExtender的用法
昨天在搜索中使用了這個(gè)控件,不過(guò)不知道為什么在IE中反應(yīng)比較慢2008-10-10js禁止頁(yè)面復(fù)制功能禁用頁(yè)面右鍵菜單示例代碼
禁止頁(yè)面復(fù)制功能、禁用頁(yè)面右鍵菜單等等在瀏覽網(wǎng)頁(yè)時(shí)想必大家都有遇到過(guò)吧,下面為大家詳細(xì)介紹下使用js是如何實(shí)現(xiàn)的,感興趣的朋友可以參考下2013-08-08JavaScript中 ES6 generator數(shù)據(jù)類(lèi)型詳解
generator 是ES6引入的新的數(shù)據(jù)類(lèi)型,由function* 定義, (注意*號(hào)),接下來(lái)通過(guò)本文給大家介紹js中 ES6 generator數(shù)據(jù)類(lèi)型,非常不錯(cuò),感興趣的朋友一起學(xué)習(xí)吧2016-08-08javascript實(shí)現(xiàn)類(lèi)似百度分享功能的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)類(lèi)似百度分享功能的方法,以實(shí)例形式較為完整的分析了基于javascript實(shí)現(xiàn)百度分享功能所涉及的樣式與分享功能實(shí)現(xiàn)方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07純javascript代碼實(shí)現(xiàn)計(jì)算器功能(三種方法)
純javascript代碼實(shí)現(xiàn)計(jì)算器功能,接下來(lái),由小編給大家分享一下用純javascript代碼編寫(xiě)的計(jì)算器程序,需要的朋友可以參考下2015-09-09