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:图表无法出现的主要内容,如果未能解决你的问题,请参考以下文章

wx-charts 微信小程序图表插件

v-charts 使用方法

以德国日期格式输入数据并结合 Chart Js

v-charts 和 websocket实现数据展示动态推送

iframe 内容无法出现在 Firefox 中

Charts.js 使用货币和千位分隔符格式化 Y 轴