ECharts柱状图或者折线图方法封装

前台界面样式

bar.png
line.png
pie.png
  • 样式代码
<!DOCTYPE html>
<html>

    <head>
        <meta charset="utf-8" />
        <title>首页</title>

        <script type="text/javascript" src="js/echarts.js"></script>

        <script type="text/javascript" src="js/jquery.js"></script>

        <style>
            .page {
                display: flex;
                flex-wrap: wrap;
                width: 100%;
                height: 100%;
                overflow-y: auto;
            }
            
            .red {
                background-color: #FF5722;
            }
            
            .green {
                background-color: #009688;
            }
            
            .blue {
                background-color: #1E9FFF;
            }
            
            .yellow {
                background-color: #FFB800;
            }
            
            .index-module {
                display: flex;
                flex-direction: column;
                width: 32rem;
                height: 30rem;
                margin: 1rem;
                box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
            }
            
            .big-module {
                width: 56rem;
            }
            
            .index-module-title {
                padding: 1rem;
                color: #fff;
                font-family: '楷体';
                font-weight: bold;
            }
            
            .index-module-content {
                height: calc(100% - 50px);
            }
            
            .index-Chart {
                height: calc(100% - 1rem);
                padding: 0.5rem;
            }
        </style>
    </head>

    <body>
        <div class="page">

            <!--
                从后台获取数据(通用方法)
            -->
            <div class="index-module big-module">
                <div class="index-module-title red">
                    <span id="Common1"></span>
                </div>
                <div class="index-module-content">
                    <div id="CommonData1" class="index-Chart">
                    </div>
                </div>
            </div>
            
            <div class="index-module big-module">
                <div class="index-module-title red">
                    <span id="Common2"></span>
                </div>
                <div class="index-module-content">
                    <div id="CommonData2" class="index-Chart">
                    </div>
                </div>
            </div>
            
            <div class="index-module">
                <div class="index-module-title red">
                    <span id="Common3"></span>
                </div>
                <div class="index-module-content">
                    <div id="CommonData3" class="index-Chart">
                    </div>
                </div>
            </div>


        </div>
    </body>

</html>
  • JS方法(需引用echarts.js和jquery.js)
    /**
     * ECharts柱状图,折线图,扇图通用方法
     * @param {Object} id DOM容器id
     * @param {Object} title DOM标题id
     * @param {Object} url
     */
    function MyECharts(id, title, url) {
        // 基于准备好的dom,初始化echarts实例
        var myChart = echarts.init(document.getElementById(id));

        //数据
        $.ajax({
            url: url,
            success: function(data) {
                data = JSON.parse(data);

                $("#" + title).html(data.text);
                var option = new Object();
                switch(data.type) {
                    case 'line':
                        option = {
                            title: {
                                text: data.text,
                                subtext: data.subtext,
                                x: 'center'
                            },
                            legend: {
                                left: 'right',
                                orient: 'vertical',
                                align: 'right'

                            },
                            tooltip: {},
                            dataset: {
                                // 提供一份数据。
                                dimensions: data.dimensions,
                                source: data.source
                            },
                            // 声明一个 X 轴,类目轴(category)。默认情况下,类目轴对应到 dataset 第一列。
                            xAxis: {
                                type: 'category'
                            },
                            // 声明一个 Y 轴,数值轴。
                            yAxis: {},
                            // 声明多个 bar 系列,默认情况下,每个系列会自动对应到 dataset 的每一列。
                            series: data.series
                        };
                        break;
                    case 'bar':
                        option = {
                            title: {
                                text: data.text,
                                subtext: data.subtext,
                                x: 'center'
                            },
                            legend: {
                                left: 'right',
                                orient: 'vertical',
                                align: 'right'

                            },
                            tooltip: {},
                            dataset: {
                                // 提供一份数据。
                                dimensions: data.dimensions,
                                source: data.source
                            },
                            // 声明一个 X 轴,类目轴(category)。默认情况下,类目轴对应到 dataset 第一列。
                            xAxis: {
                                type: 'category'
                            },
                            // 声明一个 Y 轴,数值轴。
                            yAxis: {},
                            // 声明多个 bar 系列,默认情况下,每个系列会自动对应到 dataset 的每一列。
                            series: data.series
                        };
                        break;
                    case 'pie':
                        // 指定图表的配置项和数据
                        option = {
                            title: {
                                text: data.text,
                                subtext: data.subtext,
                                x: 'center'
                            },
                            tooltip: {
                                trigger: 'item',
                                formatter: "{a} <br/>{b} : {c} ({d}%)"
                            },
                            legend: {
                                left: 'right',
                                orient: 'vertical',
                                align: 'right'

                            },
                            series: [{
                                name: data.text,
                                type: 'pie',
                                radius: '55%',
                                center: ['50%', '60%'],
                                data: data.source,
                                itemStyle: {
                                    emphasis: {
                                        shadowBlur: 10,
                                        shadowOffsetX: 0,
                                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                                    }
                                }
                            }]
                        };
                        break;
                    default:

                }

                // 使用刚指定的配置项和数据显示图表。
                myChart.setOption(option);
            },
            error: function() {
                //alert("error");
            }
        })
    }
//调用例子
MyECharts("CommonData1", "Common1", "/DataBind.ashx?method=GetCommonDataListbar");

MyECharts("CommonData2", "Common2", "/DataBind.ashx?method=GetCommonDataListline");

MyECharts("CommonData3", "Common3", "/DataBind.ashx?method=GetCommonDataListpie");

  • C#后台数据封装方法
        /// <summary>
        /// ECharts数据转化
        /// </summary>
        /// <param name="type">图表类型:line折线图,bar柱状图,pie扇图(扇图不能有多列)</param>
        /// <param name="dt">数据</param>
        /// <param name="text">标题</param>
        /// <param name="subtext">备注</param>
        /// <returns></returns>
        public static string EChartsToJson(string type,DataTable dt,string text,string subtext)
        {
            StringBuilder jsonBuilder = new StringBuilder();
            StringBuilder series = new StringBuilder();//数据列
            StringBuilder dimensions = new StringBuilder();
            int Columns = dt.Columns.Count;
            if (type == "pie")
            {
                series.Append("null");
            }
            else
            {
                series.Append("[");
                for (int i = 0; i < Columns - 1; i++)
                {
                    series.Append("{");
                    series.AppendFormat("\"type\":\"{0}\"", type);
                    series.Append("}");
                    series.Append(",");
                }
                series.Remove(series.Length - 1, 1);
                series.Append("]");
            }
            

            dimensions.Append("[");
            for (int i = 0; i < Columns; i++)
            {
                dimensions.Append("\"" + dt.Columns[i].ColumnName + "\",");
            }
            dimensions.Remove(dimensions.Length - 1, 1);
            dimensions.Append("]");

            jsonBuilder.Append("{");
            jsonBuilder.AppendFormat("\"text\":\"{0}\", ", text);
            jsonBuilder.AppendFormat("\"subtext\":\"{0}\", ", subtext);
            jsonBuilder.AppendFormat("\"dimensions\":{0}, ", dimensions);
            jsonBuilder.AppendFormat("\"type\":\"{0}\", ", type);
            jsonBuilder.AppendFormat("\"series\":{0}, ", series);
            jsonBuilder.Append("\"source\":");
            jsonBuilder.Append("[ ");
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                jsonBuilder.Append("{");
                for (int j = 0; j < Columns; j++)
                {
                    jsonBuilder.Append("\"");
                    jsonBuilder.Append(dt.Columns[j].ColumnName);

                    jsonBuilder.Append("\":\"");
                    jsonBuilder.Append(dt.Rows[i][j]);
                    jsonBuilder.Append("\",");


                }
                jsonBuilder.Remove(jsonBuilder.Length - 1, 1);
                jsonBuilder.Append("},");
            }
            jsonBuilder.Remove(jsonBuilder.Length - 1, 1);
            jsonBuilder.Append("]");
            jsonBuilder.Append("}");
            jsonBuilder.Replace("\n", " ");
            return jsonBuilder.ToString();
        }
//方法调用
EChartsToJson("bar", dt, "标题", "备注");//柱状图
EChartsToJson("line", dt, "标题", "备注");//折线图
EChartsToJson("pie", dt, "标题", "备注");//扇图
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容

  • 奋斗者在汗水汇集的江河里,将事业之舟驶到了理想的彼岸。
    洋氵羊阅读 142评论 0 0
  • 为了避免开会带给参加会议人的枯燥无味,主讲人也换种开会模式,可采用图画的模式,吸引大家的视觉感受,从而让会议更...
    李向姿阅读 187评论 0 0