Ошибка: несоответствие типов. Значение [00,00,00] не соответствует типу timeofday
Я хочу создать линейную диаграмму Google из данных MySQL в формате json. Данные в формате JSON представлены в следующем формате:
{
"result": [
{
"Date": "Dec 17,2017",
"start_time": "22,08,17",
"selected_time": "[00,00,00]"
},
{
"Date": "Dec 18,2017",
"start_time": "21,48,57",
"selected_time": "[00,00,00]"
},
{
"Date": "Dec 21,2017",
"start_time": "13,23,05",
"selected_time": "[00,00,00]"
},
{
"Date": "Dec 22,2017",
"start_time": "00,13,33",
"selected_time": "[00,00,00]"
},
{
"Date": "Dec 23,2017",
"start_time": "14,48,34",
"selected_time": "[00,00,00]"
},
{
"Date": "Dec 27,2017",
"start_time": "19,21,34",
"selected_time": "[00,00,00]"
}
]
}
Ниже приведен код для того, что я делаю. но он не принимает значения start_time и selected_time, поскольку дает ошибку несоответствия. У меня есть типы данных varchar для всех этих полей в MySQL DB.
function callbackFuncWithData(json){
var data = new google.visualization.DataTable();
data.addColumn('string', 'Date');
data.addColumn('timeofday', 'start_time');
data.addColumn('timeofday', 'selected_time');
$.each(json, function (key, value) {
$.each(value, function (key, value) {
var temp = [];
temp = value;
alert([temp['Date']+" "+temp['start_time']+" "+temp['selected_time']]);
data.addRows([
[ temp['Date'],temp['start_time'],temp['selected_time']]
]);
});
});
var options = {
tooltip: {
isHtml: true
},
title: 'Trendlines with multiple lines',
hAxis: {
title: 'Date',
},
vAxis: {
title: 'Time'
},
pointSize: 5,
series: {
0: { pointShape: 'circle' },
}
};
var chart = new google.visualization.LineChart(document.getElementById('multipleTrendChart'));
chart.draw(data, options);
}
}).fail(function (jq, text, err) {
console.log(text + ' - ' + err);
});
}
</script>
</head>
<body>
<div id="multipleTrendChart"></div>
</body>
</html>
Но он показывает эту ошибку "Ошибка: несоответствие типов. Значение 22,08,17 не соответствует типу timeofday в индексе столбца 1". Кто-то, пожалуйста, предложите мне, в чем проблема. Спасибо
1 ответ
Если вы измените формат JSON, он должен выглядеть следующим образом,
без кавычек, окружающих массивы для 'timeofday'
{
"Date": "Dec 17,2017",
"start_time": [22,08,17],
"selected_time": [00,00,00]
},
в противном случае вы можете использовать следующее для преобразования в массивы...
$.each(json, function (key, value) {
data.addRow([
value.Date,
value.start_time.split(','),
JSON.parse(value.selected_time)
]);
});