饼状图&柱状图

queryReportGraphics.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <script type="text/javascript" src="jquery-2.1.4.js"></script>
    <script type="text/javascript" src="reportGraphics.js"></script>
    <script type="text/javascript" src="echarts.common.min.js"></script>
    <script type="text/javascript" src="echarts.js"></script>
    <script type="text/javascript" src="echarts.min.js"></script>
    <script type="text/javascript" src="queryReportGraphicsl.js"></script>
    <title>queryReportGraphics</title>
</head>
<body>
    <div class="row">
	<div class="box col-md-12">
		<div class="box-inner">
			<div class="box-content">
			  	<div class="charts-content">
                      <!-- 1.饼图 -->
			        <div class="map-area">
		         		<div class="charts-item-task"> 
		         			<div id="regularClass-piechart"></div>
                        </div>
                       
			            <div class="error-content">
			            	<div id="regularSubClass-piechart"></div>
			            </div> 
			        </div>
			        <div class="charts-btm">
                      
			            <div class="charts-item-large">
			                <div id="productName-piechart"></div>
                        </div>
                      
			            <div class="charts-item1">
			                <div id="error-chart"></div> 
			            </div>
                    </div>
                    <!-- 2.柱形图 -->
                    <div class="map-area">
		         		<div class="charts-item-task"> 
		         			<div id="regularProblem-barchart"></div>
                        </div>
                       
			            <div class="error-content">
			            	<div id="regularDistort-barchart"></div>
			            </div> 
			        </div>
			        <div class="charts-btm">
                    
			            <div class="charts-item-large">
			                <div id="productProblem-barchart"></div>
                        </div>
                      
			            <div class="charts-item">
			                <div id="productDistort-barchart"></div> 
			            </div>
                    </div>
			    </div>
			</div>
		</div>
	</div>
</body>
<style>
	.row,.box-inner{
		/* min-1140px; */
		overflow:auto;
	}
    .charts-content {
        100%;
       min-1100px;
       overflow: hidden; 
    }

    #world-map {
         1100px;
        min-800px;
        height: 400px;
        margin-left: -50px; 
        cursor: default; 
    }

    #productDistort-barchart {
         500px;
        /* min-180px; */ 
        height: 250px;
        z-index:100;
    }
    
    .invisible-bolck{
    	10%;
    	height:100%;
    	min-100px;
    	opacity:0;
    }

    .error-content{
    	display: flex;
        display: -webkit-flex;
    	/*  25%; */
    	48%;
    	height: 270px;
    	border: 1px solid #2fa4e7;
    	/* position:absolute; */
    	background-color: #fff;
    	align-items:center;
    	justify-content: center;
    	right:1%;
    	border-radius: 6px;
    	overflow-x: hidden; 
    	/* box-shadow: -2px -2px 5px #2fa4e7; */
    }
    
    .task-content{
    	display: flex;
        display: -webkit-flex;
    	position:absolute;
    	left:10px;
    	/*  25%; */
    	270px;
    	background-color: #fff;
    	height: 80%;
    	border: 1px solid #2fa4e7;
    	border-radius: 6px;
    	overflow-x: hidden; 
    	align-items:center;
    	justify-content: center;
    	/* box-shadow: -2px -2px 5px #2fa4e7; */
    }
    
    #regularClass-piechart{
    	 500px;
        height: 250px; 
        z-index:100;
    }
    #regularProblem-barchart{
    	 500px;
        height: 250px; 
        z-index:100;
    }
    .charts-btm {
         100%;
        display: flex;
        display: -webkit-flex;
        justify-content: space-around; 
        margin-bottom: 10px;
    }

    .map-area {
        position: relative;
        display: flex;
        align-items: center;
        /* height: 350px; */
        margin-bottom: 20px;
        margin-top: 10px; 
         100%;
        /* min-1000px; */
        justify-content: space-around;
    }

    #agent-chart,
    #productName-piechart {
         500px; 
        /* max-100%; */
        height: 250px;
    }
    #productProblem-barchart {
     500px; 
    /* max-100%; */
    height: 250px;
    }

    #regularSubClass-piechart{
     500px;
    /* max-100%; */
    height: 250px;
    }
    
    #regularDistort-barchart{
    	 500px;
        /* max-100%; */
        height: 250px;
    }
    .charts-item1 {
    	display:flex;
    	display:-webkit-flex;
        justify-content: center;
        align-items: center;
         48%;
        min-320px;
        height: 270px;
        border: 1px solid hsl(210, 100%, 99%);
        border-radius: 6px;
        overflow-x: hidden;
        /* box-shadow: -2px -2px 5px #2fa4e7; */
    }
    .charts-item {
    	display:flex;
    	display:-webkit-flex;
        justify-content: center;
        align-items: center;
         48%;
        min-320px;
        height: 270px;
        border: 1px solid #2fa4e7;
        border-radius: 6px;
        overflow-x: hidden;
        /* box-shadow: -2px -2px 5px #2fa4e7; */
    }
    
      .charts-item-large {
    	display:flex;
    	display:-webkit-flex;
        justify-content: center;
        align-items: center;
         48%;
        min-450px;
        height: 270px;
        border: 1px solid #2fa4e7;
        border-radius: 6px;
        overflow: hidden; 
        /* box-shadow: -2px -2px 5px #2fa4e7; */ 
    }
    
   .charts-item-task{
   		display:flex;
    	display:-webkit-flex;
        justify-content: center;
        align-items: center;
         48%;
        min-450px;
        height: 270px; 
        border: 1px solid #2fa4e7;
        border-radius: 6px;
        overflow: hidden; 
        /* box-shadow: -2px -2px 5px #2fa4e7; */
   }
    
</style>
</html>

  queryReportGraphicsl.js

$(function () {
    //饼图-声明变量
    var pieRegularClass = {
      "ruleType": {
        "types": {
          "WEB_LDAP": 0,
          "文件操作": 0,
          "WEB_XSS": 0,
          "Cherry.zip": 0,
          "WEB_SQL": 0,
          "Orange.zip": 2,
          "存储和传输": 0,
          "Android": 0,
          "密码算法": 0,
          "WEB_XXE": 0,
          "认证鉴权": 0,
          "WEB_CRLF": 0,
          "信息泄露": 6,
          "WEB_代码注入": 0,
          "密码算法:Android": 0,
          "WEB_代码注入:Android": 0,
          "Mango.zip": 239
        },
        "ruleTypeTotal": 27530,
        "ruleTypeDistortTotal": 135,
        "ruleTypeTagTotal": 247
      },
      "ruleName": {
        "ruleNameTypeDistortTotal": 135,
        "types": {
          "FIND_XXE": 0,
          "FIND_MD5": 0,
          "FIND_HTML_PASSWORD": 0,
          "Cherry.zip": 0,
          "Orange.zip": 2,
          "FIND_MODE_WORLD": 0,
          "FIND_GEOLOCATIONENABLED": 0,
          "FIND_JSP_EVAL": 0,
          "FIND_WebView_Html": 0,
          "FIND_SHA1": 0,
          "FIND_UNLINK": 0,
          "FIND_LDAP": 0,
          "FIND_CANONICALPATH": 0,
          "FIND_SSL": 0,
          "FIND_SHELL_system": 0,
          "Mango.zip": 22,
          "FIND_HTML_AUTOCOMPLETE": 0,
          "FIND_PASSWORD": 6,
          "FIND_INTENT_ACTIVITY": 0,
          "FIND_SHELL": 0,
          "FIND_RSA_KeyFactory": 0,
          "FIND_NEXTENTRY": 0,
          "FIND_HmacSHA_KeyFactory": 0,
          "FIND_XXE_SAXParser": 0,
          "FIND_CLIPBOAR": 0,
          "FIND_RSA": 0,
          "FIND_HTTP_HEADER": 0,
          "FIND_SETRESULT": 0,
          "其他": 217,
          "FIND_MYBATIS": 0,
          "FIND_AESECB": 0,
          "FIND_RANDOM": 0,
          "FIND_HmacSHA": 0,
          "FIND_OS_INJECT": 0,
          "FIND_CIPHERSUITES": 0,
          "FIND_PROTOCOLS": 0,
          "FIND_AES_128": 0,
          "FIND_OPENFILEOUTPUT": 0,
          "FIND_CLASSLOADER": 0,
          "FIND_PREFERENCES": 0
        },
        "ruleNameTypeTagTotal": 247,
        "ruleNameTypeTotal": 27530
      },
      "productName": {
		"productNameTotal": 27530,
		"distortTypes":{
            "社交":9,
            "游戏中心":37,
            "Hicloud云服务":0,
            "华为帐号":0,
            "应用市场":0,
            "HMS":99
        },
        "types": {
          "社交": 8,
          "游戏中心": 39,
          "华为帐号": 0,
          "应用市场": 2,
          "HMS": 198
        },
        "productNameTagTotal": 247,
        "productNameDistortTotal": 135
      }
    }
	// console.log(pieRegularClass)
	// console.log(pieRegularClass.ruleType)
	// console.log(pieRegularClass.ruleName)
	// console.log(pieRegularClass.productName)
    
    // 大类声明
    textpie1 = '大类';
    var data1 = [];
    // 小类声明	
    textpie2 = '小类';
    var data2 = [];
    //产品声明
    textpie3 = '产品'
	var data3 = [];
	
	var ruleTypeObj = pieRegularClass.ruleType.types;
    for (var key in ruleTypeObj) {
		if(ruleTypeObj[key]!==0){
			data1.push({value:ruleTypeObj[key],name:key})
		}	
	}
	var ruleNameObj=pieRegularClass.ruleName.types;
	for(var key in ruleNameObj){
		if(ruleNameObj[key]!==0){
			data2.push({value:ruleNameObj[key],name:key})
		}
	}  
	var productNameObj=pieRegularClass.productName.types;
	for(var key in productNameObj){
		if(productNameObj[key]!==0){
			data3.push({value:productNameObj[key],name:key})
		}
	}
    //饼状图-模板		
    function fun_echarts_PIE(echartsPieCnt, pieName, datas) {
      echartsPieCnt.setOption({
        title: {
          text: pieName, //名字
          subtext: '',
           left: 10
        },
        tooltip: {
          trigger: 'item',
          formatter: "{a} <br/>{b} : {c} ({d}%)"
        },
        legend: {
          orient: 'vertical',
          left: 'left',
        },
        series: [{
          type: 'pie',
          radius: '55%',
          center: ['50%', '60%'],
          data: datas, //数据
          itemStyle: {
            emphasis: {
              shadowBlur: 10,
              shadowOffsetX: 0,
              shadowColor: 'rgba(0, 0, 0, 0.5)'
            },
            normal: {
              color: function (params) {
                var colorList = ['#4F6D9F', '#0cA98C', '#F8B131', '#EB5345', '#635CA0', '#4275AA',
                  '#4F6D9F', '#0cA98C', '#F8B131', '#EB5345', '#635CA0', '#4275AA'
                ];
                return colorList[params.dataIndex];
              }
            }
          }
        }]
      });
    };

    // 饼图-初始化图表标签
    var myChart1 = echarts.init(document.getElementById('regularClass-piechart'));
    fun_echarts_PIE(myChart1, textpie1, data1);

    var myChart2 = echarts.init(document.getElementById('regularSubClass-piechart'));
    fun_echarts_PIE(myChart2, textpie2, data2);

    var myChart3 = echarts.init(document.getElementById('productName-piechart'));
    fun_echarts_PIE(myChart3, textpie3, data3);

	//柱状图-声明变量
    textbar1 = '大类'
    var data_Type1 = [],
      	data_Qty1 = [],
     	textbar2 = '小类'
    var data_Type2 = [],
     	data_Qty2 = []
    textbar3 = '产品(有效问题数图)'
    var data_Type3 = [],
      	data_Qty3 = []
    textbar4 = '产品(误报率图)'
    var data_Type4 = [],
	  	data_Qty4 = []
	var ruleTypeObjBar = pieRegularClass.ruleType.types;
	for( var key in ruleTypeObjBar){
		if(ruleTypeObjBar[key]!==0){
			data_Type1.push(key);
			data_Qty1.push(ruleTypeObjBar[key]);
		}
	};
	var ruleNameObjBar=pieRegularClass.ruleName.types;
	for(var key in ruleNameObjBar){
		if(ruleNameObjBar[key]!==0){
			data_Type2.push(key);
			data_Qty2.push(ruleNameObjBar[key]);
		}
	}
	var productNameObjBar=pieRegularClass.productName.types;
	for(var key in productNameObjBar){
		if(productNameObjBar[key]!==0){
			data_Type3.push(key);
			data_Qty3.push(productNameObjBar[key]);
		}
	}
	var productNameObjBar=pieRegularClass.productName.distortTypes;
	for(var key in productNameObjBar){
		if(productNameObjBar[key]!==0){
			data_Type4.push(key);
			data_Qty4.push(productNameObjBar[key]);
		}
	}

// 	console.log(data_Qty1);
// console.log(data_Type1);
  //console.log(pieRegularClass.ruleType.types)
    //柱状图-模板
    function fun_echarts_BAR(echartsBarCnt, barName, data_Types, data_Qtys) {
      echartsBarCnt.setOption({
        title: {
          text: barName,
          x: 'center'
        },
        color: ['#3398DB'],
        tooltip: {
          trigger: 'axis',
          axisPointer: { // 坐标轴指示器,坐标轴触发有效
            type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
          }
        },
        grid: {
          left: '3%',
          right: '4%',
          bottom: '3%',
          containLabel: true
        },
        xAxis: [{
          type: 'category',
          data: data_Types, // ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
          axisTick: {
            alignWithLabel: true
          }
        }],
        yAxis: [{
          type: 'value'
        }],
        series: [{
          name: '直接访问',
		  type: 'bar',
		  center: ['45%', '45%'],
          barWidth: '18%',
          data: data_Qtys, //[10, 52, 200, 334, 390, 330, 220],
          itemStyle: {
            normal: {
              color: function (params) {
                var colorList = ['#4F6D9F', '#0cA98C', '#F8B131', '#EB5345', '#635CA0', '#4275AA',
                  '#4F6D9F', '#0cA98C', '#F8B131', '#EB5345', '#635CA0', '#4275AA'
                ];
                return colorList[params.dataIndex];
              }
            }
          }
        }]
      });
    }
    //柱状图-初始化图表标签
    var myBarChart1 = echarts.init(document.getElementById('regularProblem-barchart'));
    fun_echarts_BAR(myBarChart1,  textbar1, data_Type1, data_Qty1);

    var myBarChart2 = echarts.init(document.getElementById('regularDistort-barchart'));
    fun_echarts_BAR(myBarChart2,  textbar2, data_Type2, data_Qty2)

    var myBarChart3 = echarts.init(document.getElementById('productProblem-barchart'));
    fun_echarts_BAR(myBarChart3,  textbar3, data_Type3, data_Qty3);

    var myBarChart4 = echarts.init(document.getElementById('productDistort-barchart'));
    fun_echarts_BAR(myBarChart4,  textbar4, data_Type4, data_Qty4)
  });

  

原文地址:https://www.cnblogs.com/77yaer/p/10078535.html