从DIV元素获取图形数据

Emre7

我使用Chart.js,我想从DIV元素内的属性中提取数据。

我可以在data-gpget和中获取数据 data-gpret它写入控制台,但不将其视为“数据”数据。

data: getATT('#graph3','data-gpval')data: getATT('#graph3','data-gpret')可能是什么原因呢?我想念什么?谢谢。

<div id="graph3" data-gpget="[28,12,14,27,11]" data-gpret="[21,64,32,73,76]"> 
  <canvas id="js-chartjs-earnings"></canvas>
</div>

JS:

function getATT(id,value) {
   return $(id).attr(value);
}



return e = a, t = [{
                key: "initCharts", value: function () {
Chart.defaults.scale.gridLines.color = "transparent", Chart.defaults.scale.gridLines.zeroLineColor = "transparent", Chart.defaults.scale.ticks.beginAtZero = !0, Chart.defaults.global.elements.line.borderWidth = 0, Chart.defaults.global.elements.point.radius = 0, Chart.defaults.global.elements.point.hoverRadius = 0, Chart.defaults.global.tooltips.cornerRadius = 3, Chart.defaults.global.legend.labels.boxWidth = 12;
                    var r, a = jQuery(".js-chartjs-earnings");
                    r = {
                        labels: ["MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"],
                        datasets: [{
                            label: "GETTING",
                            fill: !0, 
                            data: getATT('#graph3','data-gpget')
                        }, {
                            label: "RETURNS",
                            fill: !0,
                            data: getATT('#graph3','data-gpret')
                        }]
                    }, a.length && new Chart(a, {
                        type: "bar",
                        data: r,
                        options: {
                            tooltips: {
                                intersect: !1, callbacks: {
                                    label: function (r, a) {
                                        return a.datasets[r.datasetIndex].label + ": $" + r.yLabel
                                    }
                                }
                            }
                        }
                    })
                }
            }, {
                key: "init", value: function () {
                    this.initCharts()
                }
            }], null && r(e.prototype, null), t && r(e, t), a
白帽

attr方法将始终返回一个字符串。
尝试改用该data方法...

return $(id).data(value);

只要确保data-从属性名称中删除前缀即可。

查看/运行以下示例...

var testATT = getATT('#graph3','data-gpget');
var testData = getData('#graph3','gpget');
console.log(typeof testATT, testATT);
console.log(typeof testData, testData);

function getData(id,value) {
   return $(id).data(value);
}
function getATT(id,value) {
   return $(id).attr(value);
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id="graph3" data-gpget="[28,12,14,27,11]" data-gpret="[21,64,32,73,76]"> 
  <canvas id="js-chartjs-earnings"></canvas>
</div>

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章