微信小程序 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 相关文章推荐
Display SQL Server Login Mode
Jun 21 Javascript
Jquery实战_读书笔记2 选择器
Jan 22 Javascript
js取得url地址参数实例
Feb 22 Javascript
原始的js代码和jquery对比体会
Sep 10 Javascript
JS实现根据出生年月计算年龄
Jan 10 Javascript
JQuery validate 验证一个单独的表单元素实例
Feb 17 Javascript
react.js 获取真实的DOM节点实例(必看)
Apr 17 Javascript
React BootStrap用户体验框架快速上手
Mar 06 Javascript
vue-cli2.0转3.0之项目搭建的详细步骤
Dec 11 Javascript
jqGrid表格底部汇总、合计行footerrow处理
Aug 21 Javascript
nodemon实现Typescript项目热更新的示例代码
Nov 19 Javascript
jquery添加div实现消息聊天框
Feb 08 jQuery
微信小程序 购物车简单实例
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
如何将数据从文本导入到mysql
2006/10/09 PHP
PHP分页显示制作详细讲解
2006/12/05 PHP
php的字符串用法小结
2010/06/08 PHP
php中防止伪造跨站请求的小招式
2011/09/02 PHP
详谈php ip2long 出现负数的原因及解决方法
2017/04/05 PHP
JavaScript的面向对象方法以及差别
2008/03/31 Javascript
AJAX分页的代码(后台asp.net)
2011/02/14 Javascript
如何使Chrome控制台支持多行js模式——意外发现
2013/06/13 Javascript
整理的比较全的event对像在ie与firefox浏览器中的区别
2013/11/25 Javascript
JavaScript实现动画打开半透明提示层的方法
2015/04/21 Javascript
jQuery常用的一些技巧汇总
2016/03/26 Javascript
jQuery弹出遮罩层效果完整示例
2016/09/13 Javascript
Bootstrap弹出框modal上层的输入框不能获得焦点问题的解决方法
2016/12/13 Javascript
jQuery插件FusionCharts实现的3D帕累托图效果示例【附demo源码】
2017/03/25 jQuery
js解决软键盘遮挡输入框的问题分享
2017/12/19 Javascript
js 实现在2d平面上画8的方法
2018/10/10 Javascript
vue-cli3.0+element-ui上传组件el-upload的使用
2018/12/03 Javascript
layui的select联动实现代码
2019/09/28 Javascript
简单实现节流函数和防抖函数过程解析
2019/10/08 Javascript
请求时token过期自动刷新token操作
2020/09/11 Javascript
Python 详解基本语法_函数_返回值
2017/01/22 Python
Pandas之groupby( )用法笔记小结
2019/07/23 Python
python爬虫 urllib模块url编码处理详解
2019/08/20 Python
django formset实现数据表的批量操作的示例代码
2019/12/06 Python
python代码中怎么换行
2020/06/17 Python
css3中background新增的4个新的相关属性用法介绍
2013/09/26 HTML / CSS
用HTML5制作一个简单的弹力球游戏
2015/05/12 HTML / CSS
Columbia美国官网:美国著名的户外服装品牌
2016/11/24 全球购物
Nebula美国官网:便携式投影仪
2019/03/15 全球购物
建筑项目策划书
2014/01/13 职场文书
优秀毕业生自我鉴定
2014/02/11 职场文书
校园歌咏比赛主持词
2014/03/18 职场文书
小学优秀辅导员事迹材料
2014/05/11 职场文书
林肯就职演讲稿
2014/05/19 职场文书
2014年感恩母亲演讲稿
2014/05/27 职场文书
2019预备党员转正申请书模板2篇!
2019/08/07 职场文书