Fork me on GitHub

Echarts环形图、折线图通过ajax动态获取数据

环形图

 1 (function(){
 2     var myChart = echarts.init(document.getElementById("index-pie-1"));
 3      option = {
 4         tooltip: {
 5             trigger: 'item',
 6             formatter: '{a} <br/>{b}: {c} ({d}%)'
 7         },
 8         legend: {
 9             orient: 'vertical',
10             left: 0,
11             data: []
12         },
13         series: [
14             {
15                 name: '用户来源',
16                 type: 'pie',
17                 left:90,
18                 radius: ['50%', '70%'],
19                 avoidLabelOverlap: false,
20                 label: {
21                     show: false,
22                     position: 'center'
23                 },
24                 emphasis: {
25                     label: {
26                         show: true,
27                         fontSize: 20,
28                         fontWeight: 'bold'
29                     }
30                     },
31                 labelLine: {
32                     show: false
33                 },
34                 data: []
35             }
36             ]
37     };
38     myChart.showLoading();
39     $.ajax({
40         type: 'get',
41         url: 'json/chart/column/getData',//请求数据的地址
42         dataType: "json",        //返回数据形式为json
43         success: function (gameData) {
44             //请求成功时执行该函数内容,result即为服务器返回的json对象
45             $.each(gameData,function (key,item) {
46                 var newArr = {};
47                 newArr.value = item.value;
48                 newArr.name = item.name;
49                 option.legend.data.push(item.name);
50                 option.series[0].data.push(newArr);
51             });
52             myChart.hideLoading();
53             myChart.setOption(option);
54         }
55     });
56 })();

 

折线图

/*(function(){
    var myChart = echarts.init(document.getElementById("widget-chart-box-1"));
    var myChart2 = echarts.init(document.getElementById("widget-chart-box-2"));

    var labelTop = {

        normal : {
            label : {
                show : true,
                position : 'center',
                formatter : '{b}',
                textStyle: {
                    baseline : 'bottom'
                }
            },
            labelLine : {
                show : false
            }

        }
    };
    var labelFromatter = {
        normal : {
            label : {
                formatter : function (params){
                    return 100 - params.value + '%'
                },
                textStyle: {
                    baseline : 'center'
                }
            }
        },
    }
    var labelBottom = {
        normal : {
            color: '#ccc',
            label : {
                show : true,
                position : 'center'
            },
            labelLine : {
                show : false
            }
        },
        emphasis: {
            color: '#ccc'
        }
    };
    var radius = [40, 35];
    option = {



        legend: {
            x : 'center',
            y : 'center',

        },

        grid: {
            x:0,
            y:0,
            x2:0,
            y2:0
        },

        toolbox: {
            show : true,
            feature : {
                magicType : {
                    show: true,
                    type: ['pie', 'funnel'],
                    option: {
                        funnel: {
                            width: '20%',
                            height: '30%',
                            itemStyle : {
                                normal : {
                                    label : {
                                        formatter : function (params){
                                            return 'other\n' + params.value + '%\n'
                                        },
                                        textStyle: {
                                            baseline : 'middle'
                                        }
                                    }
                                },
                            }
                        }
                    }
                }

            }
        },
        series : [
            {
                type : 'pie',

                radius : radius,
                x: '0%', // for funnel
                itemStyle : labelFromatter,
                data : [
                    {name:'111', value:46, itemStyle : labelBottom},
                    {name:'', value:54,itemStyle : labelTop}
                ]
            }

        ],
        animation :false
    };


    myChart.setOption(option);
    myChart2.setOption(option);
})();*/
/*折线图*/
(function(){
    var myChart = echarts.init(document.getElementById("index-line-1"));

    option1 = {
        tooltip: {
            trigger: 'axis'
        },
        legend: {
            data: []
        },
        grid: {
            left: '3%',
            right: '4%',
            bottom: '3%',
            containLabel: true
        },
        toolbox: {
            feature: {
                saveAsImage: {}
            }
        },
        xAxis: {
            type: 'category',
            boundaryGap: false,
            data: []
        },
        yAxis: {
            type: 'value'
        },
        series: []
    };
    myChart.showLoading();
    $.ajax({
                type: 'get',
                url: 'json/chart/column/getData',//请求数据的地址
                dataType: "json",        //返回数据形式为json
                success: function (gameData) {
                    //请求成功时执行该函数内容,result即为服务器返回的json对象
                    var x = gameData.week;
                    var game_data = gameData.weekdata;
                    $.each(x,function (key,item) {
                        option1.xAxis.data.push(item.date_start);
                    });
                    $.each(game_data,function (key,item) {
                        option1.legend.data.push(item.name);
                        var newArr = {};
                        newArr.name = item.name;
                        newArr.type = 'line';
                        newArr.stack = '总量';
                        newArr.data = item.data;
                        option1.series.push(newArr);
                    });

                    myChart.hideLoading();
                    myChart.setOption(option1);
                 }
         });
})();

其实方法很简单。有问题可以私信博主,q-760106033    v-Autumn123O  (v最后一个字母哦大写,不是零0)

posted @ 2020-03-28 11:49  君乐豹  阅读(901)  评论(0编辑  收藏  举报
Live2D