- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Highcharts 显示多个图表,每个图表位于不同的选项卡上。我在图表底部添加了一些按钮来打开和关闭所有系列,以及打开和关闭系列分组。这些按钮适用于第一个选项卡,但不适用于后续选项卡。每个选项卡根据统计组(Chart1、Chart2、Chart3)进入不同的页面:
<a href="path_to_file/ajax.<?php echo $statGroup; ?>.php?host=<?php echo $statGroup; ?>&from=<?php echo $from; ?>&through=<?php echo $through; ?>"><?php echo $statGroup; ?></a>
Highcharts 的代码在调用的每个页面上都不同,但按钮仅适用于第一个选项卡。每个选项卡的数据都正确显示。这是我正在使用的代码,其中每个选项卡的“StatGroup1”更改为 StatGroup2,依此类推:
$from = isset($var_from) ? $var_from : strtotime('-36 hours');
$through = isset($var_through) ? $var_through : time();
//print_r(getcwd());
$stats = new cimsSonusEMS($through, $from);
$series = array();
foreach ($stats->get_cpu($statGroup) as $slot => $util) {
$data = array();
foreach ($util as $time => $stat) {
$time *= 1000;
$data[] = "[$time, $stat]";
}
$data_string = implode(',', $data);
$series[] = "{ name: 'Slot $slot', type: 'spline', data: [$data_string]}";
}
?>
<div id="graph-StatGroup1"></div>
<div id="onOffButtons">
<button id="allOn"> All Cards On </button>
<button id="allOff"> All Cards Off </button>
<button id="MNSoff" value="MNS Off"> MNS On/Off </button>
<button id="PNSoff" value="PNS Off"> PNS On/Off </button>
<button id="SPSoff" value="SPS Off"> SPS On/Off </button>
<button id="CNSoff" value="CNS Off"> CNS On/Off </button>
</div>
<script type="text/javascript">
$(document).ready(function() {
chartStatGroup1 = new Highcharts.Chart({
chart: {
renderTo: 'graph-StatGroup1',
zoomType: 'x',
width: 900,
height: 400
},
credits: { enabled: false },
title: { text: 'CPU Utilization by Card' },
legend: { itemWidth: 120 },
xAxis: {
type: 'datetime',
maxZoom: 1000 * 3600 * 6,
labels: {
formatter: function() {
return Highcharts.dateFormat('%b %e<br />%H:%M', this.value);
}
}
},
tooltip: {
shared: true,
formatter: function() {
var tip = Highcharts.dateFormat('%A, %B %e, %l:%M %P', this.x);
$.each(this.points, function(i, point) {
tip += '<br /><span style="color: ' + point.series.color + '">' + this.series.name + '</span>: ' + point.y + '%';
});
return tip;
}
},
yAxis: {
title: { text: null },
min: 0,
max: 100
},
plotOptions: {
spline: {
lineWidth: 1,
marker: {
enabled: false,
states: {
hover: {
enabled: true,
radius: 5
}
}
}
}
},
series: [ <?php echo implode(',', $series); ?> ]
});
$("#allOn").click(function(){
var series = chartStatGroup1.series;
for (var i = 0; i < series.length; i++) {
series[i].setVisible(true, false);
}
chartStatGroup1.redraw();
alert("All On");
MNSoff.value = "MNS Off";
PNSoff.value = "PNS Off";
SPSoff.value = "SPS Off";
CNSoff.value = "CNS Off";
});
$("#allOff").click(function() {
var series = chartStatGroup1.series;
for (var i = 0; i < series.length; i++) {
series[i].setVisible(false, false);
}
chartStatGroup1.redraw();
alert("All Off");
MNSoff.value = "MNS On";
PNSoff.value = "PNS On";
SPSoff.value = "SPS On";
CNSoff.value = "CNS On";
});
$("#MNSoff").click(function() {
var series = chartStatGroup1.series;
if (this.value == "MNS Off") {
series[0].setVisible(false, false);
series[1].setVisible(false, false);
chartStatGroup1.redraw();
alert("MNS off");
this.value = "MNS On";
} else {
series[0].setVisible(true, false);
series[1].setVisible(true, false);
chartStatGroup1.redraw();
alert("MNS on");
this.value = "MNS Off";
}
});
$("#PNSoff").click(function() {
var series = chartStatGroup1.series;
if (this.value == "PNS Off") {
series[2].setVisible(false, false);
series[3].setVisible(false, false);
series[4].setVisible(false, false);
chartStatGroup1.redraw();
alert("PNS off");
this.value = "PNS On";
} else {
series[2].setVisible(true, false);
series[3].setVisible(true, false);
series[4].setVisible(true, false);
chartStatGroup1.redraw();
alert("PNS on");
this.value = "PNS Off";
}
});
$("#SPSoff").click(function() {
var series = chartStatGroup1.series;
if (this.value == "SPS Off") {
series[5].setVisible(false, false);
series[6].setVisible(false, false);
chartStatGroup1.redraw();
alert("SPS off");
this.value = "SPS On";
} else {
series[5].setVisible(true, false);
series[6].setVisible(true, false);
chartStatGroup1.redraw();
alert("SPS on");
this.value = "SPS Off";
}
});
$("#CNSoff").click(function() {
var series = chartStatGroup1.series;
if (this.value == "CNS Off") {
series[7].setVisible(false, false);
series[8].setVisible(false, false);
series[9].setVisible(false, false);
series[10].setVisible(false, false);
series[11].setVisible(false, false);
series[12].setVisible(false, false);
series[13].setVisible(false, false);
chartStatGroup1.redraw();
alert("CNS off");
this.value = "CNS On";
} else {
series[7].setVisible(true, false);
series[8].setVisible(true, false);
series[9].setVisible(true, false);
series[10].setVisible(true, false);
series[11].setVisible(true, false);
series[12].setVisible(true, false);
series[13].setVisible(true, false);
chartStatGroup1.redraw();
alert("CNS on");
this.value = "CNS Off";
}
});
});
</script>
我无法使用 Highstock,只能使用 Highcharts。谢谢。
更新:
有效的代码如下:
$(document).on({
click: function () {
var series = chartCMHGSX2.series;
for (var i = 0; i < series.length; i++) {
series[i].setVisible(true, false);
}
chartCMHGSX2.redraw();
alert("All On");
MNSoff.value = "MNS Off";
PNSoff.value = "PNS Off";
SPSoff.value = "SPS Off";
CNSoff.value = "CNS Off";
}
}, '#allOn');
非常感谢@popnoodles的帮助!
最佳答案
这是因为 highcharts 正在动态创建元素。当 JS 执行时,只有当时存在的元素知道它们所接受的指令。
幸运的是,当您单击某些内容时,除非明确告知不要这样做,否则该单击会一直冒泡到文档。
因此,您要做的就是将事件绑定(bind)到任何存在且不会被覆盖的祖先,故障安全是 document
,并将事件委托(delegate)给您想要与之交互的元素,该元素在 JS 执行时可能存在也可能不存在。只要祖先存在,指令就会被记录下来。
所以,这个 $('#something').click(function(){})
可能会工作一次,但是 #something
会被覆盖,它的替换不会'不知道说明。
有了这个 $(document).on('click', '#something', function(){})
document
确实知道指令,听到了点击声,如果#something
是目标或目标的祖先,则将执行该指令。
关于javascript - 按钮在后续选项卡上无法在 Highcharts 中重绘图表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23940769/
给定一个 Option[Future[Option[Int]]] : scala> val x: Option[Future[Option[Int]]] = Some ( Future ( Some
如果我理解正确,EitherT[Option,A,B] 应该与 Option[Either[A,B]] 相同,但编译器不同意.以下代码编译失败: def f[A,B] = implicitly[Eit
我刚开始在使用 parcel.js 构建静态 Assets 时遇到此错误。它在本地工作,但我在 Heroku 上的构建出错,我不确定它是否相关。 最佳答案 得到同样的问题。通过将 core-js 安装
当我生成 Telerik Report 时,只有 Export PDF 可用。即使我将 docx 和 xlsx 的配置设置为 true。这是我在网络配置中的配置。
我的 iTunesConnect 应用程序显示 Apple Pay 选项。我正在使用布伦特里。 即使我们没有在应用程序中使用 Apple Pay 功能。 有人可以帮我解决如何在我的 itunesCon
我正在 Raspbian 中从命令行运行以下查询: mysql -u $NAME -p $PASS Tweets -e "SELECT count(*) FROM raw_tweets;" 它输出以下
我正在尝试使用 ffmpeg(在 linux 下)为视频添加一个小标题。所以,我使用: ffmpeg -i hk.avi -r 30000/1001 -metadata title="SOF" hk_
我正在尝试使用 ffmpeg 使用 ffserver 流式传输视频。您将在 ffserver1.conf 文件下方找到 ffmpeg 命令的日志输出。 其中一个错误引用了预设,每次我尝试使用预设时,我
我正在尝试对 Option 使用 fold 或 map 操作而不是 match。 我有一个选项 val ao: Option[String] = xxxx 和一个函数 f: (String => Fu
Dockerfile documentation表示有可能通过 --platform FROM 中的选项像这样的指令: FROM [--platform=] [AS ] 在我的 dockerfile
我不确定“属性(property)”或“选项”是否是正确的术语,但这是我需要弄清楚的。 鉴于以下情况: ' $.fileup({ url: '/file/upload',
我正在尝试使用 jQuery 检查是否选择了值 = 1 的选择选项,然后将类添加到某些元素。但有些东西不起作用。可以请人看一下代码吗? 我的代码: Reservation
我对 VIM 中的这些感到困惑。有些事情需要设置,而另一些则让。 而且,我如何检查某个选项。我知道这是一个选项,因为我使用 set 来更改它。 例如,如何检查当前文件类型选项是否为 java? 最佳答
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我在看《Professional F# 2.0》一书作者展示如下代码 let a string : option = None if a.IsNone then System.Console.
我习惯使用方法顶部的 java 样板检查输入参数: public static Boolean filesExist(String file1, String file2, String file3
假设我有一串 "Insert Post -title Some PostTitle -category 2 -date-posted 2013-02:02 10:10:10" 我一直在尝试做的是将这个
从 1.3.70 EAP 开始,在 org.jetbrains.kotlin.gradle.dsl.KotlinJvmOptions 这是 var useIR: kotlin.Boolean 哪个激活
我无法获取订购捆绑商品的所有子产品及其选项。这可能吗? 最佳答案 以下是您如何找出哪些产品应与所有其他项目一起附加到列表中的捆绑产品中的方法: foreach ($order->getAllItems
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我是一名优秀的程序员,十分优秀!