ChartJS 是一个基于 JavaScript 的图表库,用于创建各种类型的图表,如折线图、柱状图、饼图等。EJS(Embedded JavaScript)是一种简单的模板语言,允许你在 HTML 中嵌入 JavaScript 代码。
假设你有一个简单的 EJS 模板和一个 ChartJS 图表配置,以下是如何在 EJS 模板中使用 ChartJS 的示例:
chart.ejs
)<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>ChartJS with EJS</title>
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
</head>
<body>
<canvas id="myChart" width="400" height="200"></canvas>
<script>
const ctx = document.getElementById('myChart').getContext('2d');
const chartData = <%- JSON.stringify(chartData) %>;
new Chart(ctx, {
type: 'bar',
data: chartData,
options: {
scales: {
y: {
beginAtZero: true
}
}
}
});
</script>
</body>
</html>
const express = require('express');
const app = express();
const ejs = require('ejs');
app.set('view engine', 'ejs');
app.get('/', (req, res) => {
const chartData = {
labels: ['Red', 'Blue', 'Yellow', 'Green', 'Purple', 'Orange'],
datasets: [{
label: '# of Votes',
data: [12, 19, 3, 5, 2, 3],
backgroundColor: [
'rgba(255, 99, 132, 0.2)',
'rgba(54, 162, 235, 0.2)',
'rgba(255, 206, 86, 0.2)',
'rgba(75, 192, 192, 0.2)',
'rgba(153, 102, 255, 0.2)',
'rgba(255, 159, 64, 0.2)'
],
borderColor: [
'rgba(255, 99, 132, 1)',
'rgba(54, 162, 235, 1)',
'rgba(255, 206, 86, 1)',
'rgba(75, 192, 192, 1)',
'rgba(153, 102, 255, 1)',
'rgba(255, 159, 64, 1)'
],
borderWidth: 1
}]
};
res.render('chart', { chartData });
});
app.listen(3000, () => {
console.log('Server is running on port 3000');
});
canvas
元素未正确加载或 ChartJS 库未正确引入。canvas
元素的 ID 正确,并且 ChartJS 库已正确引入。通过以上示例和解释,你应该能够在 EJS 模板中成功使用 ChartJS 创建图表。如果有更多具体问题,欢迎继续提问。
领取专属 10元无门槛券
手把手带您无忧上云