Как динамически добавлять строки/столбцы в таблицу столбцов Google
Я хочу создать диаграмму столбцов, используя API визуализации Google, я могу отправить данные для заполнения диаграммы DataTable в форме массива. Но мне нужно создать диаграмму с переменным числом столбцов/строк, в зависимости от того, что содержат мои массивы, и я не знаю, как правильно их перебирать и добавлять в DataTable.
Вот пример анализа синтаксических данных STATIC для создания диаграммы:
(все это в javascript)
var data = google.visualization.arrayToDataTable([
['Year', 'Sales', 'Expenses'],
['2004', 1000, 400],
['2005', 1170, 460],
['2006', 660, 1120],
['2007', 1030, 540]
]);
API имеет эти методы для добавления столбцов и строк:
- другой метод получения тех же данных, что и выше:
var data = new google.visualization.DataTable();
data.addColumn('string', 'Year');
data.addColumn('number', 'Sales');
data.addColumn('number', 'Expenses');
data.addRows([ ['2004', 1000 , 400], ['2005', 1170, 460], ['2006', 660, 1120], ['2007',1030,540]
]);
Мне нужен цикл for или double for loop для повторения массивов, которые я отправляю и динамически добавляю содержимое строк.
Чтобы быть более точным, скажем, в одном случае у меня были бы данные, написанные выше, и в другом случае я бы
это:
['Year', 'Sales', 'Expenses' , 'Other'],
['2004', 1000, 400 , 232 ],
['2005', 1170, 460 , 421 ],
['2006', 660, 1120 , 4324 ],
['2007', 1030, 540 , 4234 ],
['2008', 1530, 50 , 234 ],
поэтому я проанализировал бы эти данные через параметры в функции let say (я не знаю, было ли это правильной идеей) многие arraylists, содержащие каждую строку: Row1 = ['2004', 1000, 400, 232]
Row2 = ['2005', 1170, 460, 421] и....
Как я могу использовать цикл for или цикл double для итерации массивов, которые я отправляю для динамического создания данных (с переменными числами строк и столбцов), содержащих данные?
Ответы
Ответ 1
Здесь рабочее решение в jsfiddle.
Посмотрите на следующую функцию. Это выполняет итерацию по массиву данных и обновляет диаграмму:
// function to update the chart with new data.
function updateChart() {
dataTable = new google.visualization.DataTable();
var newData = [['Year', 'Sales', 'Expenses' , 'Other'],
['2004', 1000, 400 , 232 ],
['2005', 1170, 460 , 421 ],
['2006', 660, 1120 , 4324 ],
['2007', 1030, 540 , 4234 ],
['2008', 1530, 50 , 234 ]];
// determine the number of rows and columns.
var numRows = newData.length;
var numCols = newData[0].length;
// in this case the first column is of type 'string'.
dataTable.addColumn('string', newData[0][0]);
// all other columns are of type 'number'.
for (var i = 1; i < numCols; i++)
dataTable.addColumn('number', newData[0][i]);
// now add the rows.
for (var i = 1; i < numRows; i++)
dataTable.addRow(newData[i]);
// redraw the chart.
chart.draw(dataTable, options);
}
Ответ 2
var obj = JSON.parse(r.d);//Json data will come from any web service or any other source
var data2 = new google.visualization.DataTable();
//To Add Column Dynamically
for (var j = 0; j < array.length; j++) // this array contains columns
{
if (j == 0)
{
data2.addColumn(typeof (array[j]), array[j]);
}
else
{
data2.addColumn('number', array[j]);//if 2nd column must be integer
}
}
// To Add Rows Dynamically to a google chart
data2.addRows(obj.length);\\Total Rows
for (var i = 0; i < obj.length; i++)
{
for (var k = 0; k < array.length; k++)//Total Column
{
if (k == 0)
{
data2.setCell(i, k, obj[i][array[k]].toString());//if first Column is String
}
else
{
data2.setCell(i, k, parseInt([obj[i][array[k]]]));//if other columns are int type... for charts mostly we treat just first column as string
}
}
}
Ответ 3
Вы можете поместить данные в одну строку и использовать JSON.parse(stringData). Столбец года должен быть в двойных кавычках
var data = new google.visualization.DataTable();
data.addColumn('string', 'Year');
data.addColumn('number', 'Sales');
data.addColumn('number', 'Expenses');
var stringData = '[["2004", 1000 , 400], ["2005", 1170, 460], ["2006", 660, 1120], ["2007",1030,540]]';
data.addRows(JSON.parse(stringData));