简单介绍:前端
俗话说,一图胜千言。图形化的信息可让人们对数据有更加直观清晰的理解,让信息发布者更加高效地展现本身的核心内容。在前端开发中,若是缺乏合适工具,制做数据可视化图表会十分复杂。然而随着数据可视化概念逐年火热,有较多优秀的图表开源库和制做工具脱颖而出。下面,咱们就拿其中比较有名的 14个产品进行简要介绍git
可视工具:github
AnyChart(http://www.anychart.com/ )
AnyChart 是基于 Flash/JavaScript(HTML5) 的图表解决方案,它能够轻松地跨浏览器、跨平台工做。除了基础的图表功能外,它还有收费的交互式图表和仪表功能。它能够经过 XML 格式获取数据,该方式让开发人员很是灵活地控制图表上的每个数据点,而当图表数据点数量偏大时,则能够采用 CSV 数据输入,减少数据文件大小和图表加载时间。编程
AmCharts(http://www.amcharts.com/ )
AmCharts 是一款高级图表库,致力于对 Web 上的数据可视化提供支持。它所支持的图表包括柱状图、条状图、线图、蜡烛图、饼图、雷达、极坐标图、散点图、燃烧图和金字塔图等等。amCharts 库是一款彻底独立的类库,在应用中不依赖任何其余第三方类库,就可直接编译运行。除了提供最基本的规范要素外,amCharts 还提供了交互特性。用户在浏览基于 amCharts 制做的图表时,用鼠标 hover 图表内容,能够与其进行交互,使图表展现细节信息,其中呈现信息的容器被叫作 Balloon(气球)。除此以外图表能够动态动画的形式被绘制出来,带来了了很是好的展现效果。canvas
Cesium(http://cesiumjs.org/ )
Cesium 一样专一于地理数据可视化,它是一个 Javascript 库,能够在 Web 浏览器中绘制 3D/2D 地球。无需任何插件便可基于 WebGL 来进行硬件加速。除此以外,它还有跨平台、跨浏览器的特性。Cesium 自己基于 Apache 开源协议,支持商业及非商业项目。浏览器
Chart.js(https://gionkunz.github.io/chartist-js/ )
Chartist.js 是一个很是简单并且实用的 JavaScript 图表生成工具,它支持 SVG 格式,图表数据转换灵活,同时也支持多种图表展示形式。在工程中,Chartist.js 的 CSS 和 JavaScript 分离,所以代码比较简洁,在应用时配置流程十分简单。它生成的是响应式图表,能够自动支持不一样的浏览器尺寸和分辨率,更多的是,它也支持自定义 SASS 架构。网络
D3.js(http://vis.stanford.edu/papers/d3 )
2011年,Mike Bostock、Vadim Ogievetsky 和 Jeff Heer 发布了 D3,它是目前 Web 端评价最高的 Javascript 可视化工具库。D3 可以向用户提供大量线性图和条形图以外的复杂图表样式,例如 Voronoi 图、树形图、圆形集群和单词云等等。它的优势是实例丰富,易于实现调试数据同时可以经过扩展实现任何想到的数据可视化效果,缺点是学习门槛比较高。与 jQuery 相似,D3 直接对 DOM 进行操做,这是它与其它可视化工具的主要区别所在:它会设置单独的对象以及功能集,并经过标准 API 进行 DOM 调用。架构
echarts(http://echarts.baidu.com/ )
一款免费开源的数据可视化产品,给用户提供直观、生动、可交互和可个性化定制的数据可视化图表。Echarts 上手简单。其具备的拖拽重计算、数据视图、值域漫游等特性大大加强了用户体验,帮助用户在对数据挖掘、整合时大幅提升效率。同时,Echarts 提供了丰富的图表类型,除了常见的折柱饼,还支持地图、力导向图、treemap、热力图、树图等等。更惊艳的是,它还支持任意维度的堆积和多图表混合展示。总而言之,这是一款让咱们很是惊喜的可视化产品,很是强大,不过他图表不是很美观,对移动端的支持也还有些欠缺,不过这些问题在官方最新发布的3.0 beta中获得了很大改善。echarts
Flot(http://www.flotcharts.org/ )
Flot 是一个纯 Javascript 绘图库,做为 jQuery 的插件使用。它能够较为轻松地跨浏览器工做,甚至包括 IE6。由于 jQuery 的特性,开发者能够全面地控制图表的动画、交互,把数据的呈现过程优化得更加完美。框架
FusionCharts(http://www.fusioncharts.com/ )
FusionCharts Free 是可跨平台、跨浏览器的 Flash 图表解决方案,它可以被 ASP、.NET、PHP、JSP、ColdFusion、Ruby on Rails、简单 HTML 页面甚至 PPT 调用。在使用过程当中,用户原则上并不须要知道任何 Flash 的知识,只须要了解你所用的编程语言,并进行简单的调用便可以实现应用。
Google Charts (https://developers.google.com/chart/)
有没有必要过多的介绍这里谷歌图表。 我相信大多数读者都熟悉这个工具,它是功能强大,易于使用,并且免费。
HighCharts( http://www.highcharts.com )
HighCharts是一个流行的JavaScript图表库。 它提供了一个简单易用的方式,以互动的图表(S)添加到您的网站或Web应用程序。 输出在现代浏览器和VML在Internet Explorer中使用SVG渲染。 图表精美动画眼帘自动,该框架还支持实时数据流。 更重要的是,它是免费下载和使用非商业(以及可受权用于商业用途)。 目前,它支持线,样条曲线,面积,areaspline,柱形图,条形图,饼图,散点图,角规,arearange,areasplinerange,columnrange,气泡,箱形图,偏差线,漏斗,瀑布和极地图表类型。
Leaflet (http://leafletjs.com/ )
Leaflet是一个开源的JavaScript库,在全部主要的桌面和移动平台的做品。 单张使得它易于使用OpenStreetMap的数据,并在HTML5 / CSS3包装彻底集成交互式数据可视化。 这是很是轻(仅为33KB),并有不少的功能做出任何种类的地图。 所以,经常被用于须要展现地理位置的项目。
MetricsGraphics( http://metricsgraphicsjs.org/ )
MetricsGraphics.js 是一个基于 D3,为可视化和时间序列化的数据而优化的库。它提供了一种便捷的方法,用一致且响应式方式来产生相同类型的图形。它如今支持折线图、散点图、直方图、地毯图和基本的线性回归图。同时,它体积很是小巧,一般能够控制在 60kb 以内。
Sigma.js( http://sigmajs.org ) Sigma.js是一个JavaScript库,这是专门为使用HTML5 canvas元素绘制图表。 这使得轻松地发布在网页上网络,并容许开发人员在富Web应用程序的网络整合的探索。 西格玛提供了不少不一样的设置来轻松地自定义绘图的方式。 此外,公共的API,开发人员能够扩大如何与网络交互的可能性越大(如修改数据,移动相机,刷新渲染,监听事件)。