小程序实现多列选择器


Posted in Javascript onFebruary 15, 2019

本文实例为大家分享了小程序实现多列选择器的具体代码,供大家参考,具体内容如下

代码分两部分,先上wxml

<view class="container">
 <form catchsubmit="formSubmit">
  <view class="form-card">
   <view class="weui-cell weui-cell_input">
    <view class="weui-cell__hd">
     <view class="weui-label">物种<span>*</span></view>
    </view>
    <view class="weui-cell__bd">
     <picker mode="multiSelector" bindchange="bindMultiPickerChange" bindcolumnchange="bindMultiPickerColumnChange" value="{{multiIndex}}" range="{{multiArray}}">
      <view class="weui-input">{{multiArray[0][multiIndex[0]]}}{{multiArray[1][multiIndex[1]]}}{{multiArray[2][multiIndex[2]]}}</view>
     </picker>
    </view>
   </view>
  </view>
 </form>  
</view>

其次是js

Page({
 
 /**
  * 页面的初始数据
  */
 data: {
  objectMultiShow: [],
  objectMultiArray: [],
  multiArray: [],
  multiIndex: [],
  checkeIndex: []
 },
 
 /**
  * 生命周期函数--监听页面加载
  * objectMultiShow--匹配多列选择器渲染数据所对应的json数据(包含id,parentId,name)
  * multiArray--多列选择器渲染数据
  */
 onLoad: function (options) {
  // 初始化
  let data = {
   objectMultiShow: this.data.objectMultiShow,
   objectMultiArray: this.data.objectMultiArray,
   multiArray: this.data.multiArray,
   multiIndex: this.data.multiIndex,
   checkeIndex: this.data.checkeIndex
  }
  data.objectMultiArray = [
   [{ id: 0, name: '无脊柱动物' }, { id: 1, name: '脊柱动物' }],
   [
    { id: 0, name: '扁性动物', parentId: 0 }, { id: 1, name: '线形动物', parentId: 0 }, { id: 2, name: '环节动物', parentId: 0 }, { id: 3, name: '软体动物', parentId: 0 }, { id: 4, name: '节肢动物', parentId: 0 },
    { id: 5, name: '鱼', parentId: 1 }, { id: 6, name: '两栖动物', parentId: 1 }, { id: 7, name: '爬行动物', parentId: 1 }
   ],
   [
    { id: 0, name: '猪肉绦虫', parentId: 0 }, { id: 1, name: '吸血虫', parentId: 0 },
    { id: 2, name: '蛔虫', parentId: 1 },
    { id: 3, name: '蚂蚁', parentId: 2 }, { id: 4, name: '蚂蟥', parentId: 2 },
    { id: 5, name: '河蚌', parentId: 3 }, { id: 6, name: '蜗牛', parentId: 3 }, { id: 7, name: '蛞蝓', parentId: 3 },
    { id: 8, name: '昆虫', parentId: 4 }, { id: 9, name: '甲壳动物', parentId: 4 }, { id: 10, name: '蛛形动物', parentId: 4 }, { id: 11, name: '多足动物', parentId: 4 },
    { id: 3, name: '鲫鱼', parentId: 5 }, { id: 4, name: '带鱼', parentId: 5 },
    { id: 3, name: '青蛙', parentId: 6 }, { id: 4, name: '娃娃鱼', parentId: 6 },
    { id: 3, name: '蜥蜴', parentId: 7 }, { id: 4, name: '龟', parentId: 7 }, { id: 4, name: '壁虎', parentId: 7 },
   ]
  ]
  data.objectMultiShow = data.objectMultiArray.map((item, index) => {
   if (index > 0) {
    item = item.filter(i => i.parentId === data.objectMultiArray[index - 1][0].id)
   }
   return item
  })
  data.multiArray = data.objectMultiShow.map(item => {
   item = item.map(i => i.name)
   return item
  })
  console.log(data.multiIndex)
  // 数据更新
  this.setData(data)
 },
 
 bindMultiPickerChange: function (e) {
  console.log('picker发送选择改变,携带值为', e.detail.value)
  this.setData({
   multiIndex: e.detail.value
  })
 },
 bindMultiPickerColumnChange: function (e) {
  console.log('修改的列为', e.detail.column, ',值为', e.detail.value);
  // 初始化数据
  var data = {
   objectMultiShow: this.data.objectMultiShow,
   multiArray: this.data.multiArray,
   multiIndex: this.data.multiIndex
  };
 
  // 改变第i列数据之后,后几列选择第0个选项(重置)
  data.multiIndex[e.detail.column] = e.detail.value;
  for (let i = e.detail.column; i < data.multiIndex.length - 1; i++) {
   data.multiIndex[i + 1] = 0
  }
 
  /**
   * 改变第i列数据之后,后几列数据更新
   * 两种写法:for 和 switch,switch为三列选择器写法,for由switch精简拓展过来,可用于多列选择器
   * swich写法:如果更改的是第一列数据,第二列数据通过filter筛选(parentId = 第一列选中项id),同时更新第三列数据
   *      如果更改的是第二列数据,更新第三列数据 通过filter筛选(parentId = 第二列选中项id)
   */
  let arry = this.data.objectMultiArray
  for (let i = e.detail.column; i < data.multiIndex.length - 1; i++) {
   data.objectMultiShow[i + 1] = arry[i + 1].filter(item => item.parentId === data.objectMultiShow[i][data.multiIndex[i]].id)
   data.multiArray[i + 1] = data.objectMultiShow[i + 1].map(item => item.name)
  }
  /*switch (e.detail.column) {
   case 0:
    data.objectMultiShow[1] = arry[1].filter(item => item.parentId === data.objectMultiShow[0][data.multiIndex[0]].id)
    data.multiArray[1] = data.objectMultiShow[1].map(item => item.name)
    data.objectMultiShow[2] = arry[2].filter(item => item.parentId === data.objectMultiShow[1][data.multiIndex[1]].id)
    data.multiArray[2] = data.objectMultiShow[2].map(item => item.name)
    break;
   case 1:
    data.objectMultiShow[2] = arry[2].filter(item => item.parentId === data.objectMultiShow[1][data.multiIndex[1]].id)
    data.multiArray[2] = data.objectMultiShow[2].map(item => item.name)
  }*/
  // 数据更新
  this.setData(data);
 }
})

wxml部分选用的官方组件--picker,根据官方文档mode=multiSelector,表示使用多列选择器。

其他参数容我吐槽下:首先是range--绑定的二维数据,只能是字符串组成的二维数组,比如[["a","b"], ["c","d"]],这样的话多列选择器就是第一列a,b选项,第二列c,d选项。感觉很美。然而事实上这能干啥捏?我们做的多列选择器并不是只是页面展示,要跟后台对接数据的,就这样传字符串合适否?我需要的是带id之类的对象,而wxml页面又不支持双括号绑定数据里写map之类的函数方法。所以,我们后台传过来的数据要改造一下,提取其中的name为绑定数据。

第二个就是value,本来以为这个是对应项中的第几个是这样的:a如果对应c,b如果对应d。选择bd应该就是[1, 1],而事实上是[1, 0]。也就是对应页面上展示的第几个对应(bd,页面上第一列有ab两个选项,第二列有且只有一个d)

其他关于bindchange绑定的方法是点击确认按钮触发,bindcolumnchange绑定的方法是滑动多列选择器时候触发,至于bindcancel绑定感觉就是笑话,数据实时改变,取消需要再绑定一个中间值才能达到该有的效果,这里暂时没有做。

js部分我使用了五个数据

  • objectMultiShow: []   选中带id的Object对象数组
  • objectMultiArray: []    后台带id,parentId对象数组
  • multiArray: []    微信小程序组件需求的字符串二维数组
  • multiIndex: []    微信小程序组件需求的选中对象数组
  • checkeIndex: []    基于bindcancel的中间值(暂时未做)

为了达到我想到的真正的多列效果,我不惜出卖肉体,跟后台大哥达成的各种屈辱协议,获得了想要的数据格式第一列数组不带parentId,因为没有parent。第二列parentId对应第一列id,第三列parentId对应第二列id,如果还有多,可以依次类推。然后根据需求,依次从中获取所需的其他数据,完成数据初始化。

然后在滑动多列选择器的时候,动态更新后一列的数据,我这里做的处理是更新后一列数据,并默认选择第一个选项。

详细注释写完,发现更多的是配置代码,具体的功能代码反而很少。

个人感觉,小程序不是写代码,而是在配置选项搭建出来的。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery 最简单的属性菜单
Oct 08 Javascript
非常好用的JsonToString 方法 简单实例
Jul 18 Javascript
扩展jQuery对象时如何扩展成员变量具体怎么实现
Apr 25 Javascript
js数组去重的5种算法实现
Nov 04 Javascript
javascript中类的定义方式详解(四种方式)
Dec 22 Javascript
超实用的JavaScript表单代码段
Feb 26 Javascript
Jquery和JS获取ul中li标签的实现方法
Jun 02 Javascript
JS身份证信息验证正则表达式
Jun 12 Javascript
ES6知识点整理之数组解构和字符串解构的应用示例
Apr 17 Javascript
Vue2(三)实现子菜单展开收缩,带动画效果实现方法
Apr 28 Javascript
基于iview的router常用控制方式
May 30 Javascript
JavaScript this使用方法图解
Feb 04 Javascript
jQuery实现经典的网页3D轮播图封装功能【附源码下载】
Feb 15 #jQuery
微信实现自动跳转到用其他浏览器打开指定APP下载
Feb 15 #Javascript
微信小程序实现联动选择器
Feb 15 #Javascript
推荐一个基于Node.js的表单验证库
Feb 15 #Javascript
微信小程序实现左右列表联动
May 19 #Javascript
webpack-url-loader 解决项目中图片打包路径问题
Feb 15 #Javascript
微信小程序实现单选选项卡切换效果
Jun 19 #Javascript
You might like
PHP中防止直接访问或查看或下载config.php文件的方法
2012/07/07 PHP
PHP实现通过Luhn算法校验信用卡卡号是否有效
2015/03/23 PHP
php动态变量定义及使用
2015/06/10 PHP
php实现用户注册密码的crypt加密
2017/06/08 PHP
浅谈Yii乐观锁的使用及原理
2017/07/25 PHP
jquery tab插件制作实现代码
2010/06/22 Javascript
JS防止用户多次提交的简单代码
2013/08/01 Javascript
jQuery中对未来的元素绑定事件用bind、live or on
2014/04/17 Javascript
jquery+easeing实现仿flash的载入动画
2015/03/10 Javascript
浅谈javascript原型链与继承
2015/07/13 Javascript
实例讲解javascript注册事件处理函数
2016/01/09 Javascript
Bootstrap树形组件jqTree的简单封装
2016/01/25 Javascript
DeviceOne 让你一见钟情的App快速开发平台
2016/02/17 Javascript
JavaScript设计模式之单体模式全面解析
2016/09/09 Javascript
巧用Javascript的逻辑运算符
2016/12/02 Javascript
利用vue.js插入dom节点的方法
2017/03/15 Javascript
js判断是否是手机页面
2017/03/17 Javascript
vue和webpack安装命令详解
2018/06/15 Javascript
JS+H5 Canvas实现时钟效果
2018/07/20 Javascript
vue组件从开发到发布的实现步骤
2018/11/11 Javascript
vue实现条件叠加搜索的解决方法
2019/05/28 Javascript
了解JavaScript函数中的默认参数
2019/05/30 Javascript
vue-admin-template配置快捷导航的代码(标签导航栏)
2020/09/04 Javascript
[01:03:50]DOTA2-DPC中国联赛 正赛 CDEC vs DLG BO3 第二场 2月7日
2021/03/11 DOTA
python实现实时监控文件的方法
2016/08/26 Python
python图形工具turtle绘制国际象棋棋盘
2019/05/23 Python
pyinstaller打包单个exe后无法执行错误的解决方法
2019/06/21 Python
python粘包问题及socket套接字编程详解
2019/06/29 Python
使用python获取邮箱邮件的设置方法
2019/09/20 Python
Python GUI编程学习笔记之tkinter中messagebox、filedialog控件用法详解
2020/03/30 Python
Keras load_model 导入错误的解决方式
2020/06/09 Python
幼儿园大班教学反思
2014/02/10 职场文书
美术毕业生求职信
2014/02/25 职场文书
《夸父追日》教学反思
2014/02/26 职场文书
本科应届生自荐信
2014/06/29 职场文书
预备党员学习十八届三中全会精神思想汇报
2014/09/13 职场文书