json - 将数据传递给水平条 Highchart.js,在 codeigniter 中只显示一条记录
问题描述
我真的很困惑如何将数据从控制器传递到水平条 bcz 这是我第一次处理图表,我希望有人可以帮助我 n 告诉我获取数据 n 传递到图表的最佳方法。
我尝试在视图中使用 foreach,然后在图表脚本中回显..当我使用 Print_R 时,我可以看到所有数据..但是当我将它放在水平条图表中时,它只给我 1 条记录。这是结果的屏幕截图
这就是我在控制器和视图中所做的:
控制器
public function index()
{
$data['db1'] = $this->m_mds->isiChart();
$data['content'] = 'tempelates/MDS/content';
$data['chart'] = 'tempelates/MDS/chart';
$this->load->view('tempelate',$data);
}
这是视野中的foreach:
<figure class="highcharts-figure">
<div id="container"></div>
</figure>
<script src="https://code.highcharts.com/highcharts.js"></script>
<script src="https://code.highcharts.com/modules/exporting.js"></script>
<script src="https://code.highcharts.com/modules/export-data.js"></script>
<script src="https://code.highcharts.com/modules/accessibility.js"></script>
<?php foreach ($db1->result_array() as $key) {
$nmbrg= $key['NAMA_BRG'];
$oos=$key['OOS'];
$kurang= $key['kurang_4'];
$osa=$key['OSA'];
}?>
<script>
Highcharts.chart('container', {
chart: {
type: 'bar',
options3d: { enabled: true, }
},
title: {
text: 'Stacked bar chart'
},
xAxis: {
categories: [<?php echo json_encode($nmbrg)?> ]
},
yAxis: {
min: 0,
title: {
text: 'Total fruit consumption'
}
},
legend: {
reversed: true
},
plotOptions: {
series: {
stacking: 'normal'
}
},
series: [{
name: 'OOS',
data: [<?php echo json_encode($oos)?>]
}, {
name: '<4',
data: [<?php echo json_encode($kurang)?>]
}, {
name: 'OSA',
data: [<?php echo json_encode($osa)?>]
}]
});
</script>
我想做的是..像这样制作foreach的输出
[{"namabrg":"YOLITE C+100 STRAWBERRY ","oos":1719,"kurang":4264,"osa":40100},{"namabrg":"YOLITE KIDS 70 ML BND 4 ORI ","oos":2,"kurang":3,"osa":162}]
并将来自 foreach 的所有数据传递到水平条形图。
解决方案
您需要将您的 PHP 代码块更改为:(将单个值放入数组并将数组值内爆到列表)
<?php
$nmbrg_values = array();
$oos_values = array();
$kurang_values = array();
$osa_values = array();
foreach ($db1->result_array() as $key) {
$nmbrg_values[] = $key['NAMA_BRG'];
$oos_values[] = $key['OOS'];
$kurang_values[] = $key['kurang_4'];
$osa_values[] = $key['OSA'];
}
$nmbrg = implode(", ", $nmbrg_values);
$oos = implode(", ", $oos_values);
$kurang = implode(", ", $kurang_values);
$osa = implode(", ", $osa_values);
?>
推荐阅读
- python - 从 numpy 数组创建栅格,从 csv 文件中获取值
- java - 静态工厂方法 - 返回任何子类型
- sql - SQL:如何从一个链接到另一个表的表中找到描述值?
- html - 加载时我的网站字体大小会自动更改
- excel - 在统计上创建非线性方程的上限和下限斜率
- python - 使用 Boto 3 将文件从 AWS S3 传输到 SFTP
- wordpress - 如何将 Wordpress 仪表板登录网址更改为网站网址?
- html - 使表格的第一列变粘
- kentico - 我可以根据宏使母版页(Kentico 11 Portal Engine)上的 Doctype 动态化吗?
- c - 如何触发保存文件的创建