前言:angular中快速使用echarts
在html使用ehart很简单,你只需要引入文件和按照官方例子按照对应参数配置和数据填充就Ok了,那么在angular中怎么使用eharts(可以使用echarts3),你只需要去看个官方提供的demo,大致知道图形通过做哪些事构建出来的就行。
步骤:
1.知道大致流程,这里你可以官网直接去gitup地址,上面有angular echarts的使用方法的介绍,我三个都看了觉得最三个最容易看懂且代码也比较少,克隆下来看里面代码很快就明白了。
2.引入文件到项目中
1)你可以使用npm i ng-echarts --save-dev,然后在task任务中打包,相应地方require引入。
2)通过下载js文件外部引入(博主一般将插件都外部引入放在lib目录中)
你在gitup克隆下来的demo中js文件复制到lib的echarts下,macarons.js是一个主题文件,你需要在官网中的主题文件下载中下载你对应的主题。
3.在gulp任务中将引入的文件打包
gulp.task('build-lib-js', ['build-clean-third-lib-js'], function () { var thirdLibJs = gulp.src([//外部引用js './lib/bootstrap/js/bootstrap.min.js', './lib/echarts/echarts.min.js', './lib/echarts/macarons.js', ]) .pipe(concat('lib.min.js', {newLine: '\r\n'})) .pipe(gulp.dest('js')); return merge.apply(null, thirdLibJs); });
4.使用方法 1).html模块 ec-option:echarts中的option ec-config:其他参数的配置项 * theme:图表主题名称, * event:绑定事件 * dataLoaded:数据是否加载(用于Loading)
2)自定义组件模块
1 angular.module('ng-echarts',[]) 2 .directive('ngEcharts',[function(){ 3 return { 4 link: function(scope,element,attrs,ctrl){ 5 function refreshChart(){ 6 var theme = (scope.config && scope.config.theme) 7 ? scope.config.theme : 'default'; 8 var chart = echarts.init(element[0],theme); 9 if(scope.config && scope.config.dataLoaded === false){10 chart.showLoading();11 }12 13 if(scope.config && scope.config.dataLoaded){14 chart.setOption(scope.option);15 chart.resize();16 chart.hideLoading();17 }18 19 if(scope.config && scope.config.event){20 if(angular.isArray(scope.config.event)){21 angular.forEach(scope.config.event,function(value,key){22 for(var e in value){23 chart.on(e,value[e]);24 }25 });26 }27 }28 };29 30 //自定义参数 - config31 // event 定义事件32 // theme 主题名称33 // dataLoaded 数据是否加载34 35 scope.$watch(36 function () { return scope.config; },37 function (value) { if (value) {refreshChart();}},38 true39 );40 41 //图表原生option42 scope.$watch(43 function () { return scope.option; },44 function (value) { if (value) {refreshChart();}},45 true46 );47 },48 scope:{49 option:'=ecOption',50 config:'=ecConfig'51 },52 restrict:'EA'53 }54 }]);
3)controller模块(配置参数和加载数据) 你可以根据官方例子将数据更改为接口获取,将配置项根据需要修改参数,参数具体参考
.controller('Ctrl1',function($scope,$interval,$timeout){ function onClick(params){ console.log(params); }; $scope.lineConfig = { theme:'default',//主题 event: [{click:onClick}],//触发事件 dataLoaded:true//数据是否加载 }; $scope.lineOption = { title : { //标题 text: '未来一周气温变化(5秒后自动轮询)', 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 : [//x轴 { type : 'category', boundaryGap : false, data : ['周一','周二','周三','周四','周五','周六','周日'] } ], yAxis : [//y轴 { 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 : '平均值'} ] } } ] }; })
-----原创文章,©版权所有,转载请注明标明出处:http://www.cnblogs.com/doinbean