php城市区域选择器,微信小程序 省市区选择器实例详解

微信小程序 省市区选择器:

最近学习微信小程序,为了检验自己的学习效果,自己做一个小示例,网上搜索下类似的实例,发现这个更好,大家看下。

一、区域间手势滑动切换,标题栏高亮随之切换

思路是:拿当前的current来决定高亮样式

1.监听swiper滚动到的位置:

currentChanged: function (e) {

// swiper滚动使得current值被动变化,用于高亮标记

var current = e.detail.current;

this.setData({

current: current

});

}

2.布局文件中做条件判断,是否加上高亮样式,其中area-selected是目标样式,color: red;

{{provinceName}}

{{provinceName}}

{{cityName}}

{{cityName}}

{{regionName}}

{{regionName}}

{{townName}}

{{townName}}

3.点击上级时为下一级赋予“请选择”字样provinceTapped: function(e) {

...

that.setData({

cityName: '请选择',

city: array,

cityObjects: area

});

...

}

其他级别以其类推。

效果如下:

bc0236c3706abc90011a4c51f308fcc4.gif

二、标题栏点击切换,则区域间也随着切换changeCurrent: function (e) {

// 记录点击的标题所在的区级级别

var current = e.currentTarget.dataset.current;

this.setData({

current: current

});

}

标题栏上绑定点击事件

效果如下:

69c03c149a92790d297d3d106ba20b26.gif

数据绑定用起来果然是爽,寥寥几句代码完成了点击切换,要是别的平台的写同样的功能,这要写半天。

三、回到前一级点击某区域后,要自动将往后级的数组、index、name、array清空,否则逻辑错乱了。

例如,依次选择了北京-朝阳区-三环以内之后,又回到了省级选择了浙江省,此时二级三级区域都还是原先所选的朝阳区-三环以内,左右滑动区域内容也显示的是错的。

为了解决这个bug,需要再次处理tapped点击事件,将子级的选择清空。provinceTapped: function(e) {

// 标识当前点击省份,记录其名称与主键id都依赖它

var index = e.currentTarget.dataset.index;

// current为1,使得页面向左滑动一页至市级列表

// provinceIndex是市区数据的标识

this.setData({

current: 2,

cityIndex: index,

regionIndex: -1,

townIndex: -1,

cityName: this.data.city[index],

regionName: '',

townName: '',

region: [],

town: []

});

...

}

b4d3ce7571ce8cbc89c55983fcdc9d2f.gif

四、修正一初始化即提供4个swiper-item的bug

处理方式是加一个数组的元素个数是否为零,例如城市当它有值才显现

{{item}}

{{item}}

相应地在js文件中生成它this.setData({

- current: 2,

cityIndex: index,

regionIndex: -1,

townIndex: -1,

this.setData({

region: array,

regionObjects: area

});

+ // 确保生成了数组数据再移动swiper

+ that.setData({

+ current: 2

+ });

});

注意这里是将current的setData操作移到region与regionObject之下了,保证了先有值再控制swiper的位移。

最后上一个与原生picker写的对比gif图:

80f3026d6ab2139587c98cd5f75934c0.gif

不用在picker上反复点击反复选择,也不会出现跨级点击的问题,体验上是不是有好一点呢?

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

更多微信小程序 省市区选择器实例详解相关文章请关注PHP中文网!

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值