国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

微信小程序下拉菜單效果的實例代碼

2019-11-19 11:34:27
字體:
來源:轉載
供稿:網友


//wcss/**DropDownMenu**/ /*總菜單容器*/ .menu { display: block; height: 28px; position: relative;} /*一級菜單*/ .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;}
/*二級菜單外部容器樣式*/.menu dd { position: absolute; width: 100%; margin-top: 40px; left: 0; z-index: -99;}/*二級菜單普通樣式*/.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;}/*二級菜單高亮樣式*/.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"> 時間:{{dateValue}}</picker>   </dd>  </block></dl>//js//數據源var ReportDataSync = [  {    reportType: "日報1",    chilItem: [      { ID: 1, Name: "日報1", ReportUrl: "DailyReport.aspx", Type: 1 },      { ID: 2, Name: "日報2", ReportUrl: "DailyReport.aspx", Type: 1 },      { ID: 3, Name: "日報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: "月報3",    chilItem: [      { ID: 1, Name: "月報1", ReportUrl: "DailyReport.aspx", Type: 1 },      { ID: 2, Name: "月報2", ReportUrl: "DailyReport.aspx", Type: 2 }]  }]//定義字段var initSubMenuDisplay = [] var initSubMenuHighLight = []var initAnimationData = []/// 初始化DropDownMenuloadDropDownMenu()that.setData({  reportData: ReportDataSync,//菜單數據  subMenuDisplay: initSubMenuDisplay, //一級  subMenuHighLight: initSubMenuHighLight, //二級   animationData: initAnimationData //動畫})//一級菜單點擊tapMainMenu: function (e) {  //獲取當前一級菜單標識  var index = parseInt(e.currentTarget.dataset.index);  //改變顯示狀態  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)},//二級菜單點擊tapSubMenu: function (e) {  //隱藏所有一級菜單  //this.setData({  //subMenuDisplay: initSubMenuDisplay()  //});  // 當前二級菜單的標識  var indexArray = e.currentTarget.dataset.index.split('-');   // 刪除所在二級菜單樣式  for (var i = 0; i < initSubMenuHighLight.length; i++) {    if (indexArray[0] == i) {      for (var j = 0; j < initSubMenuHighLight[i].length; j++) {        initSubMenuHighLight[i][j] = '';      }    }  }  //給當前二級菜單添加樣式  initSubMenuHighLight[indexArray[0]][indexArray[1]] = 'highlight';  //刷新樣式  this.setData({    subMenuHighLight: initSubMenuHighLight  });   // 設置動畫   this.animation(indexArray[0]);},//菜單動畫animation: function (index) {    // 定義一個動畫   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();  // 導出到數據,綁定給view屬性   var animationStr = animation.export();  // 原來的數據   var animationData = this.data.animationData;  animationData[index] = animationStr;  this.setData({    animationData: animationData  });}/// <summary>/// 初始化DropDownMenu/// 1.一級目錄 initSubMenuDisplay :['hidden']/// 2.二級目錄 initSubMenuHighLight :[['',''],['','','','']]]/// </summary>function loadDropDownMenu() {  for (var i = 0; i < ReportDataSync.length; i++) {    //一級目錄    initSubMenuDisplay.push('hidden')    //二級目錄    var report = []    for (var j = 0; j < ReportDataSync[i].chilItem.length; j++) {      report.push([''])    }    initSubMenuHighLight.push(report)       //動畫    initAnimationData.push("")  }}

總結

以上所述是小編給大家介紹的微信小程序下拉菜單效果的實例代碼,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 固阳县| 屏东市| 故城县| 无锡市| 沂源县| 崇阳县| 临沧市| 水富县| 平泉县| 河源市| 波密县| 合阳县| 枞阳县| 海南省| 达孜县| 遵义县| 筠连县| 乐安县| 宜阳县| 萝北县| 新民市| 班玛县| 日照市| 司法| 江油市| 乐平市| 安平县| 通河县| 曲阜市| 长宁县| 康乐县| 留坝县| 刚察县| 大方县| 开封市| 永嘉县| 灌阳县| 额尔古纳市| 浮山县| 资兴市| 澄迈县|