微信小程序中如何实现省市区街道四级地址级联选择

大家好,我是雄雄。

在这里插入图片描述

前言

  • 微信小程序中支持省市区地址级联吗?
  • 微信小程序中的地址级联最多支持到几级?

今天,我们就来看看,微信小程序中的地址级联的使用,以及一些坑…希望大家看完之后能避免踩坑啊。

省市区级联

小程序中,picker组件是个很棒的组件,可以干好多事儿,微信官方对它的解释是:

从底部弹起的滚动选择器。

那么,它都支持哪些功能呢?

  1. 普通选择器(selector)
  2. 多列选择器(multiSelector)
  3. 时间选择器(time)
  4. 日期选择器(date)
  5. 省市区选择器(region)

属性列表参考如图所示:
在这里插入图片描述
选择器的类型,就是通过mode的值来区分。
mode取值如下图所示:

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我可以为您提供一些思路和方案。 首先,自定义字段名的级联选择一般可以通过两种方式实现: 1. 使用Picker组件实现级联选择; 2. 使用自定义组件实现级联选择。 下面我分别为您介绍这两种实现方式的具体步骤和注意事项。 1. 使用Picker组件实现级联选择 步骤: 1)在wxml文件定义三个Picker组件,分别用于选择一级、二级和三级字段名。例如: ``` <view class="picker-box"> <view class="picker-item"> <picker mode="selector" range="{{level1}}" bindchange="pickerChange1"> <view class="picker-value">{{value1}}</view> </picker> </view> <view class="picker-item"> <picker mode="selector" range="{{level2}}" bindchange="pickerChange2"> <view class="picker-value">{{value2}}</view> </picker> </view> <view class="picker-item"> <picker mode="selector" range="{{level3}}" bindchange="pickerChange3"> <view class="picker-value">{{value3}}</view> </picker> </view> </view> ``` 2)在js文件定义三个数组,分别用于存储一级、二级和三级字段名。例如: ``` Page({ data: { level1: ['字段名1', '字段名2', '字段名3'], level2: [], level3: [], value1: 0, value2: 0, value3: 0, }, pickerChange1: function (e) { // 级联选择,更新二级字段名 let level2 = []; let value1 = e.detail.value; switch (value1) { case 0: level2 = ['字段名1-1', '字段名1-2']; break; case 1: level2 = ['字段名2-1', '字段名2-2']; break; case 2: level2 = ['字段名3-1', '字段名3-2']; break; } this.setData({ level2: level2, value1: value1, value2: 0, value3: 0, }); }, pickerChange2: function (e) { // 级联选择,更新三级字段名 let level3 = []; let value2 = e.detail.value; switch (value2) { case 0: level3 = ['字段名1-1-1', '字段名1-1-2']; break; case 1: level3 = ['字段名1-2-1', '字段名1-2-2']; break; case 2: level3 = ['字段名2-1-1', '字段名2-1-2']; break; case 3: level3 = ['字段名2-2-1', '字段名2-2-2']; break; case 4: level3 = ['字段名3-1-1', '字段名3-1-2']; break; case 5: level3 = ['字段名3-2-1', '字段名3-2-2']; break; } this.setData({ level3: level3, value2: value2, value3: 0, }); }, pickerChange3: function (e) { // 更新三级字段名 let value3 = e.detail.value; this.setData({ value3: value3, }); }, }) ``` 注意事项: 1)在Picker组件,mode属性必须设置为selector; 2)在js文件,必须定义三个数组分别用于存储一级、二级和三级字段名; 3)在pickerChange1和pickerChange2函数,必须根据一级和二级字段名的选择更新二级和三级字段名的数组; 4)在pickerChange3函数,只需要更新三级字段名即可。 2. 使用自定义组件实现级联选择 步骤: 1)在wxml文件定义一个自定义组件,例如: ``` <view class="picker-box"> <custom-picker level="{{level1}}" bindchange="pickerChange"></custom-picker> <custom-picker level="{{level2}}" bindchange="pickerChange"></custom-picker> <custom-picker level="{{level3}}" bindchange="pickerChange"></custom-picker> </view> ``` 2)在js文件定义一个数组,用于存储所有的字段名。例如: ``` Page({ data: { fields: [ ['字段名1', '字段名2', '字段名3'], ['字段名1-1', '字段名1-2', '字段名2-1', '字段名2-2', '字段名3-1', '字段名3-2'], ['字段名1-1-1', '字段名1-1-2', '字段名1-2-1', '字段名1-2-2', '字段名2-1-1', '字段名2-1-2', '字段名2-2-1', '字段名2-2-2', '字段名3-1-1', '字段名3-1-2', '字段名3-2-1', '字段名3-2-2'], // 更多级别的字段名可以继续添加 ], value: [0, 0, 0], }, pickerChange: function (e) { let value = e.detail.value; this.setData({ value: value, }); }, }) ``` 3)在自定义组件,使用Picker组件实现级联选择。例如: ``` Component({ properties: { level: { type: Array, value: [], }, }, data: { value: 0, }, methods: { pickerChange: function (e) { let value = e.detail.value; this.setData({ value: value, }); this.triggerEvent('change', {value: value}); }, }, }) ``` 注意事项: 1)自定义组件,必须使用Picker组件实现级联选择,并且在自定义组件的properties定义level属性,用于接收父组件传递的数组; 2)在js文件,必须定义一个数组用于存储所有的字段名,并在pickerChange函数根据选择的值更新value数组; 3)在自定义组件,必须定义一个change事件,并在pickerChange函数触发该事件,将value的值传递给父组件。 以上是两种实现级联选择的方式,您可以根据自己的需要选取适合的方法。希望能够帮助到您。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

穆雄雄

哎,貌似还没开张来着呢~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值