1.echarts是什么?

关键字:data visualization,canvas,chart

Echarts是基于轻量级的canvas类库,纯javaScript实现,MVC封装,数据驱动,一款直观、生动,可交互,可个性化定制的数据图表。

2.为什么Echarts基于canvas类库?

svg与canvas是两个可以选择的类库之一,其中svg的交互性更好,性能较弱,不适用于移动端,在绘制数万个点时会崩溃;而canvas的渲染速度和性能更好,echarts在canvas上构建一层MVC层使得它可以像svg一样交互。

3.为什么说Echarts是基于轻量级的类库?

因为Echarts是纯javaScript实现,所以它是一个轻量级的产品,侵入性较小,依赖的东西少,也就是说在换掉框架时对项目影响比较小。

4.什么是数据驱动?

所谓数据驱动是指你只需做的是定义图形数据,就可以实现绘图。

5.Echarts的特点有哪些?

三个特点,重要性和优先级依次递减。

设计效果必须直观、生动;

能够交互;

可个性化定制.

6.为什么说Echarts是MVC封装?

Echarts总体结构是基于MVC架构的,各部分的主要作用是:

Storage(M):模型层,实现图形数据的增删改查(CURD)管理。

Painter(V):视图层,实现canvas元素的生命周期管理,即视图渲染、更新控制、绘图。

Handler(C):控制层,事件交互处理,实现完整的dom事件模拟封装。

从下面的代码片段可知,Storage是一个类似数据的仓库,提供各种数据的读、写、改、删等操作。Painter持有了Storage对象,也就是说结构图中视图层与模型层存在R(read)关系,即Painter需要读取Storage中的数据进行绘图。Handler持有了Storage对象和Painter对象,也就是结构图中控制层与模型层存在CURD关系,即Handler通过访问Storage对象提供的数据增删改查操作实现事件交互处理所需的数据部分;而结构图中控制层与视图层存在call关系,即Handler通过访问Painter对象提供的视图操作实现事件交互处理的视图部分。

Storage :

/**

* 内容仓库 (M)

* @alias module:zrender/Storage

* @constructor

*/

var Storage = function () {

this._roots = [];

this._displayList = [];

this._displayListLen = 0;

};

Painter :

/**

* @alias module:zrender/Painter

* @constructor

* @param {HTMLElement} root 绘图容器

* @param {module:zrender/Storage} storage

* @param {Object} opts

*/

var Painter = function (root, storage, opts) {

// In node environment using node-canvas

var singleCanvas = !root.nodeName // In node ?

|| root.nodeName.toUpperCase() === 'CANVAS';

this._opts = opts = util.extend({}, opts || {});

/**

* @type {number}

*/

this.dpr = opts.devicePixelRatio || config.devicePixelRatio;

/**

* @type {boolean}

* @private

*/

this._singleCanvas = singleCanvas;

/**

* 绘图容器

* @type {HTMLElement}

*/

this.root = root;

var rootStyle = root.style;

if (rootStyle) {

rootStyle['-webkit-tap-highlight-color'] = 'transparent';

rootStyle['-webkit-user-select'] =

rootStyle['user-select'] =

rootStyle['-webkit-touch-callout'] = 'none';

root.innerHTML = '';

}

/**

* @type {module:zrender/Storage}

*/

this.storage = storage;

/**

* @type {Array.<number>}

* @private

*/

var zlevelList = this._zlevelList = [];

/**

* @type {Object.<string, module:zrender/Layer>}

* @private

*/

var layers = this._layers = {};

/**

* @type {Object.<string, Object>}

* @type {private}

*/

this._layerConfig = {};

if (!singleCanvas) {

this._width = this._getSize(0);

this._height = this._getSize(1);

var domRoot = this._domRoot = createRoot(

this._width, this._height

);

root.appendChild(domRoot);

}

else {

if (opts.width != null) {

root.width = opts.width;

}

if (opts.height != null) {

root.height = opts.height;

}

// Use canvas width and height directly

var width = root.width;

var height = root.height;

this._width = width;

this._height = height;

// Create layer if only one given canvas

// Device pixel ratio is fixed to 1 because given canvas has its specified width and height

var mainLayer = new Layer(root, this, 1);

mainLayer.initContext();

// FIXME Use canvas width and height

// mainLayer.resize(width, height);

layers[0] = mainLayer;

zlevelList.push(0);

this._domRoot = root;

}

// Layers for progressive rendering

this._progressiveLayers = [];

/**

* @type {module:zrender/Layer}

* @private

*/

this._hoverlayer;

this._hoverElements = [];

};

Handler :

/**

* @alias module:zrender/Handler

* @constructor

* @extends module:zrender/mixin/Eventful

* @param {module:zrender/Storage} storage Storage instance.

* @param {module:zrender/Painter} painter Painter instance.

* @param {module:zrender/dom/HandlerProxy} proxy HandlerProxy instance.

* @param {HTMLElement} painterRoot painter.root (not painter.getViewportRoot()).

*/

var Handler = function(storage, painter, proxy, painterRoot) {

Eventful.call(this);

this.storage = storage;

this.painter = painter;

this.painterRoot = painterRoot;

proxy = proxy || new EmptyProxy();

/**

* Proxy of event. can be Dom, WebGLSurface, etc.

*/

this.proxy = proxy;

// Attach handler

proxy.handler = this;

/**

* {target, topTarget}

* @private

* @type {Object}

*/

this._hovered = {};

/**

* @private

* @type {Date}

*/

this._lastTouchMoment;

/**

* @private

* @type {number}

*/

this._lastX;

/**

* @private

* @type {number}

*/

this._lastY;

Draggable.call(this);

util.each(handlerNames, function (name) {

proxy.on && proxy.on(name, this[name], this);

}, this);

};

相关连接:

1.http://www.cnblogs.com/hhstuhacker/p/zrender-source-advance-frame.html

2.zrender介绍:  http://ecomfe.github.io/zrender/

3.大数据可视化应用:dataV,    https://data.aliyun.com/visual/datav?spm=5176.8142029.388261.76.9CzYBB

4.echarts官网:  http://echarts.baidu.com/index.html

echarts研究的更多相关文章

  1. echarts 点亮中国插件研究

    echarts 真的是个神奇的东西,最近做了一个需要点亮中国的移动端项目,前期就怎样点亮中国做了调研,发现微博当初炫酷的点亮效果就是用echarts做的,于是研究了一下. 一连研究了一堆demo,不管 ...

  2. 你不知道的echarts,前端鲍哥带你研究!

    前言 相信不少前端小伙伴刚接触 e-charts 肯定有点陌生,但是echarts咱不清楚,charts我们应该很熟悉,没错,echarts 就是我们日常可见的图表,不同的是 echarts 是用代码 ...

  3. ECharts学习(4)--仪表盘

    1. ECharts中的仪表盘,要使用这个图表时把series中的type属性修改成'gauge',然后在detail中设置仪表盘详情,用于显示数据.最常用的是formatter(格式化函数或者字符串 ...

  4. 百度eCharts体验

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

  5. Echarts 页面多图自适应的解决办法 (转)

    项目中用到了echarts的多图表的 问题,如果设置了 window.onresize  = option.chart.resize() 只能控制 某个图表的 自适应,如果要是页面上的图表都要自适应. ...

  6. Echarts 地图(map)插件之 鼠标HOVER和tooltip自定义提示框

    [自行修改 "引号"] 一.鼠标HOVER时的事件: 参照官方文档解释, 可以看出这款插件有丰富的鼠标事件可供选择: 调用鼠标HOVER事件的方法很简单,只需把以下代码放到char ...

  7. 插件~使用ECharts动态在地图上标识点~动态添加和删除标识点

    之前写过一个Echarts的文章,没有基础的同学可以先看这<上一篇>,对于一个地图和说,我们在初始化之后,你可能被在地图上标识出一些点,当然这根据你的业务去标识,而如果每次更新数据都加载全 ...

  8. 一个让echarts中国地图包含省市轮廓的技巧

    背景知识及应用简介 本文主要介绍一个使用ECharts地图组件的取巧方法,该技巧源于实际需求中遇到的问题,一般没有该需求的话这个技巧也是用不到的.有前端基础和以及对ECharts有了解的人基本可以读懂 ...

  9. echarts简单使用

    最近在做一个项目,开始使用的是acharts,在电脑端访问的效果还真不错,但是放到手机端访问就惨了,尤其是iOS系统上,各种不兼容,后来准备换收费的hightcharsts,无意间发现有个免费的ech ...

随机推荐

  1. oracle 查询数据库的各种命令

    以下查询都是使用plsql查询oracle 11g 1.查询数据库版本信息 select * from v$version; 2.查询数据库优化模式 select name, value from v ...

  2. Access-Control-Allow-Origin跨域请求处理

    今天在看新项目的时候,发现很多的   Controller 中都有一个 response.setHeader("Access-Control-Allow-Origin"," ...

  3. Java入门:基础算法之二进制转换为十进制

    Java有两种方法可以将二进制数转换为十进制数: 1)使用Integer类的Integer.parseInt()方法. 2)自己编写转换逻辑. 方法1:使用Integer.parseInt()实现二进 ...

  4. <五>企业级开源仓库nexus3实战应用–使用nexus3配置npm私有仓库

    一两个星期之前,你如果在我跟前说起私服的事情,我大概会绕着你走,因为我对这个东西真的一窍不通.事实上也正如此,开发同学曾不止一次的跟我说公司的私服版本太旧了,许多新的依赖编译之后不会从远程仓库自动缓存 ...

  5. JavaScript数据类型 String字符串类型

    前言 javascript没有表示单个字符的字符型,只有字符串String类型,字符型相当于仅包含一个字符的字符串 字符串String是javascript基本数据类型,同时javascript也支持 ...

  6. html设置背景图片并自适应

    <style> html{ height:100%; } body{ padding: 0; margin: 0; background: url(images/2.jpg); backg ...

  7. Webform--LinQ 分页组合查询

    一.linq高级查 1.模糊查(字符串包含) public List<User> Select(string name) { return con.User.Where(r => r ...

  8. 用Navicat连接阿里云ECS服务器上的MySQL数据库

    今天用navtive连接阿里云服务器(Linux)的数据库时,老是连接不上,并且报10060错误,要通过以下两个步骤解决: 1.先进入linux连接数据库并输入密码: mysql -uroot -p ...

  9. Stm32复习之时钟系统

    地点:南图 这部分的内容是整个STM32学习知识的核心,不管是什么微控制器处理器,时钟系统都是其核心类似于人之心脏,因此学好理解这一章节至关重要. 为了便于理解这一系统,将从以下几个层次来讲.(忘了是 ...

  10. Bootstrap3 模态框 select2搜索框无法输入

    <div class="modal fade" role="dialog" aria-hidden="true" data-backd ...