封装一个省市区的筛选组件

筛选功能:只能单选(如需多选需要添加show-checkbox多选框属性,选中省传递省的ID,选中市传递省、市的ID, 选中区传递省市区的ID

 

父组件:

 <el-form-item><div style="width: 240px;padding-left: 20px;border-radius: 4px;color: #c0bdbd;border: 1px solid #d4cece;height: 32px;line-height: 32px;"@click="OrderAreabtn">{{ fullAddress }}</div><OrderArea v-if="OrderAreaVisible" ref="addOrUpdate" @refreshDataList="getDataList"> </OrderArea>
</el-form-item>
import OrderArea from "./orderarea.vue";
components: { OrderArea },
OrderAreaVisible: false,
fullAddress: "请选择地区",
getDataList(row) {console.log("子组件传递回来的数据", row);
},
OrderAreabtn() {this.OrderAreaVisible = true;this.$nextTick(() => {this.$refs.addOrUpdate.init();});
},

子组件:

<template><div class="shop-transcity-add-or-update"><el-dialog:modal="false"title="请选择地区":close-on-click-modal="false":visible.sync="visible"><el-form:model="dataForm"ref="dataForm"@keyup.enter.native="dataFormSubmit()"label-width="180px"style="height: 400px"><el-scrollbar style="height: 100%"><el-form-item size="mini"><el-tree:data="menuList"node-key="areaId"ref="menuListTree":props="menuListTreeProps":show-checkbox="false":check-strictly="true"@node-click="handleNodeClick"></el-tree></el-form-item></el-scrollbar></el-form><span slot="footer" class="dialog-footer"><el-button @click="visible = false">取消</el-button><el-button type="primary" @click="dataFormSubmit()">确定</el-button></span></el-dialog></div>
</template><script>
let treeDataTranslate = (data, id = "id", pid = "parentId") => {var res = [];var temp = {};for (var i = 0; i < data.length; i++) {temp[data[i][id]] = data[i];}for (var k = 0; k < data.length; k++) {if (temp[data[k][pid]] && data[k][id] !== data[k][pid]) {if (!temp[data[k][pid]]["children"]) {temp[data[k][pid]]["children"] = [];}if (!temp[data[k][pid]]["_level"]) {temp[data[k][pid]]["_level"] = 1;}data[k]["_level"] = temp[data[k][pid]]._level + 1;temp[data[k][pid]]["children"].push(data[k]);} else {res.push(data[k]);}}return res;
};
export default {data() {return {visible: false,menuList: [],menuListTreeProps: {children: "children",label: "areaName",id: "areaId",},dataForm: {province: null,area: null,city: null,fullAddress: "",},};},methods: {init() {this.visible = true;this.request({url: "/xxx/area/list",method: "get",params: {pageNum: 1,pageSize: 1000000,},}).then((res) => {//treeDataTranslate()处理数据为树结构,如果你的数据已经是树结构则可直接赋值this.menuList = treeDataTranslate(res.rows, "areaId", "parentId");});},getAreaNameById(areaId) {return this.findAreaName(this.menuList, areaId);},findAreaName(nodes, areaId) {for (let node of nodes) {if (node.areaId === areaId) {return node.areaName;}if (node.children && node.children.length > 0) {const foundName = this.findAreaName(node.children, areaId);if (foundName) {return foundName;}}}return null;},// 获取祖父节点IDgetGrandparentId(node) {const parentNode = this.findParentNode(this.menuList, node.areaId);if (parentNode) {const grandparentNode = this.findParentNode(this.menuList,parentNode.areaId);return grandparentNode ? grandparentNode.areaId : null;}return null;},findParentNode(nodes, areaId) {for (let node of nodes) {if (node.children && node.children.length > 0) {for (let child of node.children) {if (child.areaId === areaId) {return node;}}const foundNode = this.findParentNode(node.children, areaId);if (foundNode) {return foundNode;}}}return null;},handleNodeClick(node) {//选中省if (node.level == 1) {this.dataForm.province = node.areaId;this.dataForm.city = null;this.dataForm.area = null;this.dataForm.fullAddress = node.areaName;}//选中市if (node.level == 2) {this.dataForm.province = node.parentId;this.dataForm.city = node.areaId;this.dataForm.area = null;}//选中区if (node.level == 3) {const grandparentId = this.getGrandparentId(node);if (grandparentId) {this.dataForm.province = grandparentId;} else {console.log("没有找到祖父节点");}if (node.children && node.children.length > 0) {this.dataForm.city = node.areaId;this.dataForm.area = null;} else {this.dataForm.city = node.parentId;this.dataForm.area = node.areaId;}}},// 表单提交dataFormSubmit() {console.log("选中的省市区ID:",this.dataForm.province,this.dataForm.city,this.dataForm.area);const provinceName = this.getAreaNameById(this.dataForm.province);const cityName = this.getAreaNameById(this.dataForm.city);const districtName = this.getAreaNameById(this.dataForm.area);this.dataForm.fullAddress = provinceName; //选中省if (cityName) {//选中市this.dataForm.fullAddress = `${provinceName} ${cityName}`;}if (districtName) {//选中区this.dataForm.fullAddress = `${provinceName} ${cityName} ${districtName}`;}console.log("选中的省市区名称:", this.dataForm.fullAddress);this.$emit("refreshDataList", this.dataForm);this.visible = false;},},
};
</script><style lang="scss">
.shop-transcity-add-or-update {.el-scrollbar__wrap {overflow-x: hidden;}
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/60789.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大模型在蓝鲸运维体系应用——蓝鲸运维开发智能助手

本文来自腾讯蓝鲸智云社区用户: CanWay 背景 1、运维转型背景 蓝鲸平台从诞生之初&#xff0c;就一直在不遗余力地推动运维转型&#xff0c;让运维团队可以通过一体化PaaS平台&#xff0c;快速编写脚本&#xff0c;编排流程&#xff0c;开发运维工具&#xff0c;从被动地提供…

独家|京东上线自营秒送,拿出二十年底牌和美团竞争

京东自营秒送开启招商&#xff0c;即时零售也要全托管&#xff1f; 作者|王迟 编辑|杨舟 据「市象」独家获悉&#xff0c;京东将在近期上线自营秒送业务&#xff0c;目前已经开始邀约制招商。「市象」获得的招商资料显示&#xff0c;和5月刚升级上线的京东秒送以POP模式不同&…

GEE 数据集——美国gNATSGO(网格化国家土壤调查地理数据库)完整覆盖了美国所有地区和岛屿领土的最佳可用土壤信息

目录 简介 代码 引用 网址推荐 知识星球 机器学习 gNATSGO&#xff08;网格化国家土壤调查地理数据库&#xff09; 简介 gNATSGO&#xff08;网格化国家土壤调查地理数据库&#xff09;数据库是一个综合数据库&#xff0c;完整覆盖了美国所有地区和岛屿领土的最佳可用土…

JavaSE常用API-日期(计算两个日期时间差-高考倒计时)

计算两个日期时间差&#xff08;高考倒计时&#xff09; JDK8之前日期、时间 Date SimpleDateFormat Calender JDK8开始日期、时间 LocalDate/LocalTime/LocalDateTime ZoneId/ZoneDateTIme Instant-时间毫秒值 DateTimeFormatter Duration/Period

15分钟学 Go 第 53 天 :社区资源与学习材料

第53天&#xff1a;社区资源与学习材料 目标 了解Go语言官方资源掌握社区重要学习平台学会利用开源项目学习构建个人知识体系 一、Go语言官方资源汇总 资源类型网址说明Go官网golang.org官方文档、下载、教程Go Blogblog.golang.org技术博客、最新特性介绍Go Playgroundpla…

删库跑路,启动!

起因&#xff1a;这是一个悲伤的故事&#xff0c;在抓logcat时 device待机自动回根目录了&#xff0c;而题主对当前路径的印象还停留在文件夹下&#xff0c;不小心在根目录执行了rm -rf * … 所以&#xff0c;这是个悲伤的故事&#xff0c;东西全没了…device也黑屏了&#xff…

如何优化Kafka消费者的性能

要优化 Kafka 消费者性能&#xff0c;你可以考虑以下策略&#xff1a; 并行消费&#xff1a;通过增加消费者组中的消费者数量来并行处理更多的消息&#xff0c;从而提升消费速度。 批量消费&#xff1a;配置 fetch.min.bytes 和 fetch.max.wait.ms 参数来控制批量消费的大小和…

开始使用 Elastic AI Assistant 进行可观察性和 Microsoft Azure OpenAI

作者&#xff1a;Jonathan Simon 按照此分步过程开始使用 Elastic AI Assistant for Observability 和 Microsoft Azure OpenAI。 最近&#xff0c;Elastic 宣布&#xff0c;AI Assistant for Observability 现已面向所有 Elastic 用户开放。AI Assistant 为 Elastic Observabi…

vue2项目启用tailwindcss - 开启class=“w-[190px] mr-[20px]“ - 修复tailwindcss无效的问题

效果图 步骤 停止编译"npm run dev"安装依赖 npm install -D tailwindcssnpm:tailwindcss/postcss7-compat postcss^7 autoprefixer^9 创建文件/src/assets/tailwindcss.css&#xff0c;写入内容&#xff1a; tailwind base; tailwind components; tailwind utiliti…

深度学习——AE、VAE

&#x1f33a;历史文章列表&#x1f33a; 机器学习——损失函数、代价函数、KL散度机器学习——特征工程、正则化、强化学习机器学习——常见算法汇总机器学习——感知机、MLP、SVM机器学习——KNN机器学习——贝叶斯机器学习——决策树机器学习——随机森林、Bagging、Boostin…

【数字图像处理+MATLAB】基于 Sobel 算子计算图像梯度并进行边缘增强:使用 imgradientxy 函数

引言 在图像处理中&#xff0c;边缘通常是图像中像素强度变化最大的地方&#xff0c;这种变化可以通过计算图像的梯度来量化。梯度是一个向量&#xff0c;它的方向指向像素强度增加最快的方向&#xff0c;它的大小&#xff08;或者说幅度&#xff09;表示像素强度增加的速度。…

建设展示型网站企业渠道用户递达

展示型网站的主要作用便是作为企业线上门户平台、信息承载形式、拓客咨询窗口、服务/产品宣传订购、其它内容/个人形式呈现等&#xff0c;网站发展多年&#xff0c;现在依然是企业线上发展的主要工具之一且有建设的必要性。 谈及整体价格&#xff0c;自制、定制开发、SAAS系统…

无桥Boost-PFC 双闭环控制MATLAB仿真

一、无桥Boost-PFC原理概述 无桥 Boost-PFC&#xff08;Power Factor Correction&#xff0c;功率因数校正&#xff09;的工作原理是通过特定的电路结构和控制策略&#xff0c;对输入电流进行校正&#xff0c;使其与输入电压同相位&#xff0c;从而提高电路的功率因数&#xf…

java访问华为网管软件iMaster NCE的北向接口时传递参数问题

上一篇文章介绍了利用《java访问华为网管软件iMaster NCE的北向接口》的一般性步骤&#xff0c;这里详细介绍其中一个读取性能数据的示例。原因是读取华为网管软件北向接口&#xff0c;完全找不到可供参考的例子。如果不需要传递什么参数&#xff0c;就能获取到结果&#xff0c…

深度学习之pytorch常见的学习率绘制

文章目录 0. Scope1. StepLR2. MultiStepLR3. ExponentialLR4. CosineAnnealingLR5. ReduceLROnPlateau6. CyclicLR7. OneCycleLR小结参考文献 https://blog.csdn.net/coldasice342/article/details/143435848 0. Scope 在深度学习中&#xff0c;学习率&#xff08;Learning R…

【扩散——BFS】

题目 代码 #include <bits/stdc.h> using namespace std; const int t 2020, off 2020; #define x first #define y second typedef pair<int, int> PII; int dx[] {0, 0, 1, -1}, dy[] {-1, 1, 0, 0}; int dist[6080][6080]; // 0映射到2020&#xff0c;2020…

Linux软件包管理与Vim编辑器使用指南

目录 一、Linux软件包管理器yum 1.什么是软件包&#xff1f; 2.什么是软件包管理器&#xff1f; 3.查看软件包 4.安装软件 ​编辑 5.卸载软件 Linux开发工具&#xff1a; 二、Linux编辑器---vim 1.vim的基本概念 (1) 正常/普通模式&#xff08;Normal mode&#xff0…

R门 - rust第一课陈天 -内存知识学习笔记

内存 #mermaid-svg-1NFTUW33mcI2cBGB {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-1NFTUW33mcI2cBGB .error-icon{fill:#552222;}#mermaid-svg-1NFTUW33mcI2cBGB .error-text{fill:#552222;stroke:#552222;}#merm…

数据结构--数组

一.线性和非线性 线性&#xff1a;除首尾外只有一个唯一的前驱和后继。eg&#xff1a;数组&#xff0c;链表等。 非线性&#xff1a;不是线性的就是非线性。 二.数组是什么&#xff1f; 数组是一个固定长度的存储相同数据类型的数据结构&#xff0c;数组中的元素被存储在一…

Vue的基础使用

一、为什么要学习Vue 1.前端必备技能 2.岗位多&#xff0c;绝大互联网公司都在使用Vue 3.提高开发效率 4.高薪必备技能&#xff08;Vue2Vue3&#xff09; 二、什么是Vue 概念&#xff1a;Vue (读音 /vjuː/&#xff0c;类似于 view) 是一套 构建用户界面 的 渐进式 框架…