当前位置: 首页 > news >正文

uniapp 省、市、区、乡镇 数据层级选择插件 Ba-DataPicker

Ba-DataPicker 是一款uniapp数据层级选择弹窗插件。支持省市区乡四级;支持自定义数据。

  • 支持省、市、区、乡镇四级
  • 支持自定义数据
  • 支持字母检索

截图展示

在这里插入图片描述


支持定制、本地包、源码等,有建议和需要,请点击文章结尾“Uniapp插件开发”联系我(如下图)
在这里插入图片描述
也可关注博客,实时更新最新插件

uniapp 常用原生插件大全


使用方法

script 中引入组件

	const dataPicker = uni.requireNativePlugin('Ba-DataPicker')
默认数据使用

script 中调用

	export default {data() {return {msgList: []}},methods: {onShowDataPicker() { //显示数据选择弹窗dataPicker.show({},(res) => {this.showResult(JSON.stringify(res))if (res.action) {if (res.action == "onChecked") { //监听事件:点击选择} else if (res.action == "onClickOk") {//监听事件:点击确认//res.checkeds中是选中的数据} else if (res.action == "onClickCancel") {//监听事件:点击取消}}});},showResult(msg) {console.log(msg)this.msgList.unshift(msg)uni.showToast({title: msg,icon: "none",duration: 3000})}}}
自定义数据使用

script 中调用

	export default {data() {return {options: {//数据参数isDefaultData:false,//不使用默认数据list: [ //多级数据[{"name": "浙江省"}, {"name": "浙江省2"}], //第一级数据[{"name": "宁波市"}, {"name": "宁波市2"}], //第二级数据[{"name": "象山县"}, {"name": "象山县2"}], //第三级数据[{"name": "石浦镇"}, {"name": "石浦镇2"}] //第四级数据],checkedList: [0, 0, 0, 0]//各级已选中的下标},tabIndex: 0,//多层面板显示位置msgList: []}},methods: {onShowDataPicker() { //显示数据选择弹窗dataPicker.show(this.options,(res) => {this.showResult(JSON.stringify(res))if (res.action) {if (res.action == "onChecked") { //监听事件:点击选择//如下是根据需求调好的处理逻辑,也可根据情况自行更改try {let tabIndex = res.tabIndex;//操作的层级this.options.checkedList[tabIndex] = res.checkedPosition;//某一层级的选中(下标)if (tabIndex < this.options.list.length - 1) {//如果不是最后层级,处理下级数据,并自动跳转下一级for (var i = tabIndex + 1; i < this.options.list.length; i++) {//下级数据默认选择第一个this.options.checkedList[i] = 0;//模拟下级数据更新,可在这里调用接口(这里模拟的是添加一个)//设置i层级新的数据:this.options.list[i]=新的数据this.options.list[i].unshift({name: "新数据"})}}//自动显示下一级if (tabIndex < this.options.list.length - 1)this.tabIndex = tabIndex + 1//调用刷新数据this.onUpdateData(this.options)} catch (e) {this.showResult("error " + e.message)}} else if (res.action == "onClickOk") { //监听事件:点击确认//res.checkeds中是选中的数据} else if (res.action == "onClickCancel") { //监听事件:点击取消}}});},onUpdateData(options) {//更新数据options.tabIndex = this.tabIndex;dataPicker.update(options,(res) => {//this.showResult(JSON.stringify(res))});},showResult(msg) {console.log(msg)this.msgList.unshift(msg)uni.showToast({title: msg,icon: "none",duration: 3000})}}}

方法清单

名称说明
show加载并显示弹窗
update更新数据

http://www.mrgr.cn/news/47448.html

相关文章:

  • 2024AAAI SCTNet论文阅读笔记
  • 力扣-数据结构-19【算法学习day.90】
  • SQL-leetcode-584. 寻找用户推荐人
  • 51单片机(一) keil4工程与小灯实验
  • Microsoft 已经弃用了 <experimental/filesystem> 头文件
  • 小程序textarea组件键盘弹起会遮挡住输入框
  • 【工具使用】使用Docsify搭建个人文档网站
  • 【电路笔记】-求和运算放大器
  • CSS中Float(浮动)详解
  • Guava 用法指南
  • Java控制流 小案例
  • IFAdapter:用于基础文本到图像生成的实例特征控制
  • 用IntStream生成0到n的流,并找出不在numSet中的数字列表
  • 尚硅谷rabbitmq 2024 第50节 集群负载均衡 核心功能 答疑
  • 猫头虎分享已解决Bug || AssertionError: Torch not compiled with CUDA enabled 解决方案
  • 30. 串联所有单词的子串
  • 考研代码题:10.10 汉诺塔 爬楼梯 取球 猴子吃桃
  • SpringMVC源码-@ControllerAdvice和 @InitBinder注解源码讲解
  • 深入探索网易企业邮箱API的应用与优势
  • Linux的Redis安装部署
  • 前端_002_CSS扫盲
  • No.15 笔记 | CSRF 跨站请求伪造
  • 重塑排班新体验,搭贝员工排班系统 —— 让管理更高效,工作更顺心!
  • 搜维尔科技:机械臂与Haption集成增强远程操作安全性和可操作性
  • 【JVM】一文详解类加载器
  • C++——list