1👍
✅
Please remind that jQuery.getJSON()
is executed asynchronously. Therefore you should create the chart only once the data is available and processed to a format suitable for your chart. This can be done if you place code responsible for chart creation inside the jQuery.getJSON()
success handler (callback function) as follows.
$.getJSON("https://spreadsheets.google.com/feeds/list/1GnakUnNQvFXjuzMSPnBpU9eufb4SooQLGL2oFc3lfAs/od6/public/values?alt=json", data => {
var labels = [];
var numbers = [];
data.feed.entry.forEach(e => {
labels.push(e['gsx$names']['$t']);
numbers.push(Number(e['gsx$numbers']['$t']));
});
new Chart(document.getElementById('myChart'), {
type: 'radar',
data: {
labels: labels,
datasets: [{
label: 'Current level',
data: numbers,
backgroundColor: 'rgba(253, 48, 76, 0.2)',
borderColor: 'rgb(253, 48, 76)',
pointBackgroundColor: 'rgb(253, 48, 76)'
}]
},
options: {
tooltips: {
callbacks: {
title: (tooltipItem, data) => data.labels[tooltipItem[0].index]
}
}
}
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.3/Chart.min.js"></script>
<canvas id="myChart"></canvas>
Source:stackexchange.com