小程序三级联动结合vant weap(有赞)的picker选择器和popup弹出层

本文主要是介绍小程序三级联动结合vant weap(有赞)的picker选择器和popup弹出层,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

小程序三级联动结合vant weap(有赞)的picker选择器和popup弹出层

首先看数据结构

做的是地址联动和工种联动,数据结构基本相同

只贴一种地址联动的代码就好,用的比较多

  
addressList: function() {
//这个就是接口拿到地址数据resume.addressList().then(res => {this.setData({areaList: res.data[0].childSRegion});var areaList = this.data.areaList;this.setData({columns22: [{values: areaList,className: 'column1'},{values: areaList[0].childSRegion,className: 'column2',defaultIndex: 0},{values: areaList[0].childSRegion[0].childSRegion,className: 'column3',defaultIndex: 0}]});
//单独开一个setData放三级联动的结构,里面只放这一关数组,不要再放其他的了(否则错都查不到)values里面放第一级到第三级,className这个就没太所谓,defaultIndex:初始选中项的索引,默认为 0}).catch(res => {});},

 

json里面要引需要用到的vant的组件,例如这样,地址根据自己装的地址去配置

{"usingComponents": {"van-field": "/miniprogram_npm/vant-weapp/field/index","van-picker": "/miniprogram_npm/vant-weapp/picker/index","van-popup": "/miniprogram_npm/vant-weapp/popup/index"},"navigationBarTitleText": "地址联动"
}

wxml代码

这个里面就放了一个输入框,一个popup层,一个picker

      <van-field value="{{ regionValue  }}" label="工作城市" placeholder="选择工作城市" border="{{ false }}" readonly class="form-input-item" right-icon="arrow" icon="arrow" bindtap="showPopup22" /><van-popup show="{{show22}}" position="bottom"><van-picker show-toolbar title="请选择工作城市" columns="{{ columns22 }}" value-key="name" bind:change="onChange22" bind:confirm="onConfirm22" bind:cancel="onCancel" /></van-popup>

js事件

  //展示popup层//把名称初始给三级联动第一个//id也对应三级联动的第一个//这里即:北京/北京市/东城区showPopup22: function() {this.setData({regionValue1:this.data.areaList[0].name +'/' + this.data.areaList[0].childSRegion[0].name +'/' + this.data.areaList[0].childSRegion[0].childSRegion[0].name,region1: this.data.areaList[0].childSRegion[0].childSRegion[0].id,show22: true});},
//选择改变监听//对应picker里面的选项改变时触发//改变第一级同时会改变第二级和第三级onChange22(event) {console.log(event);const { picker, value, index } = event.detail;if (event.detail.index === 0) {picker.setColumnValues(1, value[0].childSRegion);picker.setColumnValues(2, value[0].childSRegion[0].childSRegion);this.setData({regionValue1: value[0].name+'/'+ value[0].childSRegion[0].name+'/'+value[0].childSRegion[0].childSRegion[0].name,region1: value[0].childSRegion[0].childSRegion[0].id})
//这个setData的是滑动第一级时触发,这改变了第一级的数值,并不会改变后面的数值,setDate//每一层在setData是有必要的,不然名称和id可能传的并非想要选中的,可以实时console.log(event)查看里面的值对应上} else if (event.detail.index === 1) {picker.setColumnValues(2, value[1].childSRegion);this.setData({regionValue1: value[0].name+'/'+value[1].name+'/'+ value[1].childSRegion[0].name,region1: value[1].childSRegion[0].id})} else if (event.detail.index == 2) {picker.setColumnValues(2, value[1].childSRegion);this.setData({regionValue1: value[0].name+'/'+value[1].name+'/'+ value[2].name,region1: value[2].id})}//setData里面更新索引所对应的名称和id//毕竟自己显示用名称,给后台要给对应的id},
//工作城市确定//确定只是用来明确显示用的名称和可能需要给后台的id(毕竟上面一步只是改变,没有确定,还不能给他赋值)//确定了就要关闭popup层了,该拿到的都已经拿到了onConfirm22: function() {this.setData({regionValue: this.data.regionValue1,region: this.data.region1});this.onCancel();},
// 关闭popup层onCancel() {this.setData({show22: false});},

 

这篇关于小程序三级联动结合vant weap(有赞)的picker选择器和popup弹出层的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/304267

相关文章

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

Python结合Flask框架构建一个简易的远程控制系统

《Python结合Flask框架构建一个简易的远程控制系统》这篇文章主要为大家详细介绍了如何使用Python与Flask框架构建一个简易的远程控制系统,能够远程执行操作命令(如关机、重启、锁屏等),还... 目录1.概述2.功能使用系统命令执行实时屏幕监控3. BUG修复过程1. Authorization

基于Python开发PDF转Doc格式小程序

《基于Python开发PDF转Doc格式小程序》这篇文章主要为大家详细介绍了如何基于Python开发PDF转Doc格式小程序,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用python实现PDF转Doc格式小程序以下是一个使用Python实现PDF转DOC格式的GUI程序,采用T

将java程序打包成可执行文件的实现方式

《将java程序打包成可执行文件的实现方式》本文介绍了将Java程序打包成可执行文件的三种方法:手动打包(将编译后的代码及JRE运行环境一起打包),使用第三方打包工具(如Launch4j)和JDK自带... 目录1.问题提出2.如何将Java程序打包成可执行文件2.1将编译后的代码及jre运行环境一起打包2

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

Python结合requests和Cheerio处理网页内容的操作步骤

《Python结合requests和Cheerio处理网页内容的操作步骤》Python因其简洁明了的语法和强大的库支持,成为了编写爬虫程序的首选语言之一,requests库是Python中用于发送HT... 目录一、前言二、环境搭建三、requests库的基本使用四、Cheerio库的基本使用五、结合req

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

EMLOG程序单页友链和标签增加美化

单页友联效果图: 标签页面效果图: 源码介绍 EMLOG单页友情链接和TAG标签,友链单页文件代码main{width: 58%;是设置宽度 自己把设置成与您的网站宽度一样,如果自适应就填写100%,TAG文件不用修改 安装方法:把Links.php和tag.php上传到网站根目录即可,访问 域名/Links.php、域名/tag.php 所有模板适用,代码就不粘贴出来,已经打