Попытка обновить визуализацию Google с помощью jquery - PullRequest
3 голосов
/ 29 июля 2009

Я относительно неопытен, поэтому, пожалуйста, потерпите меня.

Я занимаюсь разработкой простой панели инструментов с использованием API визуализации Google. Я развиваюсь в vb.net. У меня есть Аннотированная временная шкала, Карта интенсивности и набор таблиц на моем апксе.

Я пытаюсь обновить Карту интенсивности и таблицы на основе диапазона дат, который пользователь выбирает с помощью инструмента Аннотированная временная шкала.

Я надеялся обновить только эти визуализации без полной загрузки страницы. По-видимому, отличный способ сделать это - разделить визуализации на автономные страницы aspx и использовать jQuery для «загрузки» их в div.

Я говорю, по-видимому, как это не работает. Когда я пытаюсь обновить aspx, содержащий визуализацию Google, используя jQuery, я получаю сообщение «Загрузка данных с www.google.com ...» в браузере, и оно просто работает непрерывно и никогда не возвращается. Я проверил это у опытного разработчика, и он был озадачен, но подумал, что должен быть конфликт между API Google и jQuery.

Любые советы, советы, альтернативные решения приветствуются!

1 Ответ

5 голосов
/ 11 сентября 2009

только что закодировал что-то, что может вам помочь. Протестировано для BarChart, ColumnChart, LineChart и AreaChart, у меня хорошо работает (по дизайну не будет работать правильно для PieCharts).

Основной код конструктора:

function Charts (options){
    var self = this;
    self.chart = [];
    self.dataTable = new google.visualization.DataTable();
    self.settings = $.extend({
        colors:['#98D8F4','#E85500','#B3CF2F', '#FEB800', '#FFA1C5', '#D984FF', '#DD9D75'],
        width: 960, height: 600,
    }, options);
    self.add = function(type, element){
        self.chart.push({
            element: $(element),
            o: new google.visualization[type]($(element)[0]),
            draw: function(dataTable, options){
                this.element.html('');
                this.o.draw(dataTable, options);
            }
        });
    };
    self.draw = function(options){
        var settings = $.extend({}, this.settings, options);
        $.each(self.chart, function(i, chart){
            chart.draw(self.dataTable, settings)
        })
    };
    self.parseData = function(labels, legends, data){
        var countRows = data[0].length;
        self.dataTable.addColumn('string', 'Name');
        $.each(legends, function(i, legend){
            self.dataTable.addColumn('number', legend);
        })
        self.dataTable.addRows(countRows);
        $.each(labels, function(i, label){
            self.dataTable.setValue(i, 0, label);
            $.each(data, function(k, entry){
                self.dataTable.setValue(i, k+1, data[k][i]);
            })
        })
        return self.dataTable;
    };
}

Вы можете просто передать данные в виде массива для построения диаграмм (вы должны всегда анализировать данные перед вызовом метода draw)

var labels = [ "Kaspersky","Symantec","G-Data","Avira" ],
    legends = [ "Antivirensoftware (kostenpflichtig)","Antivirensoftware (kostenlos)","Internetsecurity (kostenpflichtig)","Internetsecurity (kostenlos)","Sonstiges, keine Angabe","Beta-Test KIS 2010", "Something Else" ],
    data = [ [46,4,7,33],[3,1,2,38],[42,12,14,7],[2,0,1,1],[43,8,14,18],[4,3,0,1],[1,2,4,2]];

Кроме того, этот скрипт немного сложен, вы можете легко рисовать диаграммы.

var charts = new Charts();
charts.parseData(labels, legends, data);
charts.add('ColumnChart', '#column-chart');
charts.add('BarChart', '#bar-chart');
charts.draw({title: 'Antivirus Comparison Chart', titleY:'Points'});

и легко обновиться

charts.parseData(otherLabels, otherLegends, otherData);
charts.draw({title: 'Antivirus Comparison Chart with Other Data', titleY:'Points'});

надеюсь, это поможет вам:)

Да, и не забудьте загрузить библиотеки и включить этот скрипт в функцию готовности документа, например,

google.load("jquery", "1.3.2");
google.load('visualization', '1', {'packages':['piechart','barchart','columnchart']});
google.setOnLoadCallback(function() {

/* script here */

});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...