vue 封装一个四级联动组件

时间: 2023-10-29 21:52:55 浏览: 39
好的,我可以给您提供一个简单的四级联动组件的封装示例代码,您可以根据自己的需求进行修改和优化。 ```html <template> <div> <select v-model="selectedProvince" @change="onProvinceChange"> <option value="">请选择省份</option> <option v-for="province in provinces" :value="province">{{ province.name }}</option> </select> <select v-model="selectedCity" :disabled="!selectedProvince" @change="onCityChange"> <option value="">请选择城市</option> <option v-for="city in cities" :value="city">{{ city.name }}</option> </select> <select v-model="selectedDistrict" :disabled="!selectedCity" @change="onDistrictChange"> <option value="">请选择区县</option> <option v-for="district in districts" :value="district">{{ district.name }}</option> </select> <select v-model="selectedStreet" :disabled="!selectedDistrict"> <option value="">请选择街道</option> <option v-for="street in streets" :value="street">{{ street.name }}</option> </select> </div> </template> <script> export default { data() { return { provinces: [], // 所有的省份 cities: [], // 当前省份下的所有城市 districts: [], // 当前城市下的所有区县 streets: [], // 当前区县下的所有街道 selectedProvince: null, // 当前选中的省份 selectedCity: null, // 当前选中的城市 selectedDistrict: null, // 当前选中的区县 selectedStreet: null // 当前选中的街道 }; }, mounted() { // 加载所有的省份 this.loadProvinces(); }, methods: { // 加载所有的省份 loadProvinces() { // TODO: 发送请求获取所有的省份数据 this.provinces = [ { code: "110000", name: "北京市" }, { code: "120000", name: "天津市" }, { code: "130000", name: "河北省" }, { code: "140000", name: "山西省" }, { code: "150000", name: "内蒙古自治区" } ]; }, // 加载当前省份下的所有城市 loadCities() { // TODO: 发送请求获取当前省份下的所有城市数据 this.cities = [ { code: "110100", name: "北京市" }, { code: "120100", name: "天津市" }, { code: "130100", name: "石家庄市" }, { code: "130200", name: "唐山市" }, { code: "130300", name: "秦皇岛市" } ]; }, // 加载当前城市下的所有区县 loadDistricts() { // TODO: 发送请求获取当前城市下的所有区县数据 this.districts = [ { code: "110101", name: "东城区" }, { code: "110102", name: "西城区" }, { code: "110105", name: "朝阳区" }, { code: "110106", name: "丰台区" }, { code: "110107", name: "石景山区" } ]; }, // 加载当前区县下的所有街道 loadStreets() { // TODO: 发送请求获取当前区县下的所有街道数据 this.streets = [ { code: "110101001", name: "东华门街道" }, { code: "110101002", name: "景山街道" }, { code: "110101003", name: "交道口街道" }, { code: "110101004", name: "安定门街道" }, { code: "110101005", name: "北新桥街道" } ]; }, // 省份变化时更新城市列表和区县列表 onProvinceChange() { this.selectedCity = null; this.selectedDistrict = null; this.selectedStreet = null; if (this.selectedProvince) { this.loadCities(); this.cities = []; this.districts = []; this.streets = []; } }, // 城市变化时更新区县列表和街道列表 onCityChange() { this.selectedDistrict = null; this.selectedStreet = null; if (this.selectedCity) { this.loadDistricts(); this.districts = []; this.streets = []; } }, // 区县变化时更新街道列表 onDistrictChange() { this.selectedStreet = null; if (this.selectedDistrict) { this.loadStreets(); this.streets = []; } } } }; </script> ``` 以上代码仅供参考,实际上,您需要根据自己的需求来进行修改和完善。例如,您可以将数据请求等方法单独封装到一个 `service` 文件中,让代码更加清晰易读。

相关推荐

最新推荐

recommend-type

vue element-ui之怎么封装一个自己的组件的详解

主要介绍了vue element-ui之怎么封装一个自己的组件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

使用Vue组件实现一个简单弹窗效果

主要介绍了使用Vue组件实现一个简单弹窗效果,本文主要内容会涉及到弹窗遮罩的实现, slot 插槽的使用方式,props 、 $emit 传参,具体组件代码也传上去了。需要的朋友可以参考下
recommend-type

vue之将echart封装为组件

主要介绍了vue之将echart封装为组件,本文将会以雷达图为案例,一步步讲解在vue项目中如何使用echart,如何将其封装为能重复调用的组件
recommend-type

基于vue写一个全局Message组件的实现

主要介绍了基于vue写一个全局Message组件的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

vue实现图片预览组件封装与使用

主要为大家详细介绍了vue实现图片预览组件封装与使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

优化MATLAB分段函数绘制:提升效率,绘制更快速

![优化MATLAB分段函数绘制:提升效率,绘制更快速](https://ucc.alicdn.com/pic/developer-ecology/666d2a4198c6409c9694db36397539c1.png?x-oss-process=image/resize,s_500,m_lfit) # 1. MATLAB分段函数绘制概述** 分段函数绘制是一种常用的技术,用于可视化不同区间内具有不同数学表达式的函数。在MATLAB中,分段函数可以通过使用if-else语句或switch-case语句来实现。 **绘制过程** MATLAB分段函数绘制的过程通常包括以下步骤: 1.
recommend-type

SDN如何实现简易防火墙

SDN可以通过控制器来实现简易防火墙。具体步骤如下: 1. 定义防火墙规则:在控制器上定义防火墙规则,例如禁止某些IP地址或端口访问,或者只允许来自特定IP地址或端口的流量通过。 2. 获取流量信息:SDN交换机会将流量信息发送给控制器。控制器可以根据防火墙规则对流量进行过滤。 3. 过滤流量:控制器根据防火墙规则对流量进行过滤,满足规则的流量可以通过,不满足规则的流量则被阻止。 4. 配置交换机:控制器根据防火墙规则配置交换机,只允许通过满足规则的流量,不满足规则的流量则被阻止。 需要注意的是,这种简易防火墙并不能完全保护网络安全,只能起到一定的防护作用,对于更严格的安全要求,需要
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。