亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2019年05月14日 16:51:25   作者:天下雪  
這篇文章主要介紹了微信小程序下拉菜單效果的實例代碼,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下


//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
//數(shù)據(jù)源
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 = []
/// 初始化DropDownMenu
loadDropDownMenu()
that.setData({
  reportData: ReportDataSync,//菜單數(shù)據(jù)
  subMenuDisplay: initSubMenuDisplay, //一級
  subMenuHighLight: initSubMenuHighLight, //二級
   animationData: initAnimationData //動畫
})
//一級菜單點擊
tapMainMenu: function (e) {
  //獲取當(dāng)前一級菜單標(biāo)識
  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)
},
//二級菜單點擊
tapSubMenu: function (e) {
  //隱藏所有一級菜單
  //this.setData({
  //subMenuDisplay: initSubMenuDisplay()
  //});
  // 當(dāng)前二級菜單的標(biāo)識
  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] = '';
      }
    }
  }
  //給當(dāng)前二級菜單添加樣式
  initSubMenuHighLight[indexArray[0]][indexArray[1]] = 'highlight';
  //刷新樣式
  this.setData({
    subMenuHighLight: initSubMenuHighLight
  });
   // 設(shè)置動畫
   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();
  // 導(dǎo)出到數(shù)據(jù),綁定給view屬性
   var animationStr = animation.export();
  // 原來的數(shù)據(jù)
   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("")
  }
}

總結(jié)

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

相關(guān)文章

  • JavaScript實現(xiàn)的微信二維碼圖片生成器的示例

    JavaScript實現(xiàn)的微信二維碼圖片生成器的示例

    二維碼分享功能大多是由后端實現(xiàn)的,對服務(wù)器的負(fù)載較重,這里有一個前端實現(xiàn)的版本,本文介紹了JavaScript實現(xiàn)的微信二維碼圖片生成器的示例,有需要的可以了解一下。
    2016-10-10
  • JS常見面試試題總結(jié)【去重、遍歷、閉包、繼承等】

    JS常見面試試題總結(jié)【去重、遍歷、閉包、繼承等】

    這篇文章主要介紹了JS常見面試試題,總結(jié)分析了javascript去重、遍歷、閉包、繼等相關(guān)算法與操作技巧,需要的朋友可以參考下
    2019-08-08
  • es6中的解構(gòu)賦值、擴展運算符和rest參數(shù)使用詳解

    es6中的解構(gòu)賦值、擴展運算符和rest參數(shù)使用詳解

    這篇文章分別給大家介紹了關(guān)于es6中解構(gòu)賦值、擴展運算符和rest參數(shù)使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • 一文詳解如何在項目中和平時練習(xí)中應(yīng)用es6語法

    一文詳解如何在項目中和平時練習(xí)中應(yīng)用es6語法

    ES6是JavaScript的一個版本,因為我們前面用到的vue默認(rèn)使用ES6語法開發(fā),所以我們在這一節(jié)補充ES6的知識點,下面這篇文章主要給大家介紹了關(guān)于如何在項目中和平時練習(xí)中應(yīng)用es6語法的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • javascript代碼簡寫的幾種常用方式匯總

    javascript代碼簡寫的幾種常用方式匯總

    任何一種編程語言的簡寫小技巧都是為了幫助你寫出更簡潔、更完善的代碼,讓你用更少的編碼實現(xiàn)你的需求,這篇文章主要給大家介紹了關(guān)于javascript代碼簡寫的幾種常用方式,需要的朋友可以參考下
    2021-08-08
  • ajaxControlToolkit AutoCompleteExtender的用法

    ajaxControlToolkit AutoCompleteExtender的用法

    昨天在搜索中使用了這個控件,不過不知道為什么在IE中反應(yīng)比較慢
    2008-10-10
  • js禁止頁面復(fù)制功能禁用頁面右鍵菜單示例代碼

    js禁止頁面復(fù)制功能禁用頁面右鍵菜單示例代碼

    禁止頁面復(fù)制功能、禁用頁面右鍵菜單等等在瀏覽網(wǎng)頁時想必大家都有遇到過吧,下面為大家詳細(xì)介紹下使用js是如何實現(xiàn)的,感興趣的朋友可以參考下
    2013-08-08
  • JavaScript中 ES6 generator數(shù)據(jù)類型詳解

    JavaScript中 ES6 generator數(shù)據(jù)類型詳解

    generator 是ES6引入的新的數(shù)據(jù)類型,由function* 定義, (注意*號),接下來通過本文給大家介紹js中 ES6 generator數(shù)據(jù)類型,非常不錯,感興趣的朋友一起學(xué)習(xí)吧
    2016-08-08
  • javascript實現(xiàn)類似百度分享功能的方法

    javascript實現(xiàn)類似百度分享功能的方法

    這篇文章主要介紹了javascript實現(xiàn)類似百度分享功能的方法,以實例形式較為完整的分析了基于javascript實現(xiàn)百度分享功能所涉及的樣式與分享功能實現(xiàn)方法,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • 純javascript代碼實現(xiàn)計算器功能(三種方法)

    純javascript代碼實現(xiàn)計算器功能(三種方法)

    純javascript代碼實現(xiàn)計算器功能,接下來,由小編給大家分享一下用純javascript代碼編寫的計算器程序,需要的朋友可以參考下
    2015-09-09

最新評論