(微信小程序)动态多列选择器

  • 需求概述:先选取品类,再根据品类获取品种(每个品类下面有多个品种)
    -在这里插入图片描述

  • 以下为示例代码(.详情可参考微信开发文档

1.wxml:

      <view class="weui-cell__bd">
        <picker mode="multiSelector" bindchange="bindMultiPickerChange" bindcolumnchange="bindMultiPickerColumnChange"
          value="{{multiIndex}}" range="{{multiArray}}">
          <view class="weui-select">
            {{multiArray[1][multiIndex[1]]}}
          </view>
        </picker>
      </view>

2.js:

 // 相关数据
  data: {
    multiArray: [],     // picker 数组
    multiIndex: [0, 0], // picker index
    leftArr: [],        // picker 品类
    rightArr: [],       // picker 品种
    lastId: 0           // 选中的品种的id(提交表单时的参数之一)
  },
// 相关函数:
// 1.获取种植品类
  getPinLei: function () {
    var that = this
    wx.request({
      url: baseUrl + '/variety/list',
      data: {
        parentId: 0  // 品种
      },
      success: function (res) {
        var leftArr = res.data.data.map(item => {
          return item.name
        })
        that.setData({
          multiArray: [leftArr, []],
          type01: res.data.data,  // 左侧原始数据
          leftArr: leftArr
        })
        var leftDefaultId = res.data.data[0]['id']
        that.setData({
          parentId: leftDefaultId  // 默认品类的id
        })
        that.getPinZhong()
      }
    })
  },
// 2.获取种植品种
  getPinZhong: function () {
    var that = this
    wx.request({
      url: baseUrl + '/variety/list',
      data: {
        parentId: that.data.parentId  // 品种
      },
      success: function (res) {
        var rightArr = res.data.data.map(item => {
          return item.name
        })
        var leftArr = that.data.leftArr
        that.setData({
          multiArray: [leftArr, rightArr],//picker
          type02: res.data.data, // 右侧原始数据
          rightArr: rightArr,
          lastId: res.data.data[0]['id']
        })
      }
    })
  },
// 3.列表选择滚动
  bindMultiPickerColumnChange: function (e) {
    var data = {
      multiArray: this.data.multiArray,
      multiIndex: this.data.multiIndex
    };
    data.multiIndex[e.detail.column] = e.detail.value;

    if (e.detail.column == 0) {
      // 第1列滚动变化
      var leftIndex = e.detail.value
      var leftChangeId = this.data.type01[leftIndex]['id'] // 新的id
      this.setData({
        parentId: leftChangeId
      })
      this.getPinZhong()
      data.multiIndex[1] = 0;
    }
    this.setData(data);
  },
// 4.滚动选择确定
bindMultiPickerChange: function (e) {
    this.setData({
      multiIndex: e.detail.value  // 左右变动的id
    })
    var index01 = e.detail.value[1]
    var lastId = this.data.type02[index01]['id']
    // 获取右侧(最终的品种的id)
    this.setData({
      lastId: lastId
    })
  },

3.css:

@import '../../../style/weui@2.3.0.wxss';
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值