微信小程序 下拉菜單簡(jiǎn)單實(shí)例
更新時(shí)間:2017年04月13日 16:43:06 投稿:lqh
這篇文章主要介紹了微信小程序 下拉菜單簡(jiǎn)單實(shí)例的相關(guān)資料,需要的朋友可以參考下
微信小程序 下拉菜單簡(jiǎn)單實(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)畫
})
//一級(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)畫
this.animation(indexArray[0]);
},
//菜單動(dòng)畫
animation: function (index) {
// 定義一個(gè)動(dòng)畫
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)畫
initAnimationData.push("")
}
}
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
微信小程序 label 組件詳解及簡(jiǎn)單實(shí)例
這篇文章主要介紹了微信小程序 label 組件詳解及簡(jiǎn)單實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-01-01
微信小程序開發(fā)之相冊(cè)選擇和拍照詳解及實(shí)例代碼
這篇文章主要介紹了微信小程序開發(fā)之相冊(cè)選擇和拍照詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02
JS精髓原型鏈繼承及構(gòu)造函數(shù)繼承問(wèn)題糾正
這篇文章主要為大家介紹了JS精髓原型鏈繼承及構(gòu)造函數(shù)繼承問(wèn)題糾正,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
定時(shí)器在頁(yè)面最小化時(shí)不執(zhí)行實(shí)現(xiàn)示例
這篇文章主要為大家介紹了定時(shí)器在頁(yè)面最小化時(shí)不執(zhí)行的實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
微信小程序 wx.request(OBJECT)發(fā)起請(qǐng)求詳解
這篇文章主要介紹了微信小程序 wx.request(OBJECT)發(fā)起請(qǐng)求詳解的相關(guān)資料,需要的朋友可以參考下2016-10-10
動(dòng)態(tài)引入DynamicImport實(shí)現(xiàn)原理
這篇文章主要為大家介紹了動(dòng)態(tài)引入DynamicImport實(shí)現(xiàn)原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01

