Echars 生成柱状图

2023-11-09 06:48
文章标签 生成 柱状图 echars

本文主要是介绍Echars 生成柱状图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

导包<!-- echart -->
    <script type="text/javascript" src="${ctxStatic}/echarts-2.2.7/build/dist/echarts-all.js" ></script>

 <script type="text/javascript">

  $(document).ready(function(){
            var h = $(document).height();
              var w =    $(document).width();
            $("#oBar").attr("style","width:"+w*0.33+"px;height:"+h*0.68+"px;margin-top: 0px;");
            echartData();
        }); 

 

function echartData(){ 
            var barxValue = new Array();  
            var baryValue = new Array(); 

   $.post("${ctx}/sys/m/feeBar",
                function(data) {
                    barxValue.length=0;
                    baryValue.length=0;
                    var json = data;
                    $(json).each(function(index, obj) {
                        baryValue.push(obj.userName);  
                        barxValue.push(-obj.fee);  
                });
                var title = "欠费电量(度)";
//                 baryValue.sort(function(a,b){return a-b})
                barChart(barxValue.sort(function(a,b){return a-b}),baryValue.sort(function(a,b){return a-b}),title);
            }); 

}


function barChart(xArray,yArray,title){  

               var x = xArray;
               var y = yArray;
               var title = title;
            if(title == "欠费电量(度)"){
                   var barChart1 = document.getElementById("oBar");  
                var barechart = echarts.init(barChart1);  
            }else if(title == "使用电量(度)"){
                var barChart = document.getElementById("sBar");  
                var echart = echarts.init(barChart);  
            }
            var option = {
                    color : ['#3cb371', '#b8860b', '#30e0e0'],//修改图形颜色
                    title : {
//                         text: '世界人口总量',
//                         subtext: '数据来自网络'
//                          link:'www.baidu.com' // 主标题超链接
                    },
                    tooltip : {
                        trigger: 'item',  
                        formatter: "{a}  : {c} "
                    },
                    legend: {
                        data:[title],  
                        y:"top",
                        padding:15
                    },
                    toolbox: {
                        show : false,
                        feature : {
                            mark : {show: true},
                            dataView : {show: true, readOnly: false},
                            magicType: {show: true, type: ['line', 'bar']},
                            restore : {show: true},
                            saveAsImage : {show: true}
                        }
                    },
//                     calculable : true, //是否启用拖拽重计算特性,默认关闭,
                    grid: {
                        borderWidth: 0,
                        x:95,
                        x2:40,
                        y: 50,
                        y2: 40
                    },
                    xAxis : [
                        {
                            type : 'value',//设置x为纵轴 来实现横向显示柱状图 value=纵轴
                            boundaryGap : [0, 0.01]
//                             boundaryGap : false
                        }
                       
                    ],
                    yAxis : [
                        {
                            type : 'category',
                            data : y,
                            axisLabel:{//让Y轴自动换行
                                formatter:function(params){
                                       var newParamsName = "";//返回的字符串
                                        var paramsNameNumber = params.length;//获得字符串长度
                                        var provideNumber = 7;//每行显示的长度
                                        var rowNumber = Math.ceil(paramsNameNumber / provideNumber);// 换行的话,需要显示几行,向上取整
                                        //进行判断换行
                                        if (paramsNameNumber > provideNumber) {
                                            for (var p = 0; p < rowNumber; p++) {
                                                var tempStr = "";
                                                var start = p * provideNumber;
                                                var end = start + provideNumber;
                                                if (p == rowNumber - 1) {
                                                    tempStr = params.substring(start, paramsNameNumber);
                                                } else {
                                                    tempStr = params.substring(start, end) + "\n";
                                                }
                                                newParamsName += tempStr;
                                            }

                                        } else {
                                            newParamsName = params;
                                        }
                                        return newParamsName
                                }
                            }
//                             data : ["掌握主动","博大网通","罗伯特","燕园校友","脉极客","中华科技","logYaoDa","头条","德州","水族馆"]//这里放前十名用户名desc
                        }
                    ],
                    series : [
                        {
                            name: title,
                            type: 'bar',
                            data: x ,// 这里放电量数据
                            itemStyle: {
                                normal: {
                                    color: 'tomato',
                                    label : {
                                        show: true, position: 'insideRight'
                                    }
                                }
                            }
                        }
                    ]
              };
              if(title == "欠费电量(度)"){
                  barechart.setOption(option);  
              }else if(title == "使用电量(度)"){
                  echart.setOption(option);  
              }

       };

 </script > 


JSP 写

    <div id="oBar" >
                </div>

这篇关于Echars 生成柱状图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/374545

相关文章

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南

《Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南》在日常数据处理工作中,我们经常需要将不同Excel文档中的数据整合到一个新的DataFrame中,以便进行进一步... 目录一、准备工作二、读取Excel文件三、数据叠加四、处理重复数据(可选)五、保存新DataFram

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P

详解Java中如何使用JFreeChart生成甘特图

《详解Java中如何使用JFreeChart生成甘特图》甘特图是一种流行的项目管理工具,用于显示项目的进度和任务分配,在Java开发中,JFreeChart是一个强大的开源图表库,能够生成各种类型的图... 目录引言一、JFreeChart简介二、准备工作三、创建甘特图1. 定义数据集2. 创建甘特图3.

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n