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)
}

目录
相关文章
|
2月前
|
C# Android开发 开发者
Uno Platform 高级定制秘籍:深度解析与实践样式和模板应用,助你打造统一且高效的跨平台UI设计
【9月更文挑战第7天】Uno Platform 是一个强大的框架,支持使用 C# 和 XAML 创建跨平台 UI 应用,覆盖 Windows、iOS、Android、macOS 和 WebAssembly。本文介绍 Uno Platform 中样式和模板的应用,助力开发者提升界面一致性与开发效率。样式定义控件外观,如颜色和字体;模板则详细定制控件布局。通过 XAML 定义样式和模板,并可在资源字典中全局应用或嵌套扩展。合理利用样式和模板能简化代码、保持设计一致性和提高维护性,帮助开发者构建美观高效的跨平台应用。
53 1
|
4月前
|
域名解析 安全 物联网
阿里云EMAS HTTPDNS 扩展全球服务节点:提升解析安全性与网络覆盖
阿里云EMAS HTTPDNS新增国内西南、华南及国际欧洲、美东服务节点,提升了全球覆盖能力与性能。作为高效域名解析服务,EMAS HTTPDNS针对互联网、汽车、物流、IOT等行业提供支持,解决了传统解析易遭劫持等问题。新增节点优化了就近调度功能,显著缩短响应时间并增强了服务稳定性和连续性,尤其为中国企业的海外业务提供了强有力的支持。此次扩展展现了阿里云对服务质量的持续追求和全球市场布局的战略思考。
|
3月前
|
网络协议 微服务
【Azure 微服务】基于已经存在的虚拟网络(VNET)及子网创建新的Service Fabric并且为所有节点配置自定义DNS服务
【Azure 微服务】基于已经存在的虚拟网络(VNET)及子网创建新的Service Fabric并且为所有节点配置自定义DNS服务
|
4月前
|
编解码 前端开发 图形学
【技术深度解析】多平台适配下的UI适配难题:U3D游戏UI错乱的终极解决方案
【7月更文第12天】随着移动设备市场的多元化,Unity游戏开发者面临的一大挑战是如何在不同分辨率和屏幕尺寸的设备上保持UI的一致性和美观性。游戏在高分辨率平板与低分辨率手机上呈现出的UI布局混乱、按钮错位等问题,严重影响玩家体验。本文旨在探讨Unity UI(UGUI)在多平台适配中的最佳实践,通过优化Canvas Scaler设置、灵活运用RectTransform和Anchor Points,以及高效利用设计工具,确保UI的完美适配。
594 1
|
4月前
Element UI【级联选择器】el-cascader 获取选中内容的 label 数据,鼠标悬浮显示超长内容
Element UI【级联选择器】el-cascader 获取选中内容的 label 数据,鼠标悬浮显示超长内容
640 3
|
4月前
Element UI【组件拓展】el-datetime-picker-before 禁止选择未来时间的日期时间选择器(精确到时分秒)
Element UI【组件拓展】el-datetime-picker-before 禁止选择未来时间的日期时间选择器(精确到时分秒)
150 1
|
4月前
Element UI 多选表格【翻页多选】全能版(含翻页多选数据反显、toggleRowSelection失效的原因解析和解决方案)
Element UI 多选表格【翻页多选】全能版(含翻页多选数据反显、toggleRowSelection失效的原因解析和解决方案)
303 0
|
4月前
Element UI 树形控件Tree 【详解】el-tree 展开指定节点,判断是否存在指定节点
Element UI 树形控件Tree 【详解】el-tree 展开指定节点,判断是否存在指定节点
773 0
|
4月前
|
JavaScript
js 解析和操作树 —— 获取树的深度、提取并统计树的所有的节点和叶子节点、添加节点、修改节点、删除节点
js 解析和操作树 —— 获取树的深度、提取并统计树的所有的节点和叶子节点、添加节点、修改节点、删除节点
120 0
|
4月前
Element UI 自定义/修改下拉弹窗的样式(如级联选择器的下拉弹窗样式)
Element UI 自定义/修改下拉弹窗的样式(如级联选择器的下拉弹窗样式)
447 0

推荐镜像

更多