使用Naive UI的级联选择器 Cascader进行省市区选择

序言:

在进行PC版的功能开发时,进行客户管理时老板要让客户便捷的选择自己的省市区等信息,而不是让他们一个个去填写,这时就需要使用级联选择器来进行省市区的选择。

注:element ui/plus的级联选择器也是可以的。

步骤:

  • 需要下载省市区的js文件,这个文件已经上传到主页可以自行下载,文件名称为ydui.citys.js。首先引入并声明并初始化一个变量yduiCtiys,其值来自外部的YDUI_CITYS对象,该对象预期包含所有省份及其下属城市和区县信息。:

    复制代码
    import * as ydui from '@/assets/js/ydui.citys';
    let yduiCtiys = YDUI_CITYS;
  • 1.声明一个响应式对象addressArr,用于存放最终处理好的地址选项数据,初始时options为空数组。

    2.声明并初始化了一个名为 addrs 的空数组,这个数组被用来存储处理后的地址数据,具体包括省份、城市、区县等信息。每一级(省份、城市、区县)都将以对象的形式被添加到这个数组中,并建立起父子关系。

    3.初始化和遍历省份、城市**、** 区县。整理并赋值给addressArr.options

    复制代码
    let addressArr = reactive({ options: [] });
    let addrs = [];
    yduiCtiys.forEach((province, pid) =>{
        let p = {};
        p.label = province.n;
        p.id = province.n
        // p.children = province.c;
        addrs.push(p)
    
        addrs[pid].children = [];
        province.c.forEach((city, cid) => {      
            let c = {};
            c.label = city.n;
            c.id = `${province.n} ${city.n}`
            addrs[pid].children.push(c)
    
            c.children = []
    
            city.a.forEach((area, aid) => {
                let a = {};
                a.label = area;
                a.id = `${province.n} ${city.n} ${area}`
                c.children.push(a)
            })
    
        })
    })
    addressArr.options = addrs
  • 使用naive UI的级联选择器 n-cascader 进行省市区的选择。具体api的详解请看官方文档:级联选择 Cascader。或看主页之前对n-select api的详细解释,相同api作用一样。

    复制代码
     <n-cascader
           v-model:value="area"
           clearable
           separator=" "
           placeholder="请选择区域"
           expand-trigger="click"
           :options="addressArr.options"
           label-field="label"
           value-field="id"
           children-field="children"
           size="small" >                       
      </n-cascader>
    
    
    <script>
     //area就是选择后页面展现的数据
     const area = ref('')
    </script>

附成果图:

**结语:**功能也是成功的完成了,使用此方法可以方便快捷的进行省市区的选择。

相关推荐
500佰5 小时前
技术包办模式给我带来的反思
前端
g***72705 小时前
spring-boot-starter和spring-boot-starter-web的关联
前端
用户41429296072395 小时前
解决「买不到、买得贵、买得慢」:反向海淘独立站的核心功能设计与案例复盘
前端·后端·架构
N***p3655 小时前
SpringBoot返回文件让前端下载的几种方式
前端·spring boot·后端
五号厂房5 小时前
网络请求库通用封装(GET/POST + 超时 + 传参)+fetch
前端
小雨青年5 小时前
智能交互新范式:拒绝“黑盒”,带你用 MateChat 与 DSL 构建“高可靠”的 NL2UI 引擎
前端·ai·华为云
anyup5 小时前
🔥牛逼!3分钟生成 5 套主题,还能一键切换暗黑模式!
前端·前端框架·uni-app
进击的明明5 小时前
深入讨论前端开发中的跨域问题🤔
前端
大怪v5 小时前
【创世界01】头脑热一把,我要带你纯前端手搓虚拟世界💪!
javascript·css·html
正在走向自律5 小时前
企业微信消息推送全链路实战:Java后端与Vue前端集成指南
前端·vue.js·企业微信·企业微信消息推送·官方企业微信