微信小程序省市联动功能

阅读 14845  ·  发布日期 2020-08-24 17:26  ·  温州雄霸网络科技有限公司|建站|APP小程序制作|做网站SEO推广优化
【摘要】 最近呢刚好做了一个省市联动的功能,今天看到有人问这个怎么做,我就把我做的放上来共享一下:首先呢,来看看效果,点击文字‘点击’,弹出选择窗口,点击取消或者确定(取消、确定按钮在选择框上边,截图有些不清楚),窗口下滑,做这个我用的是picker-view这个组件,现在来看一看picker-view的属性:现在开始写wxml... 【温州小程序开发,温州微信公众号,平阳做网站,平阳网站建设公司,平阳小程序商城制作,昆阳万全做网站,鳌江水头小程序,萧江腾蛟微信公众号,山门顺溪南雁海西南麂凤卧麻步怀溪网络网店服务,政采云网店管理服务】...

微信小程序省市联动功能

最近呢刚好做了一个省市联动的功能,今天看到有人问这个怎么做,我就把我做的放上来共享一下:
首先呢,来看看效果,点击文字‘点击’,弹出选择窗口,点击取消或者确定(取消、确定按钮在选择框上边,截图有些不清楚),窗口下滑,做这个我用的是picker-view这个组件,现在来看一看picker-view的属性:
现在开始写wxml的代码,对了,插一句,我这里是把它写成一个模板的,先看看目录结构我们先来看看cascade.wxml里的代码:
接下来是cascade.wxss的代码:
.cascade_box{
font-size:28rpx;
width: 100%;
height: 0;
position: fixed;
bottom: 0;
left: 0;
}
.cascade_hei{
width: 100%;
height:732rpx;
background: #000;
opacity: 0.5;
}
.cascade_find{
width: 100%;
height: 500rpx;
position: relative;
/*bottom: 0;
left: 0;
*/ background: #fff;
}
.quxiao,.queren{
display: block;
position: absolute;
width: 100rpx;
height: 80rpx;
line-height: 80rpx;
/*background: #00f;
*/ text-align: center;
color: #0f0;
}
.queren{
right: 0;
top: 0;
}
.cascade_header{
height: 80rpx;
width: 100%;
margin-bottom: 20rpx;
}
好了这里的模板写好了,接下来是引用,引用就很简单了:
首先是las.wxml的引用:
点击  省:
{
{
jieguo.sheng}
}
  市:
{
{
jieguo.shi}
}
  区:
{
{
jieguo.qu}
}
然后是las.wxss的引用(你没看错就是一句):
@import '
../../teml/cascade.wxss'
;
接下来就是JS了:
在这里要先说一下保存省市的名称的json文件格式,这个json文件里又全国的省市名称(这里只写了北京市为例子,这是我请求的数据的例子,你要根据你自己请求的数据来做一些JS的判断):
{
"regions": [{
"id": 110000, "name": "北京", "regions": [{
"id": 110100, "name": "北京市", "regions": [{
"id": 110101, "name": "东城区" }
, {
"id": 110102, "name": "西城区" }
, {
"id": 110103, "name": "崇文区" }
, {
"id": 110104, "name": "宣武区" }
, {
"id": 110105, "name": "朝阳区" }
, {
"id": 110106, "name": "丰台区" }
, {
"id": 110107, "name": "石景山区" }
, {
"id": 110108, "name": "海淀区" }
, {
"id": 110109, "name": "门头沟区" }
, {
"id": 110111, "name": "房山区" }
, {
"id": 110112, "name": "通州区" }
, {
"id": 110113, "name": "顺义区" }
, {
"id": 110114, "name": "昌平区" }
, {
"id": 110115, "name": "大兴区" }
, {
"id": 110116, "name": "怀柔区" }
, {
"id": 110117, "name": "平谷区" }
, {
"id": 110228, "name": "密云县" }
, {
"id": 110229, "name": "延庆县" }
] }
], "pinyin": "BeiJing", "hot": true, "municipality": true }
]}
这里就是对数据进行操作的las.js了Page({
data: {
sheng: [],//获取到的所有的省 shi: [],//选择的该省的所有市 qu: [],//选择的该市的所有区县 sheng_index:0,//picker-view省项选择的value值 shi_index:0,//picker-view市项选择的value值 qu_index:0,//picker-view区县项选择的value值 shengshi:null,//取到该数据的所有省市区数据 jieguo:{
}
,//最后取到的省市区名字 animationData: {
}
}
, //点击事件,点击弹出选择页 dianji:function(){
    //这里写了一个动画,让其高度变为满屏 var animation = wx.createAnimation({
duration: 500, timingFunction: '
ease'
, }
) this.animation = animation animation.height(1332+'
rpx'
).step() this.setData({
animationData:animation.export() }
) }
, //取消按钮 quxiao:function(){
    //这里也是动画,然其高度变为0 var animation = wx.createAnimation({
duration: 500, timingFunction: '
ease'
, }
) this.animation = animation animation.height(0+'
rpx'
).step() this.setData({
animationData:animation.export() }
);
    //取消不传值,这里就把jieguo 的值赋值为{
}
this.setData({
jieguo:{
}
}
);
console.log(this.data.jieguo);
}
, //确认按钮 queren:function(){
   //一样是动画,级联选择页消失,效果和取消一样 var animation = wx.createAnimation({
duration: 500, timingFunction: '
ease'
, }
) this.animation = animation animation.height(0+'
rpx'
).step() this.setData({
animationData:animation.export() }
);
//打印最后选取的结果 console.log(this.data.jieguo);
}
, //滚动选择的时候触发事件 bindChange: function(e) {
//这里是获取picker-view内的picker-view-column 当前选择的是第几项  const val = e.detail.value this.setData({
sheng_index: val[0], shi_index: val[1], qu_index: val[2] }
) this.jilian();
console.log(val);
console.log(this.data.jieguo);
}
, //这里是判断省市名称的显示 jilian:function(){
var that=this, shengshi=that.data.shengshi, sheng=[], shi=[], qu=[], qu_index=that.data.qu_index, shi_index=that.data.shi_index, sheng_index=that.data.sheng_index;
    //遍历所有的省,将省的名字存到sheng这个数组中 for (let i =0;
i i++) {
sheng.push(shengshi[i].name) }
if(shengshi[sheng_index].regions){
//这里判断这个省级里面有没有市(如数据中的香港、澳门等就没有写市) if(shengshi[sheng_index].regions[shi_index]){
//这里是判断这个选择的省里面,有没有相应的下标为shi_index的市,因为这里的下标是前一次选择后的下标,比如之前选择的一个省有10个市,我刚好滑到了第十个市,现在又重新选择了省,但是这个省最多只有5个市,但是这时候的shi_index为9,而这里的市根本没有那么多,所以会报错           //这里如果有这个市,那么把选中的这个省中的所有的市的名字保存到shi这个数组中 for(let i=0;
ii++){
shi.push(shengshi[sheng_index].regions[i].name);
}
console.log('
执行了区级判断'
);
if(shengshi[sheng_index].regions[shi_index].regions){
//这里是判断选择的这个市在数据里面有没有区县 if(shengshi[sheng_index].regions[shi_index].regions[qu_index]){
//这里是判断选择的这个市里有没有下标为qu_index的区县,道理同上面市的选择 console.log('
这里判断有没有进区里'
);
            //有的话,把选择的这个市里面的所有的区县名字保存到qu这个数组中 for(let i=0;
ii++){
console.log('
这里是写区得'
);
qu.push(shengshi[sheng_index].regions[shi_index].regions[i].name);
}
}
else{
          //这里和选择市的道理一样 that.setData({
qu_index:0 }
);
for(let i=0;
ii++){
qu.push(shengshi[sheng_index].regions[shi_index].regions[i].name);
}
}
}
else{
            //如果这个市里面没有区县,那么把这个市的名字就赋值给qu这个数组 qu.push(shengshi[sheng_index].regions[shi_index].name);
}
}
else{
      //如果选择的省里面没有下标为shi_index的市,那么把这个下标的值赋值为0;然后再把选中的该省的所有的市的名字放到shi这个数组中 that.setData({
shi_index:0 }
);
for(let i=0;
ii++){
shi.push(shengshi[sheng_index].regions[i].name);
}
}
}
else{
      //如果该省级没有市,那么就把省的名字作为市和区的名字 shi.push(shengshi[sheng_index].name);
qu.push(shengshi[sheng_index].name);
}
console.log(sheng);
console.log(shi);
console.log(qu);
//选择成功后把相应的数组赋值给相应的变量 that.setData({
sheng: sheng, shi: shi, qu: qu }
);
    //有时候网络慢,会出现区县选择出现空白,这里是如果出现空白那么执行一次回调 if(sheng.length==0||shi.length==0||qu.length==0){
that.jilian();
console.log('
这里执行了回调'
);
// console.log();
}
console.log(sheng[that.data.sheng_index]);
console.log(shi[that.data.shi_index]);
console.log(qu[that.data.qu_index]);
    //把选择的省市区都放到jieguo中 let jieguo={
sheng:sheng[that.data.sheng_index], shi:shi[that.data.shi_index], qu:qu[that.data.qu_index] }
;
   that.setData({
jieguo:jieguo }
);
}
, onLoad:function(){
var that=this;
//请求省市区的数据 wx.request({
url: '
https://wxxapp.duapp.com/quanguo.json'
,//由于服务器已关闭,这个地址已经无法使用,请用自己的数据来写 data: {
}
, method: '
GET'
, success: function(res){
// success console.log(res.data.regions);
// shengshi=res.data.regions that.setData({
shengshi:res.data.regions }
);
       that.jilian();
}
, fail: function() {
// fail }
, complete: function() {
// complete }
}
) }
}
)推荐教程:
《微信小程序》以上就是微信小程序省市联动功能的详细内容,更多请关注php中文网其它相关文章!
微信
分享相关标签:
微信小程序 省市联动本文转载于:
博客园,如有侵犯,请联系a@php.cn删除
上一篇:
新手必备的微信小程序开发指南
下一篇:
微信小程序转发好友的功能相关文章相关视频VUE2实现二级省市联动选择利用JavaScript如何实现省市联动javascript实现省市联动的代码分享如何使用JavaScript完成省市联动效果微信小程序省市联动功能 [温州做小程序]