Arya23(学习echarts)

Echarts介绍

ECharts,一个使用 JavaScript 实现的开源可视化库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(IE8/9/10/11,Chrome,Firefox,Safari等),底层依赖矢量图形库 ZRender,提供直观,交互丰富,可高度个性化定制的数据可视化图表。

百度出品的一个开源 Javascript 数据可视化库

可视化面板:应对现在数据可视化的趋势,越来越多企业需要在很多场景(营销数据,生产数据,用户数据)下使用,可视化图表来展示体现数据,让数据更加直观,数据特点更加突出。

官网地址:https://www.echartsjs.com/zh/index.html

使用Echarts

  1. 引入echarts 插件文件到html页面中
  2. 准备一个具备大小的DOM容器

    1
    <div id="main" style="width: 600px;height:400px;"></div>
  3. 初始化echarts实例对象

    1
    var myChart = echarts.init(document.getElementById('main'));
  4. 指定配置项和数据(option)

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    var option = {
    xAxis: {
    type: 'category',
    data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
    },
    yAxis: {
    type: 'value'
    },
    series: [{
    data: [820, 932, 901, 934, 1290, 1330, 1320],
    type: 'line'
    }]
    };
  5. 将配置项设置给echarts实例对象

    1
    myChart.setOption(option);

    Echarts配置

    需要了解的主要配置:series、xAxis、yAxis、grid、tooltip、title、legend、color

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    series:
    系列列表。每个系列通过 `type` 决定自己的图表类型
    大白话:图标数据,指定什么类型的图标,可以多个图表重叠。
    xAxis:直角坐标系 grid 中的 x 轴
    boundaryGap: 坐标轴两边留白策略 true,这时候刻度只是作为分隔线,
    标签和数据点都会在两个刻度之间的带(band)中间
    yAxis:直角坐标系 grid 中的 y 轴
    grid:直角坐标系内绘图网格。
    title:标题组件
    tooltip:提示框组件
    legend:图例组件
    color:调色盘颜色列表
    数据堆叠,同个类目轴上系列配置相同的`stack`
    值后 后一个系列的值会在前一个系列的值上相加。

    案例:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
      option = {
    // color设置我们线条的颜色 注意后面是个数组
    color: ['pink', 'red', 'green', 'skyblue'],
    // 设置图表的标题
    title: {
    text: '折线图堆叠123'
    },
    // 图表的提示框组件
    tooltip: {
    // 触发方式
    trigger: 'axis'
    },
    // 图例组件
    legend: {
    // series里面有了 name值则 legend里面的data可以删掉
    },
    // 网格配置 grid可以控制线形图 柱状图 图表大小
    grid: {
    left: '3%',
    right: '4%',
    bottom: '3%',
    // 是否显示刻度标签 如果是true 就显示 否则反之
    containLabel: true
    },
    // 工具箱组件 可以另存为图片等功能
    toolbox: {
    feature: {
    saveAsImage: {}
    }
    },
    // 设置x轴的相关配置
    xAxis: {
    type: 'category',
    // 是否让我们的线条和坐标轴有缝隙
    boundaryGap: false,
    data: ['星期一', '周二', '周三', '周四', '周五', '周六', '周日']
    },
    // 设置y轴的相关配置
    yAxis: {
    type: 'value'
    },
    // 系列图表配置 它决定着显示那种类型的图表
    series: [
    {
    name: '邮件营销',
    type: 'line',

    data: [120, 132, 101, 134, 90, 230, 210]
    },
    {
    name: '联盟广告',
    type: 'line',

    data: [220, 182, 191, 234, 290, 330, 310]
    },
    {
    name: '视频广告',
    type: 'line',

    data: [150, 232, 201, 154, 190, 330, 410]
    },
    {
    name: '直接访问',
    type: 'line',

    data: [320, 332, 301, 334, 390, 330, 320]
    }
    ]
    };

    注意事项

    1、 防止缩放的时候,引导线过长。引导线略短些 (series对象里面的 labelLine 对象设置 )
    连接图表 6 px
    连接文字 8 px

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
        // 文字调整
    label:{
    fontSize: 10
    },
    // 引导线调整
    labelLine: {
    // 连接扇形图线长
    length: 6,
    // 连接文字线长
    length2: 8
    }
    }
    ],

    2、浏览器缩放的时候,图表跟着自动适配。

    1
    2
    3
    4
    // 监听浏览器缩放,图表对象调用缩放resize函数
    window.addEventListener("resize", function() {
    myChart.resize();
    });

    社区介绍

    社区就是一些,活跃的echart使用者,交流和贡献定制好的图表的地方。在这里可以找到一些基于echart的高度定制好的图表,相当于基于jquery开发的插件,这里是基于echarts开发的第三方的图表。

你可以对我进行打赏哦