基于el-cascader 封装省市区层级选择器组件
2021/11/10 23:44:02
本文主要是介绍基于el-cascader 封装省市区层级选择器组件,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
基于elementUI省市区层级选择器组件
使用方法
依赖 1、elementui 2、获取数据的api接口位于 import{GetCity} from ".src/api/common" //引入组件 import CityArea from "@c/common/cityArea" //注册组件 components: { CityArea }, //使用组件 <CityArea :cityAreaValue.sync="form_data.area"></CityArea> /* form_data.area 是组件返回给父组件的数据,就是自己选择的数据的数据 组件是单向数据流,父组件向子组件传值,但是子组件不能修改父组件的值 .sync可以修改父组件的值,但只能是简单数据类型 */
传入参数: 无
传出参数:
form_data.area(自己定义接受数据的)
参数名 | 类型 | 备注 |
---|---|---|
form_data.area | String | 绑定到你自己定义的数据里 |
封装思路
<template> <div> <el-cascader v-model="city_area_value" :options="cascader_options" :props="cascader_props" @change="handleChange"> </el-cascader> </div> </template> <script> import{GetCity} from "@/api/common" export default { props: { cityAreaValue: { type: String, default: '', } }, components: {}, data() { return { city_area_value: '', // 省市区级联菜单数据 cascader_options: [], // 动态加载 省市区级联菜单数据 cascader_props: { lazy: true,//开启动态加载 lazyLoad (node, resolve) { // level 是级联菜单的层级,页面一旦加载就会自动调用该函数,为0级 let level = node.level; // 请求数据 const requesrData = {} const jsonType = { 0: { type: "province" }, 1: { type: "city", code: "province" }, 2: { type: "area", code: "city" } } // 设置输入参数 if(jsonType[level].code){ requesrData[`${jsonType[level].code}_code`] = node.value} requesrData.type = jsonType[level].type // console.log(node.level) // 省市区接口 GetCity(requesrData).then(response => { let data = response.data.data // 对返回数据进行处理 let dataType = jsonType[level].type.toUpperCase(); console.log(dataType) data.forEach(el => { el.value = el[`${dataType}_CODE`]; el.label = el[`${dataType}_NAME`]; if(level ===2){el.leaf = level => 2;} }); resolve(data) }) } } }; }, methods: { handleChange(value) { this.$emit('update:cityAreaValue',value.join()) // console.log(value.join()); } }, }; </script> <style scoped lang="scss"> </style>
1、数据获取
level表示层级的,进入页面是第0级即level=0, 是node节点是你点击的数数包含请求的数据和一些其他信息如level
通过props 配置 采用动态加载,页面加载进来会自动执行一次lazyLoad(level=0)函数,将请求接口放在lazyLoad中会自动请求一次数据,得到第一层(level)的数据,点击level=1的节点(就是数据渲染出来的选项)再执行一次lazyLoad函数请求数据。
关键点在于根据level 配置不同的请求数据,理不清楚就先用 if 实现功能,再简化,核心思路是 现将都有的属性抽出来
requesrData.type = jsonType[level].type //type是每个都有的属性,先将它抽出
//code属性第一个没有,所以先判断,判定不是第一个再将值赋给请求参数 if(jsonType[level].code){ requesrData[`${jsonType[level].code}_code`] = node.value}
2、请求的数据处理
默认 value 是值 ,label 是渲染的文本,返回的数据格式不对需要重新 遍历一次赋值
处理后的数据resolve(data) 返回给 cascader_options 让它渲染
这篇关于基于el-cascader 封装省市区层级选择器组件的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用
- 2025-01-03混合搜索:用LanceDB实现语义和关键词结合的搜索技术(应用于实际项目)
- 2025-01-03停止思考数据管道,开始构建数据平台:介绍Analytics Engineering Framework
- 2025-01-03如果 Azure-Samples/aks-store-demo 使用了 Score 会怎样?
- 2025-01-03Apache Flink概述:实时数据处理的利器
- 2025-01-01使用 SVN合并操作时,怎么解决冲突的情况?-icode9专业技术文章分享
- 2025-01-01告别Anaconda?试试这些替代品吧
- 2024-12-31自学记录鸿蒙API 13:实现人脸比对Core Vision Face Comparator
- 2024-12-31自学记录鸿蒙 API 13:骨骼点检测应用Core Vision Skeleton Detection