echarts入门

Posted SDingBa

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了echarts入门相关的知识,希望对你有一定的参考价值。

最近工作接触了echarts,算是入门吧,写下经验,方便我自己以后查看.一下先说官方文档:
y
获取echarts
1 从官网下载界面选择你需要的版本下载,根据开发者功能和体积上的需求,我们提供了不同打包的下载,如果你在体积上没有要求,可以直接下载完整版本。开发环境建议下载源代码版本,包含了常见的错误提示和警告。

2 在 ECharts 的 GitHub 上下载最新的 release 版本,解压出来的文件夹里的 dist 目录里可以找到最新版本的 echarts 库。

3 通过 npm 获取 echarts,npm install echarts –save,详见“在 webpack 中使用 echarts”

4 cdn 引入,你可以在 cdnjs,npmcdn 或者国内的 bootcdn 上找到 ECharts 的最新版本。

引入 ECharts
ECharts 3 开始不再强制使用 AMD 的方式按需引入,代码里也不再内置 AMD 加载器。因此引入方式简单了很多,只需要像普通的 javascript 库一样用 script 标签引入。

<!DOCTYPE html>
<html>
<header>
    <meta charset="utf-8">
    <!-- 引入 ECharts 文件 -->
    <script src="echarts.min.js"></script>
</header>
</html>

绘制一个简单的图表
在绘图前我们需要为 ECharts 准备一个具备高宽的 DOM 容器。

<body>
    <!-- 为 ECharts 准备一个具备大小(宽高)的 DOM -->
    <div id="main" style="width: 600px;height:400px;"></div>
</body>

然后就可以通过 echarts.init 方法初始化一个 echarts 实例并通过 setOption 方法生成一个简单的柱状图,下面是完整代码。

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>ECharts</title>
    <!-- 引入 echarts.js -->
    <script src="echarts.min.js"></script>
</head>
<body>
    <!-- 为ECharts准备一个具备大小(宽高)的Dom -->
    <div id="main" style="width: 600px;height:400px;"></div>
    <script type="text/javascript">
        // 基于准备好的dom,初始化echarts实例
        var myChart = echarts.init(document.getElementById('main'));

        // 指定图表的配置项和数据
        var option = 
            title: 
                text: 'ECharts 入门示例'
            ,
            tooltip: ,
            legend: 
                data:['销量']
            ,
            xAxis: 
                data: ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子"]
            ,
            yAxis: ,
            series: [
                name: '销量',
                type: 'bar',
                data: [5, 20, 36, 10, 10, 20]
            ]
        ;

        // 使用刚指定的配置项和数据显示图表。
        myChart.setOption(option);
    </script>
</body>
</html>

这样你的第一个图表就诞生了!

这就是官方给出的demo,,,
很明显可以看出来,这主要是,依靠插件,和json(特定)语句就能实现.

var option = 
            title: 
                text: 'ECharts 入门示例'
            ,
            tooltip: ,
            legend: 
                data:['销量']
            ,
            xAxis: 
                data: ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子"]
            ,
            yAxis: ,
            series: [
                name: '销量',
                type: 'bar',
                data: [5, 20, 36, 10, 10, 20]
            ]
        ;

线,,,下面说说,java生成

Maven坐标:

<dependency>
  <groupId>com.github.abel533</groupId>
  <artifactId>ECharts</artifactId>
  <version>3.0.0</version>
</dependency>

jar包

ECharts组件

Axis - 坐标轴
Grid - 网格
Title - 标题
Tooltip - 提示
Legend - 图例
DataZoom - 数据区域缩放
DataRange - 值域漫游
Toolbox - 工具箱
Timeline - 时间线
visualMap - 视觉映射组件

x下面说说 以下的实现:

option = 
    title: 
        text: '折线图堆叠'
    ,
    tooltip: 
        trigger: 'axis'
    ,
    legend: 
        data:['邮件营销','联盟广告','视频广告','直接访问','搜索引擎']
    ,
    grid: 
        left: '3%',
        right: '4%',
        bottom: '3%',
        containLabel: true
    ,
    toolbox: 
        feature: 
            saveAsImage: 
        
    ,
    xAxis: 
        type: 'category',
        boundaryGap: false,
        data: ['周一','周二','周三','周四','周五','周六','周日']
    ,
    yAxis: 
        type: 'value'
    ,
    series: [
        
            name:'邮件营销',
            type:'line',
            stack: '总量',
            data:[120, 132, 101, 134, 90, 230, 210]
        ,
        
            name:'联盟广告',
            type:'line',
            stack: '总量',
            data:[220, 182, 191, 234, 290, 330, 310]
        ,
        
            name:'视频广告',
            type:'line',
            stack: '总量',
            data:[150, 232, 201, 154, 190, 330, 410]
        ,
        
            name:'直接访问',
            type:'line',
            stack: '总量',
            data:[320, 332, 301, 334, 390, 330, 320]
        ,
        
            name:'搜索引擎',
            type:'line',
            stack: '总量',
            data:[820, 932, 901, 934, 1290, 1330, 1320]
        
    ]
;

q其中:

grid: 
        left: '3%',    可以使用 x 代替
        right: '4%',
        bottom: '3%',
        containLabel: true
    ,

GsonOption或Option都行;

        GsonOption option = new GsonOption();
        option.title("激活量线性图").tooltip(Trigger.axis);
        option.toolbox().feature(Tool.saveAsImage);
        option.grid().setX("3%");
        option.grid().setY("4%");
        option.grid().setY2("3%");
        option.yAxis(new ValueAxis());
        CategoryAxis category = new CategoryAxis();
        category.boundaryGap(false);

        for (int i = 0; i <= 23; i++) 
                categoryDataDay.add(String.valueOf(i));
        
        List<Series> lineList = new ArrayList<>();
        List<String> legendDays = new ArrayList<>();
        Line activeLine = new Line();
        legendDays.add(showDayStr);
        lineList.add(activeLine);
        String[] legend = new String[legendDays.size()];
        for (int i = 0; i < legendDays.size(); i++) 
            legend[i] = legendDays.get(i);
        
        option.setSeries(lineList);
        category.setData(categoryDataDay);
        option.xAxis(category);
        option.legend(legend);

(以上代码是我在项目中抽出来的,没有数据支持,读者要理解后修改,(上面代码不全.))
y以上代码 大致生成这样的格式:

 
    title: 
        text: '折线图堆叠'
    ,
    tooltip: 
        trigger: 'axis'
    ,
    legend: 
        data:['今天','昨天','前天']
    ,
    grid: 
        left: '3%',
        right: '4%',
        bottom: '3%',

    ,
    toolbox: 
        feature: 
            saveAsImage: 
        
    ,
    xAxis: 
        type: 'category',
        boundaryGap: false,
        data: ['0','2h','4h','6h','8h','10H','12']
    ,
    yAxis: 
        type: 'value'
    ,
    series: [

        
            name:'今天',
            type:'line',

            data:[150, 232, 201, 154, 190, 330, 410]
        ,
        
            name:'昨天',
            type:'line',

            data:[320, 332, 301, 334, 390, 330, 320]
        ,
        
            name:'前天',
            type:'line',

            data:[820, 932, 901, 934, 1290, 1330, 1320]
        
    ]
;

f添加上数据后,大致可以生成这样的demo,具体的线段,可以设置,

1 如果 添加stack: 字段;则出现的线段不在是重贴的,而是向上排列;

series: [

        
            name:'今天',
            type:'line',
            stack: '总量',
            data:[150, 232, 201, 154, 190, 330, 410]
        

2,注意;

legend: 
        data:['邮件营销','联盟广告','视频广告','直接访问','搜索引擎']
    ,

,里面的data字段要和series里面的子集合name字段对应;

series: [
        
            name:'邮件营销',
            type:'line',
            stack: '总量',
            data:[120, 132, 101, 134, 90, 230, 210]
        ,
        
            name:'联盟广告',
            type:'line',
            stack: '总量',
            data:[220, 182, 191, 234, 290, 330, 310]
        ,
        
            name:'视频广告',
            type:'line',
            stack: '总量',
            data:[150, 232, 201, 154, 190, 330, 410]
        ,
        
            name:'直接访问',
            type:'line',
            stack: '总量',
            data:[320, 332, 301, 334, 390, 330, 320]
        ,
        
            name:'搜索引擎',
            type:'line',
            stack: '总量',
            data:[820, 932, 901, 934, 1290, 1330, 1320]
        
    ]

d否则显示会出现错误.(数据会出现点点丢失)

以上是关于echarts入门的主要内容,如果未能解决你的问题,请参考以下文章

数据可视化-pyechartspyecharts快速入门

echarts中js面向对象编程

Echarts练习--同时显示柱状图和饼图

Echarts x轴文本内容太长的几种解决方案

Echarts x轴文本内容太长的几种解决方案

Echarts x轴文本内容太长的几种解决方案