动态添加echarts
本次只贴js和jsp代码
jsp只需添加一个div即可,
<div class="fLayout-right-box">
<hy:layoutArea width="100%"
showborder="false" align="center" id = 'contrastEcharts'>
</hy:layoutArea>
</div>
插入echart:
var xAxisData = ['00:00', '00:15', '00:30', '00:45', '01:00', '01:15', '01:30', '01:45', '02:00', '02:15', '02:30', '02:45', '03:00', '03:15', '03:30', '03:45', '04:00', '04:15', '04:30', '04:45', '05:00', '05:15', '05:30', '05:45', '06:00', '06:15', '06:30', '06:45', '07:00', '07:15', '07:30', '07:45', '08:00', '08:15', '08:30', '08:45', '09:00', '09:15', '09:30', '09:45', '10:00', '10:15', '10:30', '10:45', '11:00', '11:15', '11:30', '11:45', '12:00', '12:15', '12:30', '12:45', '13:00', '13:15', '13:30', '13:45', '14:00', '14:15', '14:30', '14:45', '15:00', '15:15', '15:30', '15:45', '16:00', '16:15', '16:30', '16:45', '17:00', '17:15', '17:30', '17:45', '18:00', '18:15', '18:30', '18:45', '19:00', '19:15', '19:30', '19:45', '20:00', '20:15', '20:30', '20:45', '21:00', '21:15', '21:30', '21:45', '22:00', '22:15', '22:30', '22:45', '23:00', '23:15', '23:30', '23:45'];
var option = {
title : {
text : '',
x : 'left'
},
legend : {
x : 'right',
data : ['今日负荷', '昨日负荷']
},
tooltip : {
trigger : 'axis',
},
grid : {
left : '5%',
right : '5%',
bottom : '30',
containLabel : true
},
xAxis : {
data : xAxisData
},
yAxis : {
splitLine : {
lineStyle : {
type : 'dashed'
}
},
scale : true,
max : 100
},
axisLabel : {
interval : 0
},
grid : {
left : '8%',
right : '0',
bottom : '1%',
containLabel : true
},
color : ['#DD4B39', '#359CB6'],
series : [{
type : 'line',
data : []
}, {
type : 'line',
data : []
}]
};
一下为js代码,可参考编写:
function fun(){
var dataArray = [];
dataArray = eval(response.getParameter("powerLoad"));
var dateArr = eval(response.getParameter("date"));
//动态添加echarts div
showTableAndEcharts.init(dataArray);
//向echarts图中动态添加数据
for (var i = 0; i < dataArray.length; i++) {
//options[i] = option;
option.title.text = treeArray[i].label;
option.legend.data = dateArr;
option.series[0].name = dateArr[0];
option.series[1].name = dateArr[1];
//动态添加数据
option.series[0].data = dataArray[i][0];
option.series[1].data = dataArray[i][1];
myChart[i] = echarts.init(document.getElementById('echartsDiv' + i));
myChart[i].setOption(option);
}
$(window).resize(function() {
for (var i = 0; i < dataArray.length; i++) {
myChart[i].resize();
}
}
var showTableAndEcharts = {
init : function(dataArray) {
$("#contrastEcharts").empty().append(this.layout(dataArray));
},
layout : function(dataArray) {
var html = '';
if (dataArray.length == 1) {
var css = 'style = "height: 98%;width: 98%;float: center;border: 1px #ccc solid;margin: 3px; "';
} else if (dataArray.length == 2) {
var css = 'style = "height: 98%;width: 45%;float: left;border: 1px #ccc solid;margin: 3px; "';
} else {
var css = 'style = "height: 50%;width: 30%;float: left;border: 1px #ccc solid;margin: 3px; "';
}
for (var i = 0; i < dataArray.length; i++) {
html += '<div ' + css + ' id="echartsDiv' + i + '"></div>';
}
return html;
}
}
动态添加echarts的更多相关文章
- 插件~使用ECharts动态在地图上标识点~动态添加和删除标识点
之前写过一个Echarts的文章,没有基础的同学可以先看这<上一篇>,对于一个地图和说,我们在初始化之后,你可能被在地图上标识出一些点,当然这根据你的业务去标识,而如果每次更新数据都加载全 ...
- js动态添加事件-事件委托
作者:白狼 出处:http://www.manks.top/javascript-dynamic-event.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给 ...
- 后台动态添加的button,如何触发button_click事件?
后台动态添加的button,需要在Page_Load或者Page_Init重新动态生成才能执行button_click public Panel GetContrlType() { Panel pan ...
- jquery动态添加的html,第三方插件无法生效的情况
今天一个问题纠结了半天,问题如下图 问题大致就是如上,新增的内容死活点不起,插件没有生效,在一个装逼前端群里面问,给我的答案是叫我去了解事件委托,了解一下事件冒泡!! 好吧,我一上午加半个下午的时间 ...
- 【Java EE 学习 75 下】【数据采集系统第七天】【二进制运算实现权限管理】【使用反射初始化权限表】【权限捕获拦截器动态添加权限】
一.使用反射动态添加权限 在该系统中,我使用struts2的时候非常规范,访问的Action的形式都是"ActionClassName_MethodName.action?参数列表" ...
- Hadoop学习笔记—13.分布式集群中节点的动态添加与下架
开篇:在本笔记系列的第一篇中,我们介绍了如何搭建伪分布与分布模式的Hadoop集群.现在,我们来了解一下在一个Hadoop分布式集群中,如何动态(不关机且正在运行的情况下)地添加一个Hadoop节点与 ...
- Net作业调度(五)—quartz.net动态添加job设计
介绍 在实际项目使用中quartz.net中,都希望有一个管理界面可以动态添加job,而避免每次都要上线发布. 也看到有园子的同学问过.这里就介绍下实现动态添加job的几种方式, 也是二次开发的核心模 ...
- vue中v-bind:class动态添加class
1.html代码 <template v-for='item in names'> <div id="app" class="selectItem&qu ...
- js表单动态添加数据并提交
情景1:已经存在form对象了,动态为form增加对象并提交 function formAppendSubmit(){ var myform=$('#newArticleForm'); //得到for ...
随机推荐
- springboot动态多数据源
参考文章:https://www.cnblogs.com/hehehaha/p/6147096.html 前言 目标是springboot工程支持多个MySQL数据源,在代码层面上,同一个SQL(Ma ...
- php递归实现一维数组转为指定树状结构 --- 省市区处理
### 这两天脑壳痛,一时短路,想不到准备利用递归实现这个需求,最后还是要请教同事,回来自己在实现了一遍,并记录下来 ### 原数据: // { // 广东省: { // 广州市: [ // &quo ...
- Xshell 连接虚拟机出现 "The remote SSH server rejected X11 forwarding request"
1. 描述 虚拟机:VirtualBox Linux: centOS7 解决了 centOS7在VirtualBox中装好后的网络连接问题 后,用 Xshell 连接服务器时出现下面情况: 2. ss ...
- node 创建
下载 node : 注意选项 ADD PATH 配置环境变量 node -v npm -v 检查创建一个服务器 : //创建一个服务器 127.0.0.1:8888 var http = requir ...
- 关于form-checkbox 必填项无效的错误
校验规则要写在一个form里 检查data,给个默认值. 否则刚进去错误提示不显示. 其次,要加 type 类型,注意大小写 触发类型为 change .
- 5G到来,App的未来,是JavaScript,Flutter还是Native ?
Native App React Native(RN)发布于2015年,也是使用JavaScript语言进行跨平台APP的开发.与H5开发不同的是,它使用JS桥接技术在运行时编译成各个平台的Nativ ...
- selenium截图
文件结构 1.DateUtil.py # cncoding = utf-8 import time from datetime import datetime ''' 本文件主要用于获取当前的日期以及 ...
- mysql5.7初始化密码报错 ERROR 1820 (HY000): You must reset your password using ALTER USER statement before
mysql初始化密码常见报错问题1,mysql5.6是密码为空直接进入数据库的,但是mysql5.7就需要初始密码 cat /var/log/mysqld.log | grep password1 2 ...
- JVM内存结构--新生代及新生代里的两个Survivor区(下一轮S0与S1交换角色,如此循环往复)、常见调优参数
一.为什么会有年轻代 我们先来屡屡,为什么需要把堆分代?不分代不能完成他所做的事情么?其实不分代完全可以,分代的唯一理由就是优化GC性能.你先想想,如果没有分代,那我们所有的对象都在一块,GC的时候我 ...
- MySQL5.7 关键字和保留关键字
来源:https://dev.mysql.com/doc/refman/5.7/en/keywords.html 标有(R)的为保留关键字. A ACCESSIBLE (R) ACCOUNT; add ...