微信小程序 WXDropDownMenu组件详解及实例代码


Posted in Javascript onOctober 24, 2016

微信小程序 WXDropDownMenu组件详解,这里给个小的示例,帮助大家学习理解,

功能: 适用于商品列表筛选与功能菜单跳转

先来看下效果图:

微信小程序 WXDropDownMenu组件详解及实例代码

思路与步骤:

布局方面,整体使用dl来写,二级包在dd中,用ul li来写;交互方面,点击某一级菜单,关闭兄弟子菜单,点击某子菜单关闭所有菜单。

1.使用dt做出第一级菜单

2.使用dd嵌套第二级菜单,初始隐藏、position为absolute,使用z-index浮出页面层

/*总菜单容器*/
.menu {
   display: block;
  height: 38px;
}

/*一级菜单*/
.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;
}

/*二级菜单外部容器样式*/
.menu dd{
  position: absolute;
  width: 100%;
  /*hack*/
  top:39px;
  left:0;
  z-index:999;
}

/*二级菜单普通样式*/
.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;
}

查看效果,接下来实现点击事件。

如图

微信小程序 WXDropDownMenu组件详解及实例代码

3.dt绑定点击事件tapMainMenu,flag控制显隐toggle,提供2个class,hidden与show,来控制显隐。注:dt也是可以bindTap的,不单是view。

/* 显示与隐藏 */
.show {
  display: block;
}

.hidden {
  display: none;
}

4.关闭所有一级菜单,每个一级菜单都有一个index标识,由tapMainMenu事件传递过去,与数组subMenuDisplay一一对应,当前元素subMenuDisplay[index]视原来状态决定是显示或隐藏。

核心代码:

<dl class="menu">
  <dt data-index="0" bindtap="tapMainMenu">价格</dt>
  <dd class="{{subMenuDisplay[0]}}">
    <ul><li>sub1</li><li>sub2</li></ul>
  </dd>
</dl>
// 使用function初始化array,相比var initSubMenuDisplay = [] 既避免的引用复制的,同时方式更灵活,将来可以是多种方式实现,个数也不定的
function initSubMenuDisplay() {
  return ['hidden', 'hidden', 'hidden'];
}

Page({
  data:{
    subMenuDisplay:initSubMenuDisplay()
  },
  tapMainMenu: function(e) {
//    获取当前显示的一级菜单标识
    var index = parseInt(e.currentTarget.dataset.index);
    // 生成数组,全为hidden的,只对当前的进行显示
    var newSubMenuDisplay = initSubMenuDisplay();
//    如果目前是显示则隐藏,反之亦反之。同时要隐藏其他的菜单
    if(this.data.subMenuDisplay[index] == 'hidden') {
      newSubMenuDisplay[index] = 'show';
    } else {
      newSubMenuDisplay[index] = 'hidden';
    }
    // 设置为新的数组
    this.setData({
      subMenuDisplay: newSubMenuDisplay
    });
  }
});

5.选中二级菜单当前项,但给个系统icon及改变背景色,文本加粗,同样改变一级菜单标题,demo中给出一个弹窗

声明tapSubMenu方法,监听二级点击事件

tapSubMenu: function(e) {
    //    获取当前显示的一级菜单标识
    var index = parseInt(e.currentTarget.dataset.index);
    console.log(index);
    // 隐藏所有一级菜单
    this.setData({
      subMenuDisplay: initSubMenuDisplay()
    });
  }

加highlight效果

/*二级菜单高亮样式*/
.menu li.highlight{
  background-color: #f4f4f4;
}

与一级菜单不同,使用二维数组的方式实现点击高亮,这样才能定位到是某一级的某二级菜单,再决定显示隐藏。 布局文件改成:

<dd class="{{subMenuDisplay[0]}}">
    <ul>
      <li class="{{subMenuHighLight[0][0]}}" data-index="0-0" bindtap="tapSubMenu">100以内</li>
      <li class="{{subMenuHighLight[0][1]}}" data-index="0-1" bindtap="tapSubMenu">100-500</li>
      <li class="{{subMenuHighLight[0][2]}}" data-index="0-2" bindtap="tapSubMenu">500-1000</li>
      <li class="{{subMenuHighLight[0][3]}}" data-index="0-3" bindtap="tapSubMenu">1000-3000</li>
      <li class="{{subMenuHighLight[0][4]}}" data-index="0-4" bindtap="tapSubMenu">3000以上</li>
    </ul>
  </dd>

效果如图

微信小程序 WXDropDownMenu组件详解及实例代码

相应的js代码要写成:

//声明初始化高亮状态数组

function initSubMenuHighLight() {
  return [
    ['','','','',''],
    ['',''],
    ['','','']
  ];
}

点击事件

tapSubMenu: function(e) {
    // 隐藏所有一级菜单
    this.setData({
      subMenuDisplay: initSubMenuDisplay()
    });
    // 处理二级菜单,首先获取当前显示的二级菜单标识
    var indexArray = e.currentTarget.dataset.index.split('-');
    console.log("indexArray : " + indexArray);
    var newSubMenuHighLight = initSubMenuHighLight();
    // 与一级菜单不同,这里不需要判断当前状态,只需要点击就给class赋予highlight即可
    newSubMenuHighLight[indexArray[0]][indexArray[1]] = 'highlight';
    console.log(newSubMenuHighLight);
    // 设置为新的数组
    this.setData({
      subMenuHighLight: newSubMenuHighLight
    });
  }

这样就实现了高亮与取消高亮。但还没完,与一级菜单不同,这里与兄弟子菜单是非互斥的,也就是说点击了本菜单,是不能一刀切掉兄弟菜单的高亮状态的。于是我们改进js代码。

声明方式,改用变量形式,方便存储。

//定义初始化数据,用于运行时保存
var initSubMenuHighLight = [
    ['','','','',''],
    ['',''],
    ['','','']
  ];

点击事件

tapSubMenu: function(e) {
    // 隐藏所有一级菜单
    this.setData({
      subMenuDisplay: initSubMenuDisplay()
    });
    // 处理二级菜单,首先获取当前显示的二级菜单标识
    var indexArray = e.currentTarget.dataset.index.split('-');
    // 初始化状态
    // var newSubMenuHighLight = initSubMenuHighLight;
    for (var i = 0; i < initSubMenuHighLight.length; i++) {
      // 如果点中的是一级菜单,则先清空状态,即非高亮模式,然后再高亮点中的二级菜单;如果不是当前菜单,而不理会。经过这样处理就能保留其他菜单的高亮状态
      if (indexArray[0] == i) {
        for (var j = 0; j < initSubMenuHighLight[i].length; j++) {
          // 实现清空
          initSubMenuHighLight[i][j] = '';
        }
        // 将当前菜单的二级菜单设置回去
      }
    }

    // 与一级菜单不同,这里不需要判断当前状态,只需要点击就给class赋予highlight即可
    initSubMenuHighLight[indexArray[0]][indexArray[1]] = 'highlight';
    // 设置为新的数组
    this.setData({
      subMenuHighLight: initSubMenuHighLight
    });
  }

有待完善功能点:

1.显示与隐藏带动画下拉

2.抽象化,使用回调函数,将监听每个二级菜单的点击

3.数据源与显示应当是分离的,一级与二级菜单的key value应该是独立在外,系统只认index,然后对相应点击作处理,跳转页面,筛选结果等

4.点击二级菜单时,会将全部组的清除,有待修复

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
Javascript+CSS实现影像卷帘效果思路及代码
Oct 20 Javascript
jQuery中has()方法用法实例
Jan 06 Javascript
js实现带缓冲效果的仿QQ面板折叠菜单代码
Sep 06 Javascript
原生js三级联动的简单实现代码
Jun 07 Javascript
jQuery中animate()的使用方法及解决$(”body“).animate({“scrollTop”:top})不被Firefox支持的问题
Apr 04 jQuery
JavaScript从原型到原型链深入理解
Jun 03 Javascript
原生js实现抽奖小游戏
Jun 27 Javascript
微信小程序实现侧边分类栏
Oct 21 Javascript
JQuery常用简单动画操作方法回顾与总结
Dec 07 jQuery
详解vue中在循环中使用@mouseenter 和 @mouseleave事件闪烁问题解决方法
Apr 07 Javascript
关于angular浏览器兼容性问题的解决方案
Jul 26 Javascript
vue3使用vue-router的完整步骤记录
Jun 20 Vue.js
微信小程序 购物车简单实例
Oct 24 #Javascript
Select2.js下拉框使用小结
Oct 24 #Javascript
微信小程序 绘图之饼图实现
Oct 24 #Javascript
用jmSlip编写移动端顶部日历选择控件
Oct 24 #Javascript
微信小程序 富文本转文本实例详解
Oct 24 #Javascript
微信小程序 参数传递详解
Oct 24 #Javascript
10分钟掌握XML、JSON及其解析
Dec 06 #Javascript
You might like
php中文件上传的安全问题
2006/10/09 PHP
Windows 下的 PHP-PEAR 安装方法
2010/11/20 PHP
PHP中return 和 exit 、break和contiue 区别与用法
2012/04/09 PHP
浅析application/x-www-form-urlencoded和multipart/form-data的区别
2014/06/22 PHP
PHP+jquery+ajax实现即时聊天功能实例
2014/12/23 PHP
php实现插入数组但不影响原有顺序的方法
2015/03/27 PHP
详解php用curl调用接口方法,get和post两种方式
2017/01/13 PHP
IE6兼容透明背景图片及解决方案
2015/08/19 Javascript
基于jQuery滑动杆实现购买日期选择效果
2015/09/15 Javascript
详解JavaScript中的属性和特性
2016/12/08 Javascript
EasyUI创建人员树的实例代码
2017/09/15 Javascript
微信小程序的日期选择器的实例详解
2017/09/29 Javascript
vue实现的网易云音乐在线播放和下载功能案例
2019/02/18 Javascript
jQuery实现滑动星星评分效果(每日分享)
2019/11/13 jQuery
微信小程序利用button控制条件标签的变量问题
2020/03/15 Javascript
JS前后端实现身份证号验证代码解析
2020/07/23 Javascript
python在命令行下使用google翻译(带语音)
2014/01/16 Python
Python编程之属性和方法实例详解
2015/05/19 Python
轻松实现TensorFlow微信跳一跳的AI
2018/01/05 Python
python学习基础之循环import及import过程
2018/04/22 Python
基于Python 中函数的 收集参数 机制
2019/12/21 Python
python 定义类时,实现内部方法的互相调用
2019/12/25 Python
python实现凯撒密码、凯撒加解密算法
2020/06/11 Python
Python中return函数返回值实例用法
2020/11/19 Python
html5教程制作简单画板代码分享
2013/12/04 HTML / CSS
HTML5 Notification(桌面提醒)功能使用实例
2014/03/17 HTML / CSS
ProBikeKit德国:在线公路自行车专家
2018/06/03 全球购物
科室工作的个人自我评价
2013/10/30 职场文书
工厂实习感言
2014/01/14 职场文书
会计自我鉴定
2014/02/04 职场文书
出纳员岗位职责风险
2014/03/06 职场文书
毕业生面试求职信
2014/06/23 职场文书
求职意向书
2014/07/29 职场文书
Python标准库之typing的用法(类型标注)
2021/06/02 Python
springboot+zookeeper实现分布式锁
2022/03/21 Java/Android
Python OpenCV形态学运算示例详解
2022/04/07 Python