ECharts的基本使用

ECharts的基本使用

一、ECharts的特点

二、基本使用

第一步:引入echarts.js文件

第二步:准备呈现图标的盒子

第三步:初始化echarts实力对象:

let mCharts = echarts.init(document.querySelector('div'));//传递的dom元素
//就是用来装echarts的框

第四步:准备配置项

let option = {
        XAxis:{
            type:'category',
            data:["小米","小红","小王"],
            yAxis:{
                type:"value",
            },
            series:[
                {
                    name:"语文",
                    type:"bar",
                    data:["70","80","90"]                    
                }
            ]
            
        }
}

第五步:将配置项设置给echarts实例对象

mCharts.setOption(option);

三、相关配置解释

●xAxis: 直角坐标系中的x轴

●yAxis: 直角坐标系中的y轴

●series: 系列列表。每个系列通过type决定自己的图表类型。

let option = {
        title:{
            text:"成绩",//标题
            link:"... ",//点击标题的链接
            tsxtStyle:{
                //主标题的文字风格
            }
        },
        XAxis:{
            type:'category',//类目轴
            data:["小米","小红","小王"],
            yAxis:{
                type:"value",//数值轴 
            },
            series:[//主要是配置给y轴的数据
                {
                    name:"语文",
                    type:"bar",//图形 bar柱状图  
                     data:["70","80","90"]                                      
                }
            ]
            
        }
}

四、七大图表

1.柱状图

柱状图常见效果:

标记:最大值 最小值 平均值

MarkPoint

Markline

let option = {
        title:{
            text:"成绩",//标题
            link:"... ",//点击标题的链接
            tsxtStyle:{
                //主标题的文字风格
            }
        },
        XAxis:{
            type:'category',//类目轴
            data:["小米","小红","小王"],
            yAxis:{
                type:"value",//数值轴 
            },
            series:[//主要是配置给y轴的数据
                {
                    name:"语文",
                    type:"bar",//图形 bar柱状图  
                   marPoint:{
                       data:[
                           {type:"max",name:"最大值"},
                           {type:"min",name:"最小值"}
                       ]
                      } ,
                   markLine:{
                       data:[
                           {type:"average",name:"平均值"}
                       ]
                    } ,
                   data:["70","80","90"],                                     
                }
            ]
            
        }
}

显示:数值显示 柱宽度

label barWidth 更改x和y的角色

series:[//主要是配置给y轴的数据
                {
                    name:"语文",
                    type:"bar",//图形 bar柱状图  
                   marPoint:{
                       data:[
                           {type:"max",name:"最大值"},
                           {type:"min",name:"最小值"}
                       ]
                      } ,
                  markLine:{//显示平均值
                       data:[
                           {type:"average",name:"平均值"}
                       ]
                    } ,
                label:{
                    show:true,
                    rotate:60,//旋转
                    position:"top"//标签的位置
                },
                data:["70","80","90"],                                     
                }
            ]

通用配置

1. title 标题

文字样式 textStyle

let option ={
    titel:{
        text:"通用样式",
        textStyle:{
            color:"red"
        },
        borderWidth:5,
        borgerRadius:5,
        borderColor:"blue",
        //标题位置
        left:10,
    } 
}

2. tooltip 提示

let option ={
        tooltip:{
          //trgger: "item",//移动到柱状内部会显示的内容
           trigger:"axis",
           triggerOn:"mouseover"//鼠标移入时显示,对应click 鼠标点击时显示
           //formatter:`{b}的成绩是{c}`//提示中显示的内容
           formatter:function(arg){//可使用回调函数
               return arg[0].name
               }
           } 
    
}

3.toolbox 工具按钮

let option ={
    toolbox:{
        feature:{
            //到处图片
            saveAsImage:{},
            //数据视图 呈现最原始的数据,并可以修改
            dataView:{},
            //重置功能
            restore:{},
            //区域缩放 可还原
            dataZoom:{},
           // 动态图表中间切换
            magicType:{
            type:["bar","line"]
            },
        }
    }
}

4.legend 图例

let option = {
        title:{
            text:"成绩",//标题
            link:"... ",//点击标题的链接
            tsxtStyle:{
                //主标题的文字风格
            }
        },
        XAxis:{
            type:'category',//类目轴
            data:["小米","小红","小王"],
            yAxis:{
                type:"value",//数值轴 
            },
            legend:{
            data:["语文","数学"]//对应的标准为data中的字符串与
            //series中的那么值匹配
            },
            series:[//主要是配置给y轴的数据
                {
                   name:"语文",
                   type:"bar",//图形 bar柱状图  
                   marPoint:{
                       data:[
                           {type:"max",name:"最大值"},
                           {type:"min",name:"最小值"}
                       ]
                      } ,
                   markLine:{
                       data:[
                           {type:"average",name:"平均值"}
                       ]
                    } ,
                   data:["70","80","90"],                                     
                },
                {
                    name:"数学",
                    type:"bar",
                    data:["75","80","70"]
                }
            ]
            
        }
}

2.折线图

let option = {
        title:{
            text:"成绩",//标题
            link:"... ",//点击标题的链接
            tsxtStyle:{
                //主标题的文字风格
            }
        },
        XAxis:{
                type:'category',//类目轴
                data:["小米","小红","小王"],
                boundaryGap:false,//x轴紧挨边缘
                },
       yAxis:{
                type:"value",//数值轴 
                scale:true//脱离0值比例
         },
       legend:{
            data:["语文","数学"]//对应的标准为data中的字符串与
            //series中的那么值匹配
         },
       series:[//主要是配置给y轴的数据
               {
                   name:"语文",
                   type:"line",//图形 折线图  
                   marPoint:{
                       data:[
                           {type:"max",name:"最大值"},
                           {type:"min",name:"最小值"}
                       ]
                    } ,
                   markLine:{
                       data:[
                           {type:"average",name:"平均值"}
                       ]
                    } ,
                    markArea:{
                        // 标注区间
                        data:[
                            [
                                {XAxis:'1月'},//开始值
                                {XAxis:'2月' },//结束值
                            ],
                            [
                                {XAxis:'7月'},//开始值
                                {XAxis:'8月' },//结束值
                            ]
                        ]
                    },
                    areaStyle:{//填充风格
                        color:'red',
                    },
                    smooth:true,//平滑的曲线 
                    lineStyle:{
                        color:'red',//线条颜色
                        type:'dashed',//线条形状 直线solid  点状虚线
                    },
                    data:["70","80","90"],                                     
                },
                {
                    name:"数学",
                    type:"bar",
                    data:["75","80","70"]
                }
            ]
            
        }
}

堆叠图

  let option = {
            yAxis: {
                type: 'category',
                data: xDataArr,
            },
            yAxis: {
                type: 'value',              
            },
            series:[
                {
                    type:"line",
                    data:data1,
                    stack:"all",//堆叠 以数据小的为坐标 stack值要一样
                    areaStyle:{},//填充风格
                },
                {
                    type:"line",
                    data:data2,
                    stack:"all",//堆叠 以数据小的为坐标
                    areaStyle:{},
                }
            ]
        }

小结

➢基本的折线图

●基本的代码结构

●x轴和y轴的数据

●series中 的type设置为line

➢折线图常见效果

●最大值\最小值\平均值markPoint markLine markArea

●线条显示smooth lineStyle

●填充风格areaStyle

●紧挨边缘boundaryGap

●脱离0值比例scale

●堆叠图stack

➢折线图特点

折线图常用来分析数据随时间的变化趋势

3.散点图

// 散点图
        let option = {
            xAxis: {
                type: "value",
                scale: true,
            },
            yAxis: {
                type: "value",
                scale: true,//脱离0值比例
            },
            serise: {
                type: "scatter",//散点图
                data: axisData,//axisData为二维数组
            }
        }

散点图的常见效果:

气泡效果图--控制散点的大小和颜色

let option = {
            xAxis: {
                type: "value",
                scale: true,
            },
            yAxis: {
                type: "value",
                scale: true,//脱离0值比例
            },
            serise: {
                // type: "scatter",//散点图
                type: "effectScatter",//散点图 涟漪动画
                rippleEffect: {
                    scale: 10 // 涟漪动画大小
                },
                showEffectOn: "",// render-每个散点渲染完后自动拥有涟漪效果 
                // emphasis-鼠标滑过时,出现的涟漪动画 
                data: axisData,//axisData为二维数组
                symbolSize: function (arg) {
                    // symbolSize可接受回调函数
                    let height = arg[0];
                    let weight = arg[1];
                    let bmi = weight / (height * height);
                    if (bmi > 28) {
                        return 20
                    } else {
                        return 5
                    }
                },
                itemStyle: {
                    color: function (arg) { //设置气泡颜色 此时arg是一个对象
                        let height = arg.data[0];
                        let weight = arg.data[1];
                        let bmi = weight / (height * height);
                        if (bmi > 28) {
                            return "red"
                        } else {
                            return "green"
                        }
                    }
                }
            }
        }

小结

➢基本的散点图

●基本的代码结构

●x轴和y轴的数据, 是- -个二维数组

●series中的type设置为scatter

●xAxis和yAxis中的type设置 为value

➢散点图常见效果

●气泡图

涟漪效果

➢散点图特点

●散点图可以帮助我们推断出不同维数据之间的相关性

●散点图也经常用在地图的标注

4.直角坐标系的通用配置

柱状图,折线图,散点图 都是直角坐标系图

let option = {
grid: {//控制图标的大小和位置
                show: true,//显示
                borderWidth: 10,
                borderColor: "red",
                left: 20,
                top: 20,
                width: 200,
                hight: 200,
            },
            XAxis: {
                type: 'category',//类目轴
                data: ["小米", "小红", "小王"],
            },
            yAxis: {
                type: "value",//数值轴 
            },
            series: [//主要是配置给y轴的数据
                {
                    name: "语文",
                    type: "bar",//图形 bar柱状图  
                    data: ["70", "80", "90"]
                }
            ]
        }

配置

如果一个轴是类目轴,需要 配置data ,如果是数值轴,不需要配置data,它会自动在 series 中去找data

1: 网格 grid

grid是用来控制直角坐标系的布局和大小

x轴和y轴就是在grid的基础上进行绘制的

●显示grid

show

●grid的边框

borderWidth、borderColor

●grid的位 置和大小

left、

top、right、

bottom

width、height

2:坐标轴axis

坐标轴分为x轴和y轴

一-个grid中最多有两种位置的x轴和y轴

●坐标轴类型 type

value:数值轴,自动会从目标数据中读取数据

category:类目轴,该类型必须通过data设置类目数据

●显示位置position

xAxis:可取值为top或者bottom

yAxis:可取值为left或者right

 let option = {
            XAxis: {
                type: 'category',//类目轴
                data: ["小米", "小红", "小王"],
                potion:top,//可取值为top或者bottom
            },
            yAxis: {
                type: "value",//数值轴 
                potion:left,//可取值为left或者right
            },
            series: [//主要是配置给y轴的数据
                {
                    name: "语文",
                    type: "bar",//图形 bar柱状图  
                    data: ["70", "80", "90"]
                }
            ]
        }

3:区域缩放dataZoom

dataZoom用于区域缩放,对数据范围过滤, x轴和y轴都可以拥有

dataZoom是- -个数组,意味着可以配置多个区域缩放器

●类型type

slider:滑块

inside:内置,依靠鼠标滚轮或者双指缩放

●指明产生作用的轴

xAxisIndex:设置缩放组件控制的是哪个x轴,一般写0即可

yAxisIndex:设置缩放组件控制的是哪个y轴, -般写0即可

●指明初始状态的缩放情况

start:数据窗口范围的起始百分比

end:数据窗口范围的结束百分比

let option4 = {
            dataZoom: [
                // dataZoom只有一个对象时,默认是x轴,如果不只一个就需要指明坐标轴
                {
                    type: "slider",//表格下方的滑块控制缩放的区域 可滚动
                    //type:"inside"//鼠标滚轮或者双击缩放
                    xAxisIndex: 0
                },
                {
                    type: "slider",//表格下方的滑块控制缩放的区域 可滚动
                    //type:"inside"//鼠标滚轮或者双击缩放
                    yAxisIndex: 0,
                    start: 0,
                    end: 50//百分之多少
                },
            ],//区域缩放
            toolbox: {
                feature: {
                    dataZoom: {},//缩放区域
                }
            },
            XAxis: {
                type: 'category',//类目轴
                data: ["小米", "小红", "小王"],
                potion: top,
            },
            yAxis: {
                type: "value",//数值轴 
                potion: left,
            },
            series: [//主要是配置给y轴的数据
                {
                    name: "语文",
                    type: "bar",//图形 bar柱状图  
                    data: ["70", "80", "90"]
                }
            ]
        }

5.饼图

基本配置

// 饼图 value 为数组,数组中包含对象
        // 对象中为name和vale [{name:"xx",value:"vv"},{name:"xx",value:"vv"}]
        let pieData = [{ name: "x2x", value: 1220 }, { name: "xx2", value: 3220 }]
        let option5 = {
            series: [{
                type: 'pie',// 饼图
                data: pieData,
            }]
        }
// 饼图常见效果
        let option6 = {
            series: [{
                type: 'pie',// 饼图
                data: pieData,
                label: {//饼图文字显示
                    show: true,//显示文字
                    // formatter: "ii",//决定文字显示的内容 可接受回调函数
                    formatter: function (arg) {
                        // 饼图中的arg参数中有一个 percent参数 为所占百分比
                        return arg.name + "平台花了" + arg.value +
                         "占" + arg.percent + "%"
                    }
                },
                // radius:20,//饼图半径的设置
                // radius:"40%",//可设置百分比
                // 参照的是宽度和高度中的较小的一个值的一半的百分比设置
                // radius:["30%","75%"],
                //设置为圆环,第0个元素代表内圆半径,第2个元素为外远半径
                roseType:"radius",
                //蓝丁格尔图 设置每部分半径不同
                // selectedMode:"single", 
                //选中的效果,能够选中的区域偏离圆点一小段距离
                selectedMode:"multiple",
                selectedOffset:20,//设置偏离圆心的距离
            }]
        }

小结

➢基本的饼图

●基本的代码结构

●数据是由name和value组成 的对象所形成的数组

●series中 的type设置为pie

●无须配置xAxis和yAxis

➢饼图常见效果

●显示文字的格式化

●圆环

●南丁格尔图

●选中效果

➢饼图特点

●饼图可以很好地帮助用户快速了解不同分类的数据的占比情况

6.地图

矢量地图的实现步骤

●ECharts最 基本的代码结构:

引入js文件, DOM容器,初始化对象,设置option

●准备中国的矢量地图json文件,放到json/map/的目录下

china.json

●使用Ajax获 取china.json

$.get("json/ map/china.json', function (chinaJson) {})

●在回调函数中往echarts全局对象注册地图的json数据

echarts.registerMap('chinaMap', chinaJson);

●在geo下设置

type:'map'

map:'

'chinaMap'

7.自适应

当浏览器的大小发生变化的时候,如果想让图表也能随之适配变化

●1. 监听窗口大小变化事件

●2.在事件 处理函数中调用ECharts实例对象的resize即可

window.onresize = function(){
myChart.resize();
}

8.加载动画

ECharts已经内置好了加载数据的动画,我们只需要在合适的时机显示或者隐藏即可

●显示加载动画

mCharts.showLoading()

●隐藏加载动画

mCharts.hideLoading()