如何从ChartJS中收集的数据中获取百分比? - php

我遇到了百分比问题。

这是我数据库中的数据:
Jobstreet-2(将其选为工作申请源的用户总数)
Facebook-1(将其选为工作申请源的用户总数)
确实.com-1(将其选为工作申请来源的用户总数)

如何从ChartJS中收集的数据中获取百分比? - php
我的代码似乎只附加了百分号。

现在,我期望得到这样的东西:
Jobstreet-50%| Facebook-25%|确实网站-25%

如果将它们加起来,您将获得100%的收益。

我不知道该怎么做。请帮我解决我的问题。

这是我的代码:

$(document).ready(function(){
    $.ajax({
        url: "/public/ajax/generateChart/",
        method: "GET",
        success: function(data) {
            var source = [];
            var count = [];

            for(var i in data) {
                source.push(data[i].source);
                count.push(data[i].number);
            }

            var config = {
                type: 'doughnut',
                data: {
                    datasets: [{
                        data: count,
                        backgroundColor: [
                            'rgba(59, 89, 152, 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)'
                        ]
                    }],
                    labels: source
                },
                options: {
                    responsive: true,
                    legend: {
                        position: 'bottom',
                    },
                    title: {
                        display: false,
                        text: 'Chart.js Doughnut Chart'
                    },
                    animation: {
                        animateScale: true,
                        animateRotate: true
                    },
                    tooltips: {
                        callbacks: {
                            label: function(tooltipItem, data) {
                                var dataset = data.datasets[tooltipItem.datasetIndex];
                                var total = dataset.data.reduce(function(previousValue, currentValue, currentIndex, array) {
                                    return previousValue + currentValue;
                                });
                                var currentValue = dataset.data[tooltipItem.index];
                                var precentage = Math.floor(((currentValue/total) * 100)+0.5);
                                return ": " + precentage + "%";
                            }
                        }
                    }
                }
            };

            var ctx = $('#chartCanvas');
            window.myDoughnut = new Chart(ctx, config);
        },
        error: function(data) {
            console.log(data);
        }
    });
});

php参考方案

您可以使用以下工具提示标签回调函数和图表插件来实现这一点...

tooltips: {
   callbacks: {
      label: function(tooltipItem, data) {
         var label = data.labels[tooltipItem.index];
         var _data = data.datasets[tooltipItem.datasetIndex].data[tooltipItem.index];
         var data = /\./.test(_data) ? _data.toFixed(2) : _data;
         return label + ' - ' + data + '%';
      }
   }
}

ᴄʜᴀʀᴛᴘʟᴜɢɪɴ

plugins: [{
   beforeInit: function(c) {
      var data = c.data.datasets[0].data
      var data_sum = data.reduce((a, b) => a + b, 0);
      var each_one = 100 / data_sum;
      c.data.datasets[0].data = data.map(e => e * each_one);
   }
}]

添加插件,然后添加图表选项

ᴡᴏʀᴋɪɴɢᴇxᴀᴍᴘʟᴇ

$(document).ready(function() {
   $.ajax({
      url: "https://istack.000webhostapp.com/json/t5.json",
      method: "GET",
      success: function(data) {
         var source = [];
         var count = [];

         for (var i in data) {
            source.push(data[i].source);
            count.push(+data[i].number);
         }

         var config = {
            type: 'doughnut',
            data: {
               datasets: [{
                  data: count,
                  backgroundColor: [
                     'rgba(59, 89, 152, 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)'
                  ]
               }],
               labels: source
            },
            options: {
               responsive: false,
               legend: {
                  position: 'bottom',
               },
               title: {
                  display: false,
                  text: 'Chart.js Doughnut Chart'
               },
               animation: {
                  animateScale: true,
                  animateRotate: true
               },
               tooltips: {
                  callbacks: {
                     label: function(tooltipItem, data) {
                        var label = data.labels[tooltipItem.index];
                        var _data = data.datasets[tooltipItem.datasetIndex].data[tooltipItem.index];
                        var data = /\./.test(_data) ? _data.toFixed(2) : _data;
                        return label + ' - ' + data + '%';
                     }
                  }
               }
            },
            plugins: [{
               beforeInit: function(c) {
                  var data = c.data.datasets[0].data
                  var data_sum = data.reduce((a, b) => a + b, 0);
                  var each_one = 100 / data_sum;
                  c.data.datasets[0].data = data.map(e => e * each_one);
               }
            }]
         }
         var ctx = $('#chartCanvas');
         window.myDoughnut = new Chart(ctx, config);
      },
      error: function(data) {
         console.log(data);
      }
   });
});

<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.6.0/Chart.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<canvas id="chartCanvas" height="200"></canvas>

php:是否有充分的理由引用所有数组键/索引? - php

我正在遍历别人的代码,他们总是避免转义其数组键。例如:$ row_rsCatalogsItems [名称]代替$ row_rsCatalogsItems ['名称']因此,我不断地对自己接触的所有事物进行微小的更改,以应对这些惰性。但是现在我想知道这样做是否有很多好处。我得到它会在默认为字符串之前检查常量(我在处理常量时会讨厌php中的行为,因为即使未定义,…

PHP标头功能不起作用 - php

我曾经使用此功能从一个PHP页面重定向到另一个:header( 'Location: student.php?cnp='.$_REQUEST['name']) ; 在我的本地主机中,它确实可以工作,但是如果在Internet中对其进行测试,则不会重定向。我也尝试给出完整的路径(如http://.../student.p…

PHP数组可以这样做吗? - php

可以说;我有一个$ friends数组,其中有2,000个不同的friendID号+我有一个带有10,000 bulletinID号的$ bulletins数组,该$ bulletins数组还将具有另一个值,该ID的用户ID是发布公告条目的用户现在可以获取所有具有与FriendsID数组中的userID匹配的userID的bulletinID号吗?甚至有可能…

PHP中的可选函数输入 - php

我注意到在一些内置的PHP函数中,例如str_replace,有一些可选的输入变量。我可以在自己的函数中有可选的输入变量吗?如果是这样,怎么办?谢谢,布赖恩 php参考方案 第一种方法是对某些参数使用默认值:function doStuff($required, $optional = '', $optional2 = '�…

在Symfony中键入提示json对象 - php

在我的Symfony 2.3项目中,我有一个curl函数,该函数从API接收JSON数据,并将该数据作为参数传递给另一个函数。当前,接受JSON对象的函数如下所示:public function updateCountries($data) { foreach (json_decode($data, true) as $key => $value) {…