支付宝小程序 使用uView实现省市区三级联动的坑

第一次开发支付宝小程序,已经准备好坠坑了,没想到坑这么大!!!

本次使用的是uView的2.0版本,不是1.0,别问我为什么不用1.0 ,哈哈哈哈咋就喜欢用新的

,所以坠坑就是自作自受了呜呜呜呜呜

首先就是正常的下载引入了,我在上一篇文章已经讲过怎么操作了,现在就不多说了。附上上一篇的链接CSDN

我是使用的死picker的多列模式与多列联动

属性columns传递的是数据,如果是二级联动,传递的就是二位数据 ,官方示例

凄惨的是,该组件本身不提供数据,需要我们自己定义本地数据, 

然后我找到的数据的结构是这样的。。

	const area = [{
					"value": '北京市',
					"label": '北京市',
					"children": [{
						"vallue": '北京城区',
						"label": '北京城区',
						"children": [{
							"value": '东城区',
							"label": '东城区',
							.....
						}]
					}]

		     }]

因为做的是省市区的三级联动,所以我传递的必须是三维数据,附上我改造数据的过程

// 处理省市区数据
			formatData() {
				var prov = [] //省份数组
				var shi = [] //市数组
				var qu = [] //区数组
				cities.forEach((provItem, provIndex) => {
					prov.push(provItem.value)
					if (provItem.children.length > 0) {
						provItem.children.forEach((shiItem, shiIndex) => {
							if (shi[provIndex] == null) {
								shi[provIndex] = [shiItem.value]
							} else {
								shi[provIndex].push(shiItem.value)
							}
							if (shiItem.children.length > 0) {
								shiItem.children.forEach((quItem, quIndex) => {
									if (qu[provIndex] == null) {
										qu[provIndex] = [
											[quItem.value]
										]
									} else {
										if (qu[provIndex][shiIndex] == null) {
											qu[provIndex][shiIndex] = [quItem.value]
										} else {
											qu[provIndex] 
                                            [shiIndex].push(quItem.value)
										}
									}
								})
							}
						})
					}
				})
				this.columns.push(prov, shi[0], qu[0][0])

经过一番周折终于得到了如下数据 

然后坑就来了,我赋值显示,????显示两条数据是怎么回事??“?有没有大佬看看是咋回事?

 

 我一开始以为是样式的问题,然后去改样式了。。。

通过控制台找到了类名

在vue组件中,在style标签中添加scoped属性,这样在这里定义的css只作用于当前组件中的元素,可使组件之间的样式不会相互污染,使样式私有化。比如在父组件内使用子组件,父组件的样式不会渗透到子组件中。因此我们需要使用深度作用选择器/deep/,然后根本没有作用。。。不能修改组件的样式

 

 

 好吧,我还是老老实实去用uView1.0吧。。。

完结啦!!!

有哪位大佬有解决方法的麻烦评论踢我一下!!!

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
uview的u-picker组件可以实现省市区三级联动使用时需要设置相应的数据源。以下是一个简单的例子: ```html <template> <view> <u-picker :picker-data="pickerData" :default-value="defaultValue" @change="onChange" /> </view> </template> <script> export default { data() { return { pickerData: [], defaultValue: [], }; }, mounted() { // 获取省市区数据 this.getAreaData(); }, methods: { async getAreaData() { // 发送请求获取省市区数据 const res = await this.$http.get('/api/area'); // 处理数据,将数据转换为u-picker可用的格式 this.pickerData = [ { label: '请选择', value: '', children: res.data.map((province) => ({ label: province.name, value: province.id, children: province.cities.map((city) => ({ label: city.name, value: city.id, children: city.areas.map((area) => ({ label: area.name, value: area.id, })), })), })), }, ]; // 设置默认值为当前所在地区 this.setDefaultArea(); }, setDefaultArea() { // 获取当前所在地区,将其设置为默认值 const area = this.$store.state.area; if (area.province && area.city && area.area) { this.defaultValue = [area.province.id, area.city.id, area.area.id]; } }, onChange(value) { // 处理选中的值 console.log(value); }, }, }; </script> ``` 在上面的代码中,我们使用了u-picker组件,并将picker-data设置为一个数组,数组中包含省市区三级数据。defaultValue设置为一个数组,数组中包含当前所在地区的id,这样在渲染u-picker时,就会自动选中对应的省市区。当用户选择省市区时,会触发onChange事件,我们可以在这里处理用户选择的省市区数据。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小邓不爱吃芹菜

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值