dojo dgrid с кнопкой перезагрузки / обновления хранилища из url (json data)
Во-первых, я использую dojo 1.1.0 и dgrid 0.4.0. Я создаю страницу с несколькими рисунками. В частности, одна сетка должна загружать данные JSON из URL и отображать их. В настоящее время он отлично работает, делая это с хранилищем RequestMemory. однако это магазин памяти. хотя это может быть тривиально для некоторых других, мне нужно найти способ загрузить данные, как это делается сейчас, а затем добавить кнопку обновления на экран, которая вызывает необходимые функции / методы для перезагрузки данных из URL и заселить dgrid.
Данные JSON поступают из URL, отформатированного так:
[{"id":1,"name":"trans1","username":"trans1","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":true},{"id":2,"name":"trans2","username":"trans2","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":true},{"id":3,"name":"trans3","username":"trans3","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":false},{"id":4,"name":"trans4","username":"trans4","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":false},{"id":5,"name":"trans5","username":"trans5","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":false},{"id":6,"name":"trans6","username":"trans6","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":false}]
Требование, которое вы увидите ниже, на самом деле содержит гораздо больше, чем просто эта сетка... отсюда и все лишнее.
У меня нет необходимости обновлять локальное хранилище, и я не хочу отслеживать URL-адреса на предмет изменений. Я просто хочу иметь возможность перезагрузить данные из URL-адреса по требованию.
Вот код, который я сейчас использую для начальной загрузки сетки (работает) и кнопка обновления, которая мне так нужна для работы.
require([ 'dojo/store/Observable' ,'dijit/Dialog', 'dijit/form/Select', 'dijit/form/MultiSelect', 'dijit/form/TextBox', 'dijit/layout/TabContainer', 'dijit/layout/ContentPane','dojo/request', 'dojo/request/xhr', 'dijit/form/ToggleButton', 'dijit/form/Button', 'dojo/parser', 'dojo/_base/declare', 'dgrid/Grid', 'dgrid/Selection', 'dgrid/Editor', 'dgrid/extensions/ColumnHider', 'dgrid/extensions/Pagination', 'dstore/RequestMemory', 'dijit/form/Select', 'dijit/registry','dojox/data/XmlStore', 'dojo/domReady!'], function (Observable, Dialog, Select, MultiSelect, TextBox, TabContainer, ContentPane, request, xhr, ToggleButton, Button, parser, declare, Grid, Selection, Editor, ColumnHider, Pagination, RequestMemory, Select, registry, XmlStore) {
//workers dgrid
var workersStore = new RequestMemory({ target: '/autoAssign/getWorkers.aa?TASKTYPE=transport&INACTIVE=FALSE' });
var workerGrid = new (declare([ Grid, Selection, Pagination, Editor, ColumnHider ]))({
collection: workersStore,
className: 'dgrid-autoheight',
id: 'workerGrid',
rowsPerPage: 6,
columns: {
name: 'Name',
username: {
label: 'username',
hidden: true
},
status: 'Status',
assignedNum: 'Assigned',
completedNum: 'Completed',
avgTime: 'Average',
aaOn: {
label: 'Auto Assign',
editor: 'checkbox',
}
}
}, 'gridNode');
workerGrid.on("dgrid-datachange",function(evt) {
var row = workerGrid.row(evt);
if (evt.cell.column.id == 'aaOn') {
var promise = request('/autoAssign/setUserAaStatus.aa?USERNAME='+row.data.username+'&TASKTYPE=transport&STATUS='+evt.value);
}
});
workerGrid.startup();
//Add refresh Button
var addRefreshButton = new Button({
label: "Refresh",
style: 'float:right;',
onClick: function(){
var promise = workersStore.fetch();
var result = promise.then(function(data){
workerGrid.set("collection", workersStore);
workerGrid.refresh();
alert("refresh pushed");
});
}
}, "refresh").startup();
}
[{"id":1,"name":"trans1","username":"trans1","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":true},{"id":2,"name":"trans2","username":"trans2","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":true},{"id":3,"name":"trans3","username":"trans3","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":false},{"id":4,"name":"trans4","username":"trans4","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":false},{"id":5,"name":"trans5","username":"trans5","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":false},{"id":6,"name":"trans6","username":"trans6","status":"Available","inactive":"no","checkedout":"false","details":"","assignedNum":"0","completedNum":"0","avgTime":"00:00","aaOn":false}]
Любая помощь будет принята с благодарностью. Ранее я делал это со старой сеткой данных Додзё и просто не могу понять, что мне здесь не хватает.
1 ответ
Технически, чтобы сделать то, что вы хотите, вам нужно обновить локальное хранилище, таким образом. dstore/RequestMemory
по сути, композиция dstore/Request
а также dstore/Cache
где один fetch
Запрос выполняется немедленно, а затем кэширующее хранилище выставляет все будущие операции выборки. Чтобы принудительно обновить хранилище с сервера, вам необходимо сообщить хранилищу, что его кэш больше не действителен, а затем повторно запросить все элементы с сервера. Это соответствует следующему:
workersStore.invalidate(); // Invalidate the cache
workersStore.fetch(); // Perform a new request for all items
workerGrid.refresh();
Как только это fetch
выполняется, то Cache
Хранилище поймет, что оно может затем извлечь все запросы из своего хранилища в памяти.
(The fetch
Звонок важен - если вы не звоните fetch
выше, ваша сетка, вероятно, не будет работать так, как вы ожидаете. Модули dgrid OnDemandGrid и Pagination выполняют ранжированные запросы, используя fetchRange
и, если Cache не знает, что у него есть все данные хранилища, он просто пропустит эти данные в исходное хранилище, которым в данном случае является запрос, который попытается получить доступ к серверу - за исключением того, что ваш сервис, по-видимому, не оборудован для обработки удаленного доступа. запросы, поэтому он будет просто возвращать весь набор данных каждый раз.)
Правда, я бы сказал, что это больше информации, чем нужно знать кому-то, использующему RequestMemory, поэтому я, вероятно, собираюсь представить проблему для какого-то API для обновления и / или обновления target
, Три строки кода выше - это TL;DR.