当前位置: 首页 > news >正文

百度echarts可以做什么

百度echarts可以做什么

一、总结

一句话总结:可视化做的很好,各种图都有。而且支持动态数据。

 

 

二、百度eCharts体验

前言 

      从昨天开始给项目里添加一些图表对比功能,上一个项目里使用的是Highcharts,本打算继续用Highcharts做的,昨天试了下做出来的效果不太好,主要也是因为看的多了没什么新鲜感了,于是便尝试下百度做的ECharts, 总体效果还是不错的。

 

先来几张效果图体验下

     其中第6张、第七张的效果可以说是在HTML环境下将Canvas发挥到极致,虽然我目前还没接触到HTML5和CSS3,深深感到和社会脱节啊,一直做信息化系统开发,整天跟随业务而变化,有时甚感无聊[随意吐槽下]。

 

优势

      1、颜色对比度和鲜明度明显要比HighCharts要好。也可能是因为我看HighCharts看的多了,有些视觉疲劳了。

      2、支持工具栏。 这个可以说是用了这么多前端插件最意外的一个功能,工具栏中支持【查看数据】、【折现图】、【堆叠】、【平铺】、【还原】、【保存为图片】,几种格式互相切换起来确实方便不少,尤其是事业单位的员工用户,闲的没事干可以点来点去。

      3、模块化引入和单文件引入。在开发时你可以引用所有echarts开发文件,方便开发和调试。但是项目发布后则可以去除不需要的文件以加快页面响应速度。

      4、用ECharts自己的话说就是折、柱、散点、K线20万数据,秒级出图(估计这一点完爆其他控件)。

      5、拖拽重新计算,可以让懂数据的、爱好数据的自行进行数据挖掘,重新整合。

缺点

      1、ECharts出生在这个视觉爆炸的年代,竟然不支持3D,这一点百度前端设计团队需要向HighCharts学习。最起码像线、柱、堆叠这些老掉牙的图应该支持3D。

      2、目前还没研究echarts的源码,从下载的Demo和我自己Demo的过程中感觉,入门有点迷糊,需要引用zrender,貌似还基于Bootstrap。

      3、API 做的不和谐,以至于我看第一眼还没搞明白怎么个用法。 就拿单位来说事吧,看了Demo中,几乎没有一个tooltip后设置单位的,可见百度有点外行了,汇总型图表不加单位不是找骂呢? 让那些爱好数据的老古董怎么看呢?

      以上两点仅为个人体验看法,不喜勿喷,如有不同看法,很乐意一起学习讨论。

 

Demo步骤

      1、分别下载ECharts 和ZRender。 后者初始化时需要引用。

      2、引用esl.js。esl.js包含和引用了echarts初始化的一些方法。写法很新颖,第一次这么写。 

    <script src="/Scripts/echarts_2_0_4/doc/asset/js/esl/esl.js" type="text/javascript"></script>


      4、准备页面DOM容器,放个div, 宽度设置450就完事了。

      5、为模块加载器配置echarts路径和zrender路径。

require.config({
            packages: [
            {
                name: 'echarts',
                location: '/Scripts/echarts_2_0_4/src',
                main: 'echarts'
            }, {
                name: 'zrender',
                location: '/Scripts/zrender/src',
                main: 'zrender'
            }]
        });

      6、动态加载echarts为后续回调函数使用做准备。

require(
            [
                'echarts',
                'echarts/chart/line',
                'echarts/chart/bar'
            ]

      7、编写回调函数(也就是做你想看到的效果)

           从代码中可以看出,当我们完成准备工作以后就可以将剩余精力放在option上了,具体option选项就可以对照API来设置了,这点应该和highcharts差别不大,就是不太详细。

option = {
    title : {
        text: '未来一周气温变化',
        subtext: '纯属虚构'
    },
    tooltip : {
        trigger: 'axis'
    },
    legend: {
        data:['最高气温','最低气温']
    },
    toolbox: {
        show : true,
        feature : {
            mark : {show: true},
            dataView : {show: true, readOnly: false},
            magicType : {show: true, type: ['line', 'bar']},
            restore : {show: true},
            saveAsImage : {show: true}
        }
    },
    calculable : true,
    xAxis : [
        {
            type : 'category',
            boundaryGap : false,
            data : ['周一','周二','周三','周四','周五','周六','周日']
        }
    ],
    yAxis : [
        {
            type : 'value',
            axisLabel : {
                formatter: '{value} °C'
            }
        }
    ],
    series : [
        {
            name:'最高气温',
            type:'line',
            data:[11, 11, 15, 13, 12, 13, 10],
            markPoint : {
                data : [
                    {type : 'max', name: '最大值'},
                    {type : 'min', name: '最小值'}
                ]
            },
            markLine : {
                data : [
                    {type : 'average', name: '平均值'}
                ]
            }
        },
        {
            name:'最低气温',
            type:'line',
            data:[1, -2, 2, 5, 3, 2, 0],
            markPoint : {
                data : [
                    {name : '周最低', value : -2, xAxis: 1, yAxis: -1.5}
                ]
            },
            markLine : {
                data : [
                    {type : 'average', name : '平均值'}
                ]
            }
        }
    ]
};


function (ec) {
      var chart = ec.init(document.getElementById('main'));
       chart.setOption(option);
}

 

总结

     刚开始使用echarts只是为了解决视觉疲劳的问题,目前刚开始弄还有一些细节问题没有搞定,比如tooltip时单位如何设置、线、柱、堆叠图如何设置圆角,最起码官方的demo都是圆角的,还有待于继续学习和研究。如果有遇到这几个问题并有解决方案的朋友欢迎发邮件指点我下,谢谢。

 

myChart.setTheme(theme);
使用官方的theme就OK了。

 

 

 

 

 

 
 
 
 
 

转载于:https://www.cnblogs.com/Renyi-Fan/p/9201949.html

相关文章:

  • 第六章
  • Disruptor并发框架
  • Oracle基础学习(二) 存储过程和函数
  • (四)Linux Shell编程——输入输出重定向
  • RHEL6解决无法使用YUM源问题 {已验证切实可行}
  • .NET Core 中的路径问题
  • 太多脚本将会毁掉持续交付
  • java中的equals和==
  • Fcoin交易所的危险游戏!韭菜请远离!
  • mavne settings.xml
  • Ambari 2.6(HDP 2.6.5)安装记要
  • IP 地址 与 DNS
  • iOS 开发知识索引
  • 多线程多进程学习threading,锁,线程间数据状态读取。
  • Lombok使用详解(转)
  • Android开源项目规范总结
  • CentOS7简单部署NFS
  • es6(二):字符串的扩展
  • HTML中设置input等文本框为不可操作
  • JS数组方法汇总
  • mysql中InnoDB引擎中页的概念
  • Netty 框架总结「ChannelHandler 及 EventLoop」
  • niucms就是以城市为分割单位,在上面 小区/乡村/同城论坛+58+团购
  • passportjs 源码分析
  • PHP 使用 Swoole - TaskWorker 实现异步操作 Mysql
  • quasar-framework cnodejs社区
  • REST架构的思考
  • vue2.0项目引入element-ui
  • Vue--数据传输
  • 多线程 start 和 run 方法到底有什么区别?
  • 记一次用 NodeJs 实现模拟登录的思路
  • 使用API自动生成工具优化前端工作流
  • Java性能优化之JVM GC(垃圾回收机制)
  • ​总结MySQL 的一些知识点:MySQL 选择数据库​
  • (16)UiBot:智能化软件机器人(以头歌抓取课程数据为例)
  • (52)只出现一次的数字III
  • (C语言)逆序输出字符串
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (十)【Jmeter】线程(Threads(Users))之jp@gc - Stepping Thread Group (deprecated)
  • (十六)一篇文章学会Java的常用API
  • (一)使用IDEA创建Maven项目和Maven使用入门(配图详解)
  • (转)IOS中获取各种文件的目录路径的方法
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)
  • .babyk勒索病毒解析:恶意更新如何威胁您的数据安全
  • .NET MVC 验证码
  • .NET 编写一个可以异步等待循环中任何一个部分的 Awaiter
  • .net 调用php,php 调用.net com组件 --
  • .NET/C# 检测电脑上安装的 .NET Framework 的版本
  • .net6解除文件上传限制。Multipart body length limit 16384 exceeded
  • .net的socket示例
  • .net连接oracle数据库
  • .NET设计模式(11):组合模式(Composite Pattern)
  • /run/containerd/containerd.sock connect: connection refused
  • /usr/local/nginx/logs/nginx.pid failed (2: No such file or directory)
  • :“Failed to access IIS metabase”解决方法