本文介绍echarts显示中国省份图,对于需要高亮的省份进行筛选。并且对省份进行选择性交互。
首先我们需要一个颜色集合,代表我们要设置多少种颜色。这里用到了dataRange。
dataRange: {
show:false,
x: 'left',
y: 'bottom',
splitList: [
{start: 5, end: 5, color: 'orange'},//当值为5时,区域背景
{start: 10, end: 10, color: '#ff6300'},//当值为10时,区域背景
{start: 15, end: 15, color: '#ccc'},//当值为15时,区域背景
],
},
然后就需要数据就行了。
series : [
{
name: '市场分布',
type: 'map',
mapType: 'china',
//hoverable: false,
roam: false,
itemStyle:{
normal:{label:{show:true}},
emphasis:{label:{show:false}}
},
data:[],
}
],
这里的data为空,因为正常情况下数据不会写死,都是从后台获取的,在这里我直接赋值。
var ini_data=[];//初始化省份数组
var provArr = ['河北', '河南', '云南', '辽宁', '黑龙江', '湖南', '安徽','山东'];//获取的省份,有可能是从后台获取
由于框架不识别'省',‘市’的字眼,所以使用正则将字眼去掉。
//正则省份,将省与市的字眼去掉,框架不识别
for(var i=0;i
此时,我们有了一个完整的ini_data对象数组了。可以直接给图表赋值了。
option.series[0].data=ini_data;//将拼接好的数组赋给参数集合
mycharts.setOption(option);//跟新图表
可以看到,只要在数组里的省份都变成了我设置的orange颜色,因为它们的value都是5。
下面就是交互了,我的需求是点击灰色省份无任何效果,点击orange色的省份背景变为‘#ff6300’。
//点击事件
mycharts.on('click', function (params) {//点击事件
select_province(params.name);
});
//初始化省颜色
function ini_province(){
var ini_len=option.series[0].data.length;
for(var i=0;i
我们通过监听click事件来获得event对象,然后获得省份,经过匹配后,将原来选中的省份清零,再改变选中省份的颜色。
至于鼠标滑过的高亮效果,是框架自带的,默认是所有省份都有,如果想去掉只要加:hoverable: false就行了,不过这样同样会取消掉橙色的省份。所以为了保留橙色省份的滑动高亮效果,我是这样写的。
//鼠标滑过事件
var testStr=','+provArr.join(",")+",";
mycharts.on('hover', function (param){
if(testStr.indexOf(","+param.name+",")!=-1){
return false;
}else{
param.value=15;
mycharts.setOption(option);
}
});
这时设置的第三个颜色生效了,当鼠标滑过时没有匹配到provArr中的省份时,就设置背景颜色为#ccc,由于默认背景是#ccc的缘故,也可以重新设置背景色,只要这里设置的颜色与背景色相同就行了。
附上demo地址:https://my.weblf.cn/xly/demo/echarts/map/map2.html
稍作修改也可点击进入省内详情:https://my.weblf.cn/xly/demo/echarts/map/map_china.html
附上完整代码:
全国市场分布图