如何使用数据库中的数据绘制 google 饼图(或圆环图)
how to draw a google pie (or donut) chart with data from database
我想在我的 MVC 项目上绘制饼图或圆环图。我可以在没有数据库的情况下绘制它。但我想用数据库中的数据绘制它。我该怎么做?
这是我的不带数据库的圆环图示例代码:
<html>
<head>
<title>Chart</title>
<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
<script type="text/javascript">
google.charts.load("current", { packages: ["corechart"] });
google.charts.setOnLoadCallback(drawChart);
function drawChart() {
var data = google.visualization.arrayToDataTable([
['Task', 'Hours per Day'],
['Work', 11],
['Eat', 2],
['Commute', 2],
['Watch TV', 2],
['Sleep', 7]
]);
var options = {
title: 'My Daily Activities',
pieHole: 0.4,
};
var chart = new google.visualization.PieChart(document.getElementById('donutchart'));
chart.draw(data, options);
}
</script>
</head>
<body>
<div id="donutchart" style="width: 900px; height: 500px;"></div>
</body>
</html>
您基本上需要在您的操作方法中生成类似于您的 javascript 数组的数据并将其传递给您的视图。我在这里硬编码了它。但是你可以用你的数据库中的数据替换它。
public ActionResult Index()
{
var data = new List<List<object>>()
{
new List<object>
{
"Task","Hours per day"
},
new List<object>
{
"Work",45
}
,
new List<object>
{
"Eat",25
},
new List<object>
{
"Commute to work",30
}
};
return View(data);
}
现在您的视图将被强类型化为 List<List<object>>
@model List<List<object>>
现在在同一视图的脚本部分,将您的模型序列化为一个 js 变量(数组),并将其用作 arrayToDataTable
方法的输入。
var dataArr = @Html.Raw(Newtonsoft.Json.JsonConvert.SerializeObject(Model));
var data = google.visualization.arrayToDataTable(dataArr);
我想在我的 MVC 项目上绘制饼图或圆环图。我可以在没有数据库的情况下绘制它。但我想用数据库中的数据绘制它。我该怎么做?
这是我的不带数据库的圆环图示例代码:
<html>
<head>
<title>Chart</title>
<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
<script type="text/javascript">
google.charts.load("current", { packages: ["corechart"] });
google.charts.setOnLoadCallback(drawChart);
function drawChart() {
var data = google.visualization.arrayToDataTable([
['Task', 'Hours per Day'],
['Work', 11],
['Eat', 2],
['Commute', 2],
['Watch TV', 2],
['Sleep', 7]
]);
var options = {
title: 'My Daily Activities',
pieHole: 0.4,
};
var chart = new google.visualization.PieChart(document.getElementById('donutchart'));
chart.draw(data, options);
}
</script>
</head>
<body>
<div id="donutchart" style="width: 900px; height: 500px;"></div>
</body>
</html>
您基本上需要在您的操作方法中生成类似于您的 javascript 数组的数据并将其传递给您的视图。我在这里硬编码了它。但是你可以用你的数据库中的数据替换它。
public ActionResult Index()
{
var data = new List<List<object>>()
{
new List<object>
{
"Task","Hours per day"
},
new List<object>
{
"Work",45
}
,
new List<object>
{
"Eat",25
},
new List<object>
{
"Commute to work",30
}
};
return View(data);
}
现在您的视图将被强类型化为 List<List<object>>
@model List<List<object>>
现在在同一视图的脚本部分,将您的模型序列化为一个 js 变量(数组),并将其用作 arrayToDataTable
方法的输入。
var dataArr = @Html.Raw(Newtonsoft.Json.JsonConvert.SerializeObject(Model));
var data = google.visualization.arrayToDataTable(dataArr);