小程序三级联动结合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中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Ubuntu设置程序开机自启动的操作步骤

《Ubuntu设置程序开机自启动的操作步骤》在部署程序到边缘端时,我们总希望可以通电即启动我们写好的程序,本篇博客用以记录如何在ubuntu开机执行某条命令或者某个可执行程序,需要的朋友可以参考下... 目录1、概述2、图形界面设置3、设置为Systemd服务1、概述测试环境:Ubuntu22.04 带图

Python程序打包exe,单文件和多文件方式

《Python程序打包exe,单文件和多文件方式》:本文主要介绍Python程序打包exe,单文件和多文件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python 脚本打成exe文件安装Pyinstaller准备一个ico图标打包方式一(适用于文件较少的程

Python程序的文件头部声明小结

《Python程序的文件头部声明小结》在Python文件的顶部声明编码通常是必须的,尤其是在处理非ASCII字符时,下面就来介绍一下两种头部文件声明,具有一定的参考价值,感兴趣的可以了解一下... 目录一、# coding=utf-8二、#!/usr/bin/env python三、运行Python程序四、

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

SpringBoot后端实现小程序微信登录功能实现

《SpringBoot后端实现小程序微信登录功能实现》微信小程序登录是开发者通过微信提供的身份验证机制,获取用户唯一标识(openid)和会话密钥(session_key)的过程,这篇文章给大家介绍S... 目录SpringBoot实现微信小程序登录简介SpringBoot后端实现微信登录SpringBoo

uniapp小程序中实现无缝衔接滚动效果代码示例

《uniapp小程序中实现无缝衔接滚动效果代码示例》:本文主要介绍uniapp小程序中实现无缝衔接滚动效果的相关资料,该方法可以实现滚动内容中字的不同的颜色更改,并且可以根据需要进行艺术化更改和自... 组件滚动通知只能实现简单的滚动效果,不能实现滚动内容中的字进行不同颜色的更改,下面实现一个无缝衔接的滚动

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

Java使用WebView实现桌面程序的技术指南

《Java使用WebView实现桌面程序的技术指南》在现代软件开发中,许多应用需要在桌面程序中嵌入Web页面,例如,你可能需要在Java桌面应用中嵌入一部分Web前端,或者加载一个HTML5界面以增强... 目录1、简述2、WebView 特点3、搭建 WebView 示例3.1 添加 JavaFX 依赖3