资讯专栏INFORMATION COLUMN

演示微信小程序地区选择伪五级联动

3403771864 / 197人阅读

  在项目中,要求微信小程序的地区可以选择伪五级联动

  展示如下

  这里采用的是自定义多列选择器picker mode="multiSelector"

  <view class="section">
  <view class="section__title">多列选择器</view>
  <picker mode="multiSelector" bindchange="bindMultiPickerChange" bindcolumnchange="bindMultiPickerColumnChange" value="{{multiIndex}}" range="{{multiArray}}">
  <view wx:if="{{multiIndex[0]==0}}" class="picker" style='font-size:24rpx'>
  当前选择:全国
  </view>
  <view wx:elif="{{multiIndex[1]==0}}" class="picker" style='font-size:24rpx'>
  当前选择:{{multiArray[0][multiIndex[0]]}}
  </view>
  <view wx:elif="{{multiIndex[2]==0}}" class="picker" style='font-size:24rpx'>
  当前选择:{{multiArray[0][multiIndex[0]]}}-{{multiArray[1][multiIndex[1]]}}
  </view>
  <view wx:elif="{{multiIndex[3]==0}}" class="picker" style='font-size:24rpx'>
  当前选择:{{multiArray[0][multiIndex[0]]}}-{{multiArray[1][multiIndex[1]]}}-{{multiArray[2][multiIndex[2]]}}
  </view>
  <view wx:else class="picker" style='font-size:24rpx'>
  当前选择:{{multiArray[0][multiIndex[0]]}}-{{multiArray[1][multiIndex[1]]}}-{{multiArray[2][multiIndex[2]]}}-{{multiArray[3][multiIndex[3]]}}
  </view>
  </picker>
  </view>

  multiArray包含4个数组(省市县镇),multiIndex是4个数组对应选中下标

  onLoad: async function (options) {
  let chinaData = await getCountryList()
  chinaData.unshift({city: [],code: 0,name: "全部"})
  for(let one of chinaData){
  one.city.unshift({county: [],code: 0,name: "全部"})
  for(let two of one.city){
  two.county.unshift({code: 0,name: "全部"})
  }
  }
  this.data.chinaData = chinaData;
  let sheng = []; // 设置省数组
  for(let i = 0; i < chinaData.length; i++) {
  sheng.push(chinaData[i].name);
  }
  this.setData({
  "multiArray[0]": sheng
  })
  this.getCity(); // 得到市
  },
  bindMultiPickerChange: function(e) {
  console.log(e);
  },
  bindMultiPickerColumnChange: function(e) {
  let move = e.detail;
  let index = move.column;
  let value = move.value;
  if (index == 0) {
  this.setData({
  multiIndex: [value,0,0,0]
  })
  this.getCity();
  }
  if (index == 1) {
  this.setData({
  "multiIndex[1]": value,
  "multiIndex[2]": 0,
  "multiIndex[3]": 0
  })
  this.getXian();
  }
  if (index == 2) {
  this.setData({
  "multiIndex[2]": value,
  "multiIndex[3]": 0,
  })
  this.getZhen();
  }
  if (index == 3) {
  this.setData({
  "multiIndex[3]": value
  })
  this.getZhen();
  }
  },
  getCity: function() { // 得到市
  let shengNum = this.data.multiIndex[0];
  let chinaData = this.data.chinaData;
  let cityData = chinaData[shengNum].city;
  let city = [];
  for (let i = 0; i < cityData.length; i++) {
  city.push(cityData[i].name)
  }
  this.setData({
  "multiArray[1]": city
  })
  this.getXian();
  },
  getXian: function(e) { // 得到县
  let shengNum = this.data.multiIndex[0];
  let cityNum = this.data.multiIndex[1];
  let chinaData = this.data.chinaData;
  let xianData = chinaData[shengNum].city[cityNum].county;
  let xian = [];
  for (let i = 0; i < xianData.length; i++) {
  xian.push(xianData[i].name)
  }
  this.setData({
  "multiArray[2]": xian
  })
  this.getZhen();
  },
  async getZhen(){// 得到镇
  let shengNum = this.data.multiIndex[0];
  let cityNum = this.data.multiIndex[1];
  let xianNum = this.data.multiIndex[2];
  let chinaData = this.data.chinaData;
  let zhen = [];
  if(chinaData[shengNum].city[cityNum].county[xianNum].code == 0){
  this.setData({
  "multiArray[3]" : ["全部"]
  })
  }else{
  //这里需要传县的code值获取镇的数据
  let res = await getTownByCounty(chinaData[shengNum].city[cityNum].county[xianNum].code)
  let zhenData = JSON.parse(res.data.data.json)
  zhenData.unshift({code: 0,name: "全部"})
  for (let i = 0; i < zhenData.length; i++) {
  zhen.push(zhenData[i].name)
  }
  this.setData({
  "multiArray[3]" : zhen
  })
  }
  }

  省市县数据返回类型

  镇返回数据

        内容已讲述完毕,欢迎大家关注后续更多精彩内容。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/128281.html

相关文章

  • 初尝信小程序2-基本框架

    摘要:有的文件不是必须的,可以参考微信小程序官方文档。应用程序和页面之间的关系微信小程序允许纵向级数最高五级,后面会介绍导航组件,设置几级页面以及之间的跳转。基本框架: .wxml :页面骨架 .wxss :页面样式 .js :页面逻辑    描述一些行为 .json :页面配置 创建一个小程序之后,app.js,app.json,app.wxss是必须的,而且名字也不能随意更改,这些是作用于AP...

    weij 评论0 收藏0
  • 信小程序页面间通信的5种方式

    摘要:另外因为依赖,而可能出现读写失败,从面造成通信失败注意点页面初始化时也会触发方式二小程序同方式一一样,利用激活方法,通过读写小程序完成数据传递清队上次通信数据优点实现简单,实现理解。 微信小程序页面间通的5种方式 PageModel(页面模型)对小程序而言是很重要的一个概念,从app.json中也可以看到,小程序就是由一个个页面组成的。 showImg(https://segmentf...

    lei___ 评论0 收藏0
  • 大厂程序员接私活被坑, 还被放鸽子,那源码就开源-基于SSM仿知乎小程序

    摘要:最近很郁闷,一个女粉丝找我要开发一个系统。但是后来,越扯越严重上升到块要开发一个知乎的高度。主要实现了仿知乎微信小程序的文件管理功能。点击下面,回复小程序 最近很郁闷,一个女粉丝找我要开发一个系统。说是很着急。   但是费用不高,说自己没钱。   我平时事也很多,又不是很想接。   说了一大...

    dongxiawu 评论0 收藏0
  • 教你从零开始使用wordpress生成信小程序(小白版教程)

    摘要:准备工作服务器最好使用服务器,小白推荐安装宝塔面板。备案域名小程序账号建议注册企业账号,可以使用已认证的公众号快速创建。七牛账号使用,加快网站访问速度。如需使用小程序发帖,也会用到。注意不要使用以下的。 showImg(https://segmentfault.com/img/bVUUeU?w=600&h=280); 准备工作 1服务器 最好使用Linux服务器,小白推荐安装宝塔面板。...

    jaysun 评论0 收藏0
  • 信小程序[第十一篇] -- 添加照片(小程序图片上传功能)

    摘要:注拍照功能在某些机型上还有闪退现象,希望微信官方可以尽快完善。这涉及到函数,这是微信小程序内置的,用来上传一个文件,有几个点要说下绿色框要上传文件资源的路径,也就是我们相册里选择的图片路径。 我们喜欢小程序的原因之一就是它提供了更多和手机系统交互的接口,比如今天要说的这个从相册选择 / 拍照功能。注:拍照功能在某些机型上还有闪退现象,希望微信官方可以尽快完善。 在上一篇中我们搞定了相册...

    muzhuyu 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<