Django 中的 Charts.js:图表无法出现
Posted
技术标签:
【中文标题】Django 中的 Charts.js:图表无法出现【英文标题】:Charts.js in Django: Charts cannot appear 【发布时间】:2021-09-29 14:21:25 【问题描述】:我正在尝试使用 Chart.js
为我的 django 项目创建一个图表应用程序。我尝试做我在 Youtube 视频中看到的非常基本的事情 - 将https://www.chartjs.org/docs/latest/ 中给出的示例代码复制并粘贴到我的文件chart.html
中,但是当我尝试运行该项目时图表没有出现。
我已将带有chart.js
链接的脚本标签添加到我的base.html
,所以我很困惑出了什么问题。
以下是我的代码:
base.html
<!doctype html>
<html lang="en">
<head>
<!-- Required meta tags -->
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<!-- semantic UI -->
<link rel="stylesheet" type='text/css' href="https://cdnjs.cloudflare.com/ajax/libs/semantic-ui/2.2.14/semantic.min.css">
<!--Chart js-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.4.1/chart.min.js" integrity="sha512-5vwN8yor2fFT9pgPS9p9R7AszYaNn0LkQElTXIsZFCL7ucT8zDCAqlQXDdaqgA1mZP47hdvztBMsIoFxq/FyyQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
<!-- jQuery -->
<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
<title>% block title %% endblock title %</title>
</head>
<body>
% block scripts % % endblock %
% block content % % endblock %
</body>
</html>
chart.html
% extends 'base.html' %
% block title %Genre Popularity Ranking% endblock title %
% block scripts %
<script>
$(document).ready(function()
var ctx = document.getElementById('myChart').getContext('2d');
var myChart = new Chart(ctx,
type: 'bar',
data:
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
]
,
options:
scales:
y:
beginAtZero: true
);
);
</script>
% endblock %
% block content %<canvas id="myChart" ></canvas>% endblock %
由于我最近才开始学习 Django,如果有人可以帮助我,我将不胜感激!
【问题讨论】:
您在浏览器中看到了什么,您可以打开浏览器开发工具选项卡并打开控制台吗? 存在未捕获的引用错误:$ 未定义。这是由于JQuery吗?我怎么可能解决它? 是的,这是由于 jquery,如果库确实在您请求的 cdn url 中,请检查您的开发工具的网络选项卡。然后将 jequery 请求放在请求的库之上。 我刚刚更新了 JQuery 的 CDN 链接,但仍然出现同样的错误 我写在回答代码示例和另一种省略 jquery 的方法中,因为它不是严格需要的。 【参考方案1】:如果图表 js 需要 jquery,请将其放在顶部。
<!-- Required meta tags -->
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<!-- semantic UI -->
<link rel="stylesheet" type='text/css' href="https://cdnjs.cloudflare.com/ajax/libs/semantic-ui/2.2.14/semantic.min.css">
<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
<!--Chart js-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.4.1/chart.min.js" integrity="sha512-5vwN8yor2fFT9pgPS9p9R7AszYaNn0LkQElTXIsZFCL7ucT8zDCAqlQXDdaqgA1mZP47hdvztBMsIoFxq/FyyQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
<!-- jQuery -->
<title>% block title %% endblock title %</title>
</head>
还要确保在 chrome 的网络选项卡中,您发出的请求以 200 响应。例如
然后在你的 js 代码中确保你有 jquery 运行:
<script>
$(document).ready(function() console.log(123); )
</script>
否则你可以只使用原生 js,例如:$(document).ready equivalent without jQuery 因为因为你在控制台 $ 没有定义你的问题是 jquery
【讨论】:
以上是关于Django 中的 Charts.js:图表无法出现的主要内容,如果未能解决你的问题,请参考以下文章