AngularJS引入Echarts的Demo

最近要用到图表展示,想了想,还是首选Echarts,HighCharts和D3.js备用吧,

而项目中也用到了AngularJS,所以需要把Echarts引入到AngularJs中一起使用,

试了试,最方便的还是用指令,(虽然指令有点不好调,用了再说)。

1、引入angular.js 

2、引入echarts.js

3、引入jquery.js---可以省略

4、直接上代码:

  1 <!DOCTYPE html >
  2   <head>
  3     <meta charset="utf-8">
  4     <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  5     <title>Echarts--柱状图与饼图</title>    
  6     <link rel="stylesheet" href="../jc/jquery-ui.css">
  7      <script type="text/javascript" src="../jc/jquery.min.js"></script>
  8     <script type="text/javascript" src="../jc/jquery-ui.min.js"></script>
  9     <script type="text/javascript" src="../jc/angular.min.js"></script>
 10       <script type="text/javascript" src="../3rd/echarts/echarts.js"></script>
 11       <style>
 12           html{
 13               height:100%;
 14           }
 15           
 16       </style>
 17   </head>
 18 
 19   <body data-ng-app="MyApp" style="height:100%;">
 20     <div data-ng-controller='MyCtrl' style="width: 100%;height: 100%;">
 21     <h3>Echarts柱状图与饼图---指令directive</h3>        
 22     
 23     <div align="center" style="width: 80%; height:100%;"> 
 24         <div align="left">
 25             <select data-ng-model="chart"
 26             data-ng-options="x for (x, y) in myCharts"
 27             data-ng-change = "showChange(chart)"
 28             >
 29             </select>        
 30         </div>
 31         
 32         <div data-ng-show="show" bar-charts  data-source='groupData' style="width: 100%;height: 80%;"></div>
 33         <div data-ng-show="!show" pie-charts  data-source='group' data-ng-repeat="group in groupData" 
 34                 style="width: 30%;height:30%;float: left;">
 35         </div>
 36     </div>
 37     </div>
 38     <script>
 39       angular.module('MyApp', [])
 40       .controller('MyCtrl', function($scope) {
 41           $scope.groupData = ['测试栏目1','测试栏目2','测试栏目3','测试栏目4','测试栏目5','测试栏目6']; 
 42           $scope.chart = 0;
 43           $scope.show = true;
 44           $scope.myCharts = {
 45                 "柱状图":0,
 46                 "饼图":1
 47           };
 48           $scope.showChange = function(chart){
 49               if(chart==0){
 50                    $scope.show = true;
 51               }else{
 52                   $scope.show = false;
 53               }    
 54             };
 55       })
 56       .directive('barCharts',function(){
 57         return{
 58             restrict:'AE',              
 59               scope :{
 60                   source:'='
 61               },
 62               template:'<div>这是柱图</div>',
 63               controller: function($scope){
 64               },
 65               link:function(scope,element,attr){
 66                   console.log(scope.source);
 67                   var chart =  element.find('div')[0];
 68                   var parent = element['context'];
 69               //    console.log(parent.clientHeight+":"+parent.clientWidth);
 70                   chart.style.width =parent.clientWidth+'px';
 71                   chart.style.height =parent.clientHeight+'px';
 72                   
 73                   var myChart = echarts.init(chart);
 74                   var option = {
 75                         title:{
 76                             text:'工作空间使用情况'
 77                         },
 78                         tooltip:{
 79                             trigger:'axis',
 80                             axisPointer:{
 81                                 type:'shadow'
 82                             }
 83                         },
 84                         legend: {
 85                             //data:['正常','警告','预警','剩余']
 86                         },
 87                         gird:{
 88                             left: '5%',
 89                             right: '5%',
 90                             bottom: '5%',
 91                             containLabel: true
 92                         },
 93                         xAxis:{
 94                             type:'value'
 95                         },
 96                         yAxis:{
 97                             type: 'category',
 98                             data: scope.source  //['测试栏目1','测试栏目2','测试栏目3','测试栏目4','测试栏目5','测试栏目6']
 99                         },
100                         series:[
101                             {
102                                 name:'已使用',
103                                 type:'bar',
104                                 stack:'存储空间',
105                                 label:{
106                                     normal:{
107                                         show:true,
108                                         position:'insideRight'
109                                     }
110                                 },
111                                 barWidth:'80%',
112                                 data:[100,200,300,260,50,120]
113                             },
114                             {
115                                 name:'剩余',
116                                 type:'bar',
117                                 stack:'存储空间',
118                                 label:{
119                                     normal:{
120                                         show:true,
121                                         position:'insideRight'
122                                     }
123                                 },
124                                 barWidth:'80%',
125                                 data:[200,100,2,80,200,180]
126                             }
127                         ]
128                     };
129                   myChart.setOption(option);
130                   myChart.resize();
131               }
132         };  
133       })
134       .directive('pieCharts',function(){
135           return{
136                 restrict:'AE',              
137                   scope :{
138                       source:'='
139                   },
140                   template:'<div>这是饼图</div>',
141                   controller: function($scope){
142                   },
143                   link:function(scope,element,attr){
144                       
145                       var chart =  element.find('div')[0];
146                       var parent = element['context'];
147                       //console.log(parent.clientHeight+":"+parent.clientWidth);
148                       chart.style.width =parent.clientWidth+'px';
149                       chart.style.height =parent.clientHeight+'px';
150                       
151                       var myChart = echarts.init(chart);
152                        var option = {
153                           backgroudColor:'#F2F2F2',
154                            title : {
155                               text: '某一个栏目',
156                               x:'center',
157                               y:'bottom'
158                           },
159                           tooltip:{
160                               trigger:'item',
161                               formatter:'{a}<br/>{b} {c}({d}%)'
162                           },
163                           series:[
164                                 {
165                                     name:'空间使用',
166                                     type:'pie',
167                                     radius:'55%',
168                                     center:['50%','60%'],
169                                     data:[
170                                         {value:50,name:'已使用'},
171                                         {value:450,name:'未使用'}
172                                     ],
173                                     itemStyle:{
174                                         emphasis: {
175                                             shadowBlur: 10,
176                                             shadowOffsetX: 0,
177                                             shadowColor: 'rgba(0, 0, 0, 0.5)'
178                                         }
179                                     }
180                                 }
181                           ]
182                        };
183                       myChart.setOption(option);
184                       myChart.resize();
185                   }
186           };
187       });
188     </script>
189   </body>
190 
191 </html>

一个Demo,就不按格式写了!

以上!

自定义数据展示颜色:

series:[
{
name:'已使用',
type:'bar',
stack:'存储空间',
label:{
normal:{
show:true,
position:'insideRight'
}
},
barWidth:'80%',
data:[
{
value:100,
itemStyle:{
normal:{
color: 3>2 ? '#CDCD19':'#00FA67'
}
}
},
{
value:200,
itemStyle:{
normal:{
color: 1>2 ? '#CDCD19':'#00FA67'
}
}
},

{
value:300,
itemStyle:{
normal:{
color: 3>2 ? '#CDCD19':'#00FA67'
}
}
},
{
value:260,
itemStyle:{
normal:{
color: 1>2 ? '#CDCD19':'#00FA67'
}
}
},
50,120]
},
{
name:'剩余',
type:'bar',
stack:'存储空间',
label:{
normal:{
show:true,
position:'insideRight'
}
},
itemStyle:{
normal:{
color:'#CBCBCB'
}
},
barWidth:'80%',
data:[200,100,2,80,200,180]
}
]

-------------------------------

series:[
{
name:'空间使用',
type:'pie',
radius:'55%',
center:['50%','60%'],
data:[
{value:50,name:'已使用',itemStyle:{
normal:{
color:'#324A5B'
}
}},
{value:450,name:'未使用',itemStyle:{
normal:{
color:'#C13530'
}
}}
],
itemStyle:{
emphasis: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
}
}
]

 

posted @ 2016-09-05 17:12  凉城  阅读(20601)  评论(9编辑  收藏  举报