angularf封装echarts

前言: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)
<ng-echarts class="col-md-6 echarts" ec-config="lineConfig" ec-option="lineOption"></ng-echarts>
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                 //自定义参数 - config
31                 // event 定义事件
32                 // theme 主题名称
33                 // dataLoaded 数据是否加载
34 
35                 scope.$watch(
36                     function () { return scope.config; },
37                     function (value) {if (value) {refreshChart();}},
38                     true
39                 );
40 
41                 //图表原生option
42                 scope.$watch(
43                     function () { return scope.option; },
44                     function (value) {if (value) {refreshChart();}},
45                     true
46                 );
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 

 
posted @ 2017-09-10 23:41  给你添麻烦了  阅读(4012)  评论(0编辑  收藏  举报