vue地区选择组件

AddressMap

a vue.js component

概述

主要用于全国地区数据的操作,包括省,市,区三级联动,地区数据的添加和删除; 在操作地区数据时,以前也用过树形的地区选择组件,但因其在再操作大量的地区数据时,渲染缓慢,所以我们就换了另一种数据展示形式和交互形式,从而就有了这个组件。

注意:该组件是vue.js组件

demo

抢鲜体验请点击这里demo

API

Props

参数类型说明
areaArray传入组件的地区的数据

Events

事件名参数说明
selectedarea组件中选中的地区

详细说明

Props

area

area 参数是必选项,表示组件初始化时的地区数据,可以为空。 area 是一个包含多个对象的数组,其中每个对象的数据结构如下:

...
area: [
    {Name: '北京',  ID: '01'},
    {Name: '南京', ID: '0401'},
    {Name: '西湖区', ID: '060105'}
],
...
复制代码

因为后来在实际的使用中,发现有时候,后台只会返回一个地区的ID值,所以这里做了优化,可以只传入ID的值,比如这样:

...
area: [
    {ID: '01'},
    {ID: '0401'},
    {ID: '060105'}
],
...
复制代码

selected

selected是由组件内部发布的一个事件,你可以在组件外面订阅这个事件,从而得到它返回的值,这个值就是组件当前选中的所有的地区,返回的这个值是由多个包含地区数据的对象组成的数组,数据结构和 area参数一样

简单的例子

<div>
     <addressmap :area="area" @selected="selected"></addressmap>
</div>
复制代码

安装和使用

npm install adc-addressmap
复制代码
  • 若作为全局组件使用
//在项目入口文件
import Vue from 'vue'
import Addressmap from 'adc-addressmap'
Vue.component('Addressmap', Addressmap)
复制代码
  • 若作为局部组件
//在某个组件中
import Addressmap from 'adc-addressmap'
export default {
...
  components: { Addressmap},
...
}
复制代码

该组件后续功能的预告

  • 结合百度的ECharts增加数据可视化的功能

最后欢迎Star

github地址

转载于:https://juejin.im/post/5ae519706fb9a07abd0d6c52

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值