uniapp picker实现:市区镇村4级懒加载

2023-10-26

使用这种方法的原因:

  • 市区镇村4级数据太大,后台接口响应时间太长

方法实现:

  • 样式
    在这里插入图片描述

  • view

      <view class="inputbox clearfix outbox" @click="showTrue">
        <text class="fl lefttxt">所在地区</text>
		<picker mode="multiSelector" :range="mulSelect" :range-key="'deptName'" @change="pickerChange" @columnchange="colChange">
			<view :class="{active:isActive}" v-if="!address">
				<u--input fontSize="12px" class="fl oneinput" suffixIcon="arrow-down" suffixIconStyle="color: #3CB261"
				v-model="userInfo.address" disabled placeholder="请选择" border="none"></u--input>
			</view>
			<view v-else style="font-size:12px;">{{address}}</view>
		</picker>
      </view>
  • data
  data() {
      return {
		province: [], //省数组
		city: [], //市数组
		district: [], //区数组
		street: [], //街道数组
		mulSelect: [], //四级联动显示数组,该数组的值为[[province],[city],[district],[street]]
		provinceId: 0, //省的id
		cityId: 0, //市的id
		districtId: 0,//区的id
		isActive:false,
		address:'',
      }
 }
  • methods
    onLoad(options) {
		this.getProvince();
    },
    methods: {
        colChange(e) {
			switch (e.detail.column){
				case 0://选择市
					this.provinceId=this.mulSelect[0][e.detail.value].deptId;
					// 获取对应的 区县
					getCountyListByCityApi({deptId:this.provinceId}).then(res=>{
						if(res.code == 200){
							this.city = res.data;
							this.mulSelect[1]=this.city;
							// 获取对应的乡镇
							getCountyListByCityApi({deptId:this.city[0].deptId}).then(res=>{
								if(res.code == 200){
									this.district = res.data;
									this.mulSelect[2]=this.district;
									// 获取对应的村
									getCountyListByCityApi({deptId:this.district[0].deptId}).then(res=>{
										if(res.code == 200){
											this.street = res.data;
											this.mulSelect[3]=this.street;
										}
									})
								}
							})
						}
					})
					break;
				case 1://选择区县
					this.cityId=this.mulSelect[1][e.detail.value].deptId;
					// 获取对应的乡镇
					getCountyListByCityApi({deptId:this.cityId}).then(res=>{
						if(res.code == 200){
							this.district = res.data;
							this.mulSelect[2]=this.district;
							// 获取对应的村
							getCountyListByCityApi({deptId:this.district[0].deptId}).then(res=>{
								if(res.code == 200){
									this.street = res.data;
									this.mulSelect[3]=this.street;
									
								}
							})
						}
					})
					break;
				case 2://选择镇
					this.districtId=this.mulSelect[2][e.detail.value].deptId;
					getCountyListByCityApi({deptId:this.districtId}).then(res=>{
						if(res.code == 200){
							this.street = res.data;
							this.mulSelect[3]=this.street;
						}
					});
					break;
				case 3://选择街道
					break;
				default:
					break;
			}
		},
        pickerChange(e) {
			//什么都不选的话,e.detail.value的值为[null,null,null,null]
			//只选择省的话,e.detail.value的值为[数字,null,null,null]
			//只选择市的话,e.detail.value的值为[数字,数字,null,null]
			//所以获取e.detail.value的值先判断是否为null,如果为null则取值为0
			for(var i=0;i<e.detail.value.length;i++){
				if(e.detail.value[i]===null){
					e.detail.value[i]=0;
				}
			}
			var s_province=this.mulSelect[0][e.detail.value[0]];//获取选中的省
			var s_city=this.mulSelect[1][e.detail.value[1]||0];//获取选中的市
			var s_district=this.mulSelect[2][e.detail.value[2]||0];//获取选中的区
			var s_street=this.mulSelect[3][e.detail.value[3]||0];//获取选中的街道
			// console.log(e.detail.value);
			//赋值显示在页面
			this.address=s_province.deptName+s_city.deptName+s_district.deptName+s_street.deptName;
			//将字体颜色修改为黑色
			this.isActive=true;
			console.log(s_street);
			// 给表单复制
			this.userInfo.address = s_street.deptId
		},
    	getProvince() { // 此方法可以继续优化
			var that = this;
			getAllCityListApi({}).then(res=>{
				that.province = []
				if(res.code == 200){
					that.province = res.data;;
					that.mulSelect.push(that.province);
					var p = that.province[0].deptId;
					getCountyListByCityApi({deptId:p}).then(res=>{
						if(res.code == 200){
							that.city = res.data;
							that.mulSelect.push(that.city);
							var p = that.city[0].deptId;
							getCountyListByCityApi({deptId:p}).then(res=>{
								if(res.code == 200){
									that.district = res.data;
									that.mulSelect.push(that.district);
									var p = that.district[0].deptId;
									getCountyListByCityApi({deptId:p}).then(res=>{
										if(res.code == 200){
											that.street = res.data;
											that.mulSelect.push(that.street);
										}
									})
								}
							})
						}
					})
				}
			})
		},

    }
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

uniapp picker实现:市区镇村4级懒加载 的相关文章

  • 在反应中将索引从一个函数传递到另一个函数

    我有一个项目列表 单击删除按钮后该项目将被删除 我知道执行此操作的步骤 但我不知道如何将密钥传递到 dlt item 范围 http jsfiddle net 3Ley7uac 1 http jsfiddle net 3Ley7uac 1
  • 服务器重新启动时显示等待页面

    我有一个服务器并为其创建一个 Web 界面 如果用户按下页面上的重新启动按钮 则用户将被重定向到reboot php他应该看到一个旋转 gif 直到服务器再次可访问并且服务器通过 shell 执行重新启动 如果服务器可以访问 那么我需要重定
  • 如何阻止 HTML 输入字段中的特殊字符? [关闭]

    Closed 这个问题需要多问focused help closed questions 目前不接受答案 我只是想问一下如何在html输入字段中阻止 等特殊字符 为什么不使用html5呢
  • 单击浏览器后退按钮时,将用户带回到他们在上一页滚动到的位置

    当用户按下浏览器中的后退按钮时 是否可以将用户带回到他们向下滚动到的页面区域 如 pageA 是屏幕大小的两倍 因此您必须滚动才能阅读更多内容 您单击 pageA 上的链接转到新页面 pageB 阅读后 您在浏览器中单击 返回 现在 当您返
  • Node.js npm mssql 函数返回未定义

    我使用 mssql 和 node js 连接到 sql server 数据库 我试图通过将连接代码包装在具有一个查询参数的函数中来减少代码 当我从 router get 函数中的 with 调用该函数时 它返回未定义 任何帮助将非常感激 f
  • 同位素 Jquery 插件布局问题

    我正在尝试在此站点上设置同位素 它需要处理布局 并且我需要能够将项目附加到容器中 问题是它似乎没有正确初始化图像 这是我初始化它的方法 document ready function var container container cont
  • 如何在此彩票功能中显示所有猜中的号码?

    我用 JS 创建了一些简单的彩票功能 一切正常 我面临的唯一问题是如何显示所有已猜到的数字 我有 6 个独立的空间 其中必须提供数字 我的目标是显示随机空间中的滚动数字 它必须仅在 6 个空间之一中提供 这对我有用 但只显示 1 个数字 我
  • 音频端播放新文件

    我有一个webapp https radio repjesus com当您使用 ajax jquery 单击链接时加载并播放音轨 一切正常 但当曲目结束时 曲目将设置为循环 并且这种情况可以永远持续下去 我希望播放器从数据库中自动加载随机曲
  • JS 中的触摸板滚动检测,无库

    我正在制作自己的小型 Javascript 库 可以轻松地将您网站 和我的网站 的默认滚动条替换为自定义滚动条 其中一部分意味着为 BODY 元素提供 overflow hidden 样式来隐藏正常的滚动条 但是 这会阻止除代码中完成的滚动
  • JS 是否支持使用键函数而不是比较器进行排序?

    JavaScript 的array sort https developer mozilla org en US docs Web JavaScript Reference Global Objects Array sort Syntax方
  • Chrome DevTools 脚本黑盒不起作用

    我正在尝试使用 chrome devtools 的新功能 黑盒脚本 这篇 Chrome Devtools 文章列出了脚本黑盒功能 https developer chrome com devtools docs blackboxing wh
  • jQuery:在方法上取消绑定 jQuery 2.0

    在 jQuery 1 9 中live 已被弃用 因此新方法变为 document on mouseover blahblahfunc 我无法解除 blahblahfunc 的绑定 通过 unbind mouseover mouseout c
  • Ember 未在生产环境中加载某些图像

    我有一个 Ember cli 1 13 应用程序 它在公共目录中存储了很多图像 现在 它将正确加载除特定组件中的图像之外的所有图像 该组件的调用方式如下 list item url list url name List Name price
  • Angular 8 - 删除 ng-component 标签 - 表行模板

    我有一个灵活的表格组件 有两种模式 普通表 有效 自定义行模板 这不是因为角度添加
  • JavaScript 排序列表

    Javascript 或 jQuery 中有排序列表吗 我有一个巨大的列表 随着时间的推移 插入操作很少 每次添加单个项目时 我无法为整个列表调用 object sort 我需要插入 o log n 不 没有 你拥有的只是Array sor
  • 在画布中的鼠标位置放大/缩小

    我正在尝试使用 p5 js 实现缩放功能 当前缩放级别以及 x 和 y 位置存储在controls view目的 默认位置或 0 0 位置位于左上角 问题是调整放大 缩小时的 x 和 y 位置值 以便无论视图的当前位置是什么 它都会停留在缩
  • 脚本和链接标签的简写 http:// 为 // ?有人以前看过/用过这个吗?

    问题如下 如果您使用 addthis 共享按钮 查看任何网站 一旦您浮动在 addthis 按钮上 并且加载了所有必需的资源 请使用 firebug 或 chrome 检查器查看文档的正文 不是源代码 而是屏幕上的实际文档 对象检查器 你会
  • 监听鼠标事件……除了 div 的溢出:滚动滚动条?

    关于如何监听 mousedown 的任何建议 document exceptdiv 的溢出 滚动滚动条 我不确定滚动条是什么元素is为了参考它 您可以使用以下命令自行检查目标 document on mousedown function e
  • Dojo 是否可以与其他 JS 框架结合?

    我们使用 Dojo 1 9 3 作为构建单页面应用程序的 JS 框架 然而 我们在 Dojo 的怪癖上花费了太多时间 因此即使是简单的任务也需要很长时间才能实现 由于缺乏适当的文档 我们经常不得不求助于阅读源代码 然后实施解决方法 我觉得如
  • Google Universal Analytics - 命令被忽略

    我正在使用 Google Universal Analytics 来跟踪页面浏览量 当我导航到具有 Google Analytics 网站实时功能的页面时 我可以看到 因此我的代码一定可以正常工作 然而 Chrome 一直在控制台中显示 I

随机推荐

  • npm安装composer-rest-server等出现错误node-pre-gyp install --fallback-to-build --library

    npm安装composer rest server等出现错误node pre gyp install fallback to build library grpc 1 10 1 install usr local lib node modu
  • 20大中国式弱点营销

    什么是弱点营销 宇宙的精灵 万物的灵长 说的是人类 但现实中 人性的弱点也不少 贪婪 恐惧 嫉妒 懒惰 好色 贪慕虚荣 难抵诱惑 害怕孤独 热爱免费 重视等级 迷信专家 崇拜名人 喜随波逐流 关于人性的一切弱点 正在被消费社会利用和营销 一
  • vector中find 的用法

    vector没有自带的find函数 需要用普通的find函数 使用如下 vector
  • CH2-Java编程基础(7个案例实现)

    案例2 1 库房出入货物程序设计 案例介绍 任务描述 现要对华为和小米两种手机产品进行入库 本案例要求编写一个模拟商品入库的程序 可以在控制台输入入库商品的数量 最后打印出仓库中所有商品详细信息以及所有商品的总库存数和库存商品总金额 商品信
  • 斗地主发牌算法JAVA

    首先定义一个卡牌类 public class Card private String numb private String color private int index public Card public Card String nu
  • 【vue】使用了 keep-alive 的 include,但是切换 router-view,页面还是会刷新

  • 二分图最大匹配与最大独立集

    一 概念部分 1 什么是二分图 通俗的说法 就是可以把图分成两部分 每一部分任意两点之间没有关系 同一部落 两部分之间点可能存在多种关系 2 怎么判断二分图 1 理论判定 如果某个图为二分图 那么它至少有两个顶点 且其所有回路的长度均为偶数
  • Ansible-基本概述

    为什么要自动化运维 纯手动软件安装部署方式 我们以 10 台机器部署 Nginx 为例 部署步骤如下 1 通过 ssh 登录一台机器 2 yum install y nginx 或者 获取安装包自行编译安装 3 配置 Nginx 4 启动
  • 微信小程序知识点GET

    1 app json中的pages用来设置小程序包含哪些页面以及页面的路径 window用来设置默认页面的窗口表现形式 tabBar用来设置小程序底部tab的表现 2 app js中的App 函数用来注册一个小程序 接受的对象参数用来指定小
  • mstsc远程报:这可能是由于CredSSP 加密Oracle修正的两种完美解决方法

    win10很完美 用的也很舒服 当然人无完人 也总有不尽如人意的时候 比如说我们经常用的远程mstsc 就出现了一个坑 既然出现坑了 我们就得把坑解决掉吧 下面就记录一下这个坑的解决方法 本文地址 https www cnblogs com
  • vue.js --父子组件通信

    目录 父子组件通信 父组件向子组件通信 子组件通过props接收 子组件向父组件通信 emit自定义事件 v model改造 emit传递父组件数据 emit传递单个父组件数据 emit传递多个父组件数据 总结 父子组件通信 父子组件通信
  • 线程的状态

    线程共有六种状态 初始状态 实现Runnable接口和继承Thread可以得到一个线程类 new一个实例出来 线程就进入了初始状态 2 1 就绪状态 就绪状态只是说你资格运行 调度程序没有挑选到你 你就永远是就绪状态 调用线程的start
  • mybatis泛型DAO接口

    本文将记录mybatis整合spring的泛型DAO接口 通过BasicDAOImpl实现类提供CRUD功能 其他DAO只需要继承和扩展BasicDAOImpl BasicDao接口定义 public interface BasicDAO
  • win10系统下将DMG转为ISO镜像——(虚拟机黑苹果操作)

    1 下载镜像 http www msdn3 com 6 20190826 这个网站超级好用 2 下载后为dmg文件 如果可以直接下载iso文件的可以跳过转换步骤 3 dmg文件转iso文件 1 下载DMG2IMG 32位 64位版Windo
  • loadrunner接口压测脚本编写模板

    接口报文 Action web reg save param return code LB res code RB Search Body Ord 1 LAST lr start transaction httpRequest web ad
  • jdbc连接数据库mysql的问题_JDBC连接Mysql数据库出现的问题汇总

    MySQL 前言 最近安装了一个 mysql 8 0 版本的数据库 在程序中连接的时候可谓是状况不断 之前也会遇到一些问题 这里就对使用 JDBC 连接mysql 会出现的问题做一个汇总 在此之前说明一下环境 开发工具 IDEA mysql
  • Selenium自动化测试 —— 通过cookie绕过验证码的操作

    验证码的处理 对于web应用 很多地方比如登录 发帖都需要输入验证码 类型也多种多样 登录 核心操作过程中 系统会产生随机的验证码图片 进行验证才能进行后续操作 解决验证码的方法如下 1 开发做个万能验证码 推荐 2 测试环境关闭验证码功能
  • Easy Code插件使用(附Spring Data JPA生成模板)

    文章目录 一 概述 二 安装 1 安装插件 2 连接数据库 三 生成代码 四 配置EasyCode 五 Spring Data JPA模板 1 controller类 2 service接口 3 serviceImpl实现类 4 dao接口
  • Python之体育竞技分析

    来源 Python语言程序设计 嵩天 一 问题描述 需求 高手过招 胜负只在毫厘 如何科学地分析体育竞技比赛 输入 球员的水平 输出 预测比赛成绩 二 具体分析 三 代码实现 from random import random 生成随机数
  • uniapp picker实现:市区镇村4级懒加载

    使用这种方法的原因 市区镇村4级数据太大 后台接口响应时间太长 方法实现 样式 view