小程序三级联动结合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

相关文章

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

C#控制台程序同步调用WebApi实现方式

《C#控制台程序同步调用WebApi实现方式》控制台程序作为Job时,需同步调用WebApi以确保获取返回结果后执行后续操作,否则会引发TaskCanceledException异常,同步处理可避免异... 目录同步调用WebApi方法Cls001类里面的写法总结控制台程序一般当作Job使用,有时候需要控制

Python利用GeoPandas打造一个交互式中国地图选择器

《Python利用GeoPandas打造一个交互式中国地图选择器》在数据分析和可视化领域,地图是展示地理信息的强大工具,被将使用Python、wxPython和GeoPandas构建的交互式中国地图行... 目录技术栈概览代码结构分析1. __init__ 方法:初始化与状态管理2. init_ui 方法:

SpringBoot结合Knife4j进行API分组授权管理配置详解

《SpringBoot结合Knife4j进行API分组授权管理配置详解》在现代的微服务架构中,API文档和授权管理是不可或缺的一部分,本文将介绍如何在SpringBoot应用中集成Knife4j,并进... 目录环境准备配置 Swagger配置 Swagger OpenAPI自定义 Swagger UI 底

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker