Element UI【详解】el-cascader 级联选择器 - 行政区划选择(可以选择任意一级),限定选择范围,获取并解析选中的节点

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: Element UI【详解】el-cascader 级联选择器 - 行政区划选择(可以选择任意一级),限定选择范围,获取并解析选中的节点

必要准备

1. 查询行政区划的接口

可以使用提供的API  行政区域查询-API文档-开发指南-Web服务 API | 地图API

获取高德开发的key 的方法,详见博客  地图开发 —— 获取地图开发的 key_朝阳39的博客-CSDN博客_地图开发平台的key

2. 在 vue.config.js 中配置接口代理

// 访问高德地图的API
'/gaodeMapAPI': {
    target: 'https://restapi.amap.com',
    changOrigin: true,
    ws: true,  // 是否启用websockets
    secure: true,
    pathRewrite: {
        '^/gaodeMapAPI': ''
    }
},

范例1 —— 级联选择行政区划(可以选择任意一级)

要点

1. 使用懒加载   lazy: true

2. lazyLoad 函数中无法直接获取到this,所有需在 data(){} 函数中,使用  let that = this

3. 最终选中的结果为一个数组,内容依次是省、市、区的行政区划代码

4. 通过在  props 中添加 checkStrictly: true 实现级联单选,从而可以选择任意一级

5. 从接口中获取到的结果,需要转换成级联选择器需要的数据格式,值存入value,可见的内容存入 label,当 leaf 赋值为true 时,得到最后一级。

( 范例中的接口必须指定 leaf  为true 的条件 item.level === "district" ,否则可以无限级联选择  )

( 另外,因范例中的接口返回的街道数据的行政区划代码是其上级的区/县的行政区划代码,所以不支持级联选择到街道)

<template>
    <div style="padding: 20px">
        <p>当前选中的行政区划编码为: {{regionCodeList}}</p>
        <el-cascader  v-model="regionCodeList" :props="props"></el-cascader>
    </div>
</template>
<script>
    export default {
        data() {
            let that = this
            return {
                regionCodeList: [],
                props: {
                    // 单选
                    checkStrictly: true,
                    // 懒加载
                    lazy: true,
                    lazyLoad(node, resolve) {
                        that.$http.get("/gaodeMapAPI/v3/config/district", {
                            params: {
                                keywords: node.value,
                                subdistrict: '1',
                                key: 'f7c1ee410753e832aad78bc5cf135351'
                            }
                        })
                            .then(res => {
                                let nodes = res.data.districts[0].districts.map(item => {
                                    return {
                                        value: item.adcode,
                                        label: item.name,
                                        leaf: item.level === "district"
                                    }
                                })
                                resolve(nodes)
                            })
                    }
                }
            }
        },
    }
</script>
<style scoped>
</style>

范例2 —— 限制行政区划的显示和选择范围

需求

1. 默认选中深圳市

2. 不能选择省,但可以选择深圳市,或者深圳市内的区

3. 不显示广东省和深圳市之外的省和市

要点

1. v-model 绑定默认值,便能实现默认选中

2. 在添加 node 时,添加  disabled: true 便可使该节点不可选

3. 在添加 node 时,通过if 判断,过滤掉不显示的省和市

<template>
    <div style="padding: 20px">
        <p>当前选中的行政区划编码为: {{regionCodeList}}</p>
        <el-cascader v-model="regionCodeList" :props="props"></el-cascader>
    </div>
</template>
<script>
    export default {
        data() {
            let that = this
            return {
                regionCodeList: ["440000", "440300"],
                props: {
                    // 单选
                    checkStrictly: true,
                    // 懒加载
                    lazy: true,
                    lazyLoad(node, resolve) {
                        that.$http.get("/gaodeMapAPI/v3/config/district", {
                            params: {
                                keywords: node.value,
                                subdistrict: '1',
                                key: 'f7c1ee410753e832aad78bc5cf135351'
                            }
                        })
                            .then(res => {
                                let districtsList = res.data.districts[0].districts
                                let nodes = []
                                districtsList.forEach(item => {
                                    if ((item.level === "province") && (item.adcode === "440000")) {
                                        nodes.push(
                                            {
                                                value: item.adcode,
                                                label: item.name,
                                                disabled: true
                                            }
                                        )
                                    } else if ((item.level === "city") && (item.adcode === "440300")) {
                                        nodes.push(
                                            {
                                                value: item.adcode,
                                                label: item.name,
                                            }
                                        )
                                    } else if (item.level === "district") {
                                        nodes.push(
                                            {
                                                value: item.adcode,
                                                label: item.name,
                                                leaf: item.level === "district"
                                            }
                                        )
                                    }
                                })
                                resolve(nodes)
                            })
                    }
                }
            }
        },
    }
</script>
<style scoped>
</style>

范例3 —— 获取选中行政区划的名称

要点

1.  绑定 change 事件,触发获取行政区划信息的代码

<el-cascader ref="chooseRegionDom" @change="getRegionInfo"  v-model="regionCodeList" :props="props"></el-cascader>

3.  解析选中的节点(节点数组中下标为 0  的节点为选中的节点)

getRegionInfo(){
    // 获取选中的nodeList
    let nodeList = this.$refs.chooseRegionDom.getCheckedNodes()
    // 解析node的label 和 value
    this.$set(this.regionInfo,'regionName',nodeList[0].label)
    this.$set(this.regionInfo,'regionCode',nodeList[0].value)
}

目录
相关文章
|
10天前
|
C# Android开发 开发者
Uno Platform 高级定制秘籍:深度解析与实践样式和模板应用,助你打造统一且高效的跨平台UI设计
【9月更文挑战第7天】Uno Platform 是一个强大的框架,支持使用 C# 和 XAML 创建跨平台 UI 应用,覆盖 Windows、iOS、Android、macOS 和 WebAssembly。本文介绍 Uno Platform 中样式和模板的应用,助力开发者提升界面一致性与开发效率。样式定义控件外观,如颜色和字体;模板则详细定制控件布局。通过 XAML 定义样式和模板,并可在资源字典中全局应用或嵌套扩展。合理利用样式和模板能简化代码、保持设计一致性和提高维护性,帮助开发者构建美观高效的跨平台应用。
23 1
|
1月前
|
JavaScript
基于Element UI或Element Plus实现具有倒计时的Message消息提示
本文介绍了如何在Element UI或Element Plus框架中实现具有倒计时功能的消息提示组件,支持多次点击生成多个独立倒计时的消息提示,并提供了详细的实现代码和使用示例。
153 1
基于Element UI或Element Plus实现具有倒计时的Message消息提示
|
1月前
|
JavaScript UED
基于Vue2.0仿Element UI的el-tooltip实现一个气泡框组件,支持多数据类型的显示和内容为空时不显示气泡框
该文章介绍了如何基于Vue2.0仿照Element UI的el-tooltip组件实现一个自定义的气泡框组件,该组件能够根据内容是否为空智能显示或隐藏,支持多种数据类型的显示。
64 0
基于Vue2.0仿Element UI的el-tooltip实现一个气泡框组件,支持多数据类型的显示和内容为空时不显示气泡框
|
16天前
|
开发者 C# Android开发
明白吗?Xamarin与Native的终极对决:究竟哪种开发方式更适合您的项目需求,让我们一探究竟!
【8月更文挑战第31天】随着移动应用开发的普及,开发者面临多种技术选择。本文对比了跨平台解决方案Xamarin与原生开发方式的优势与劣势。Xamarin使用C#进行跨平台开发,代码复用率高,可大幅降低开发成本;但因基于抽象层,可能影响性能。原生开发则充分利用平台特性,提供最佳用户体验,但需维护多套代码库,增加工作量。开发者应根据项目需求、团队技能和预算综合考量,选择最适合的开发方式。
58 0
|
18天前
|
JavaScript 前端开发 开发者
决战前端之巅!Element UI与Vuetify谁才是Vue.js组件界的霸主?一场关于颜值与实力的较量!
【8月更文挑战第30天】本文对比了两款热门的Vue.js组件库——Element UI与Vuetify。Element UI由饿了么团队打造,提供多种高质量UI组件,设计简洁大方。Vuetify基于Material Design规范,支持Vue.js 2.0及3.0版本,具备前瞻性。两者均涵盖表单、导航、数据展示等组件,Element UI配置选项丰富,而Vuetify则提供了更深层的样式定制功能。开发者可根据项目需求及个人偏好选择合适的组件库。
61 0
|
18天前
|
JavaScript 开发者 UED
Vue.js组件库大对决:Element UI与Vuetify,开发者的罗密欧与朱丽叶!
【8月更文挑战第30天】Element UI和Vuetify是Vue.js开发中的热门组件库,前者简洁高效,后者遵循Material Design,国际化程度高。两者均提供丰富的组件支持,但Vuetify组件更多样,设计更灵活;Element UI在性能和中文支持上更优。文档方面,Element UI更直观易懂,而Vuetify配置灵活但学习成本稍高。选择时需综合考虑项目需求、团队背景及设计风格,以达到最佳开发效果。
56 0
|
24天前
|
网络协议 微服务
【Azure 微服务】基于已经存在的虚拟网络(VNET)及子网创建新的Service Fabric并且为所有节点配置自定义DNS服务
【Azure 微服务】基于已经存在的虚拟网络(VNET)及子网创建新的Service Fabric并且为所有节点配置自定义DNS服务
|
18天前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件
|
1月前
|
存储 NoSQL Redis
redis 6源码解析之 object
redis 6源码解析之 object
53 6
|
3天前
|
存储 缓存 Java
什么是线程池?从底层源码入手,深度解析线程池的工作原理
本文从底层源码入手,深度解析ThreadPoolExecutor底层源码,包括其核心字段、内部类和重要方法,另外对Executors工具类下的四种自带线程池源码进行解释。 阅读本文后,可以对线程池的工作原理、七大参数、生命周期、拒绝策略等内容拥有更深入的认识。
什么是线程池?从底层源码入手,深度解析线程池的工作原理

推荐镜像

更多