ChartJS标签名称不显示,仅ID

时间:2018-06-26 01:31:54

标签: python-3.x django-rest-framework django-views chart.js chartjs-2.6.0

我已经搜索了几天这个主题,最近在我的朋友们的帮助下,今天有了很大的进步。我无法正确显示数据,现在可以了。剩下的最后一块是使标签正确显示。我发现了一个类似的问题,并且怀疑我可能可以使用数组,但无法完全弄清语法。这是类似的问题。 passing each element of array in the labels of char.js是可以正常工作的代码,只显示外键的ID,而不显示实际名称。如果我从图表标签循环中删除.id,则该图表根本不会显示。无论出于什么原因,我似乎都无法访问数据名称,只能访问ID。在此先感谢您的帮助。

我的HTML

{% extends 'base5.html' %}

{% block body_block %}
<div class="box6">
          <h1 class="title">Number of Books By Author</h1>
<canvas id="myChart"></canvas>
<div>

  <script>
  var endpoint = '{% url "Books:chart_data" %}'
  var defaultData = [];
  var labels = [];
  array = {{ procedures3 }}
  $.ajax({
      method: "GET",
      credentials: 'same-origin',
      url: endpoint,
      success: function(data){
          defaultData = data.default
          var ctx = document.getElementById("myChart");
          var myChart = new Chart(ctx, {
              type: 'bar',
              data: {
                  labels: [{% for i in book %}{{ i.id }},{% endfor %}],
                  datasets: [{
                      label: "# of Procedures",
                      data: [{% for j in book_count %}
                               {{ j }},
                             {% endfor %}],
                      backgroundColor: [
                          'rgba(255, 99, 132, 0.2)',
                          '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(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
                  }]
              }
          })
      },
      error: function(error_data){
          console.log("error")
          console.log(error_data)
      },
  })
  </script>
  {% endblock %}

ChartView

class ChartData(LoginRequiredMixin,APIView):
    model = Author
    authentication_classes = (SessionAuthentication, BasicAuthentication)
    permission_classes = (IsAuthenticated,)

    def get(self, request, format=None):
        default_items = []
        labels = []
        data = {
            "labels": labels,
            "default": default_items,
        }
        return Response(data)

ChartView

class ChartView(LoginRequiredMixin, TemplateView):
template_name = 'Book/chart.html'

def get_context_data(self, **kwargs):
    context = super(ChartView, self).get_context_data(**kwargs)
    book = Author.objects.filter(id__in=self.request.user.userprofile.author.all()).order_by('id')
    books_count = [ Book.objects.filter(author=cls).count() for cls in book ]
    context['book'] = book
    context['book_count'] = books_count
    return context

对我来说,最后一步是弄清楚如何获取书名而不是通过以下代码行获取的外键ID:

       labels: [{% for i in book %}{{ i.id }},{% endfor %}],

即使我输入i.name或i.book_name或我能想到的任何内容,似乎也无法访问该名称。经过进一步的搜索,我相信我需要对该名称进行某种类型的反向查找,仍然尝试多种方法。感谢您的提前帮助。

1 个答案:

答案 0 :(得分:1)

要引用的字段名称应在“ models.py”文件中定义-尚不清楚您是否已确定i.name或i.book_name是确定的,还是不确定。它是数据库中源表中的列名。如果它实际上是b_name或title或其他名称,则需要专门使用它。

另一件事是,您可能需要在标签列表中的字符串两边加上引号,并且如果有任何特殊的字符可能导致用引号分隔的字符串引起问题,则可能需要内置模板标签“ escapejs

所以尝试类似(标题只是我的猜测):

labels: [{% for i in book %}'{{ i.title|escapejs }}',{% endfor %}]