uniApp内置组件picker级联选择懒加载

需要通过省份id去查找城市,picker的数据是二维数组,不需要放到对应的children里面

<!-- 通过 range-key 来指定 Object 中 key 的值作为选择器显示内容,chooseProvincial数据格式为[[],[]] -->
<picker mode="multiSelector" range-key="SHORT_NAME" @columnchange="chooseProvincial" :range="addressList">
	<view style="height: 36px;line-height: 36px;">
        {{city ? city : '请选择工作城市'}}
    </view>
</picker>


// provincialList为省份列表,初始化查询出来放入addressList[0]
async chooseProvincial(e) {
	// 第一列,选择省份
	if (e.detail.column == 0) {
        // 用下标找到省份id去查询城市
		let code = this.provincialList[e.detail.value].PROVINCE_CODE
		let res = await this.$apis.getCity({ PROVINCE_CODE: code })
		this.addressList[1] = res
        // 强制视图更新
		this.$set(this.addressList, 1, res)
	}
	// 第二列,选择城市
	if (e.detail.column == 1) {
        // 选中城市名字
		this.city = this.addressList[1][e.detail.value].SHORT_NAME
        // 存入表的城市id
		this.baseFormData.city = this.addressList[1][e.detail.value].CITY_CODE
	}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值