我一直在避免使用javascript,但需要将其用于我正在使用的Google图表。我的原始代码看起来像这样......
echo "function drawChart() {
var data = google.visualization.arrayToDataTable([
['Date', 'Machines Total' ],
[ '$Day[6]', $Hour_Tot[7].$Min_Tot[7] ],
[ '$Day[5]', $Hour_Tot[6].$Min_Tot[6] ],
[ '$Day[4]', $Hour_Tot[5].$Min_Tot[5] ],
[ '$Day[3]', $Hour_Tot[4].$Min_Tot[4] ],
[ '$Day[2]', $Hour_Tot[3].$Min_Tot[3] ],
[ '$Day[1]', $Hour_Tot[2].$Min_Tot[2] ],
[ '$Day[0]', $Hour_Tot[1].$Min_Tot[1] ]
]);";
此代码工作正常,并已经过测试。我现在要做的就是 图表变得更加动态,因此用户可以输入数字,图表可以输出 天数的数据。所以我需要添加一个for循环。这就是我得到的 远。
echo "function drawChart() {
var data = google.visualization.arrayToDataTable([
['Date', 'Machine L1' ],
for (count = 1, DayNumber = 0; count == 7; ++count, ++DayNumber )
document.write([ '$Day[DayNumber]', $Hour_Tot[count].$Min_Tot[count]],);
]);";
此代码不起作用。我不明白如何使用document.write输出 我需要复制上述代码的7行。
答案 0 :(得分:1)
此代码不起作用,因为您在数组声明中放置了一个for循环。 你应该做以下......
echo "function drawChart() {
var data = google.visualization.arrayToDataTable([
['Date', 'Machine L1' ],";
for ($count = 1, $DayNumber = 0; $count <= 7; ++$count, ++$DayNumber ) {
echo " [ '$Day[$DayNumber]', $Hour_Tot[$count].$Min_Tot[$count]],";
}
echo "]);";
或者您也可以使用javascript处理它,它应该是:
echo "var arr = [['Date', 'Machine L1']];
for(var i=1;i<=7;i++) {
arr.push([{$Day}[i-1], {$Hour_Tot}[i].toString()+{$Min_Tot}[i].toString()]);
}
var data = google.visualization.arrayToDataTable(arr);
";