Добавить пустую строку в dojox/grid/DataGrid

<div id="gridDiv"></div>
<button id="addRow"  data-dojo-type="dijit.form.Button">Add Row</button>


require(['dojo/_base/lang', 'dojox/grid/DataGrid' , 'dojo/data/ItemFileWriteStore' , 'dojo/dom' , 'dojo/domReady!'],
  function(lang, DataGrid, ItemFileWriteStore, Button, dom){
    /*set up data store*/
    var data = {
      identifier: "id",
      items: []
    };

    var store = new ItemFileWriteStore({data: data});

    /*set up layout*/
    var layout = [[
      {'name': 'Column 1', 'field': 'id', 'width': '100px'},
      {'name': 'Column 2', 'field': 'col2', 'width': '100px'},
      {'name': 'Column 3', 'field': 'col3', 'width': '200px'},
      {'name': 'Column 4', 'field': 'col4', 'width': '150px'}
    ]];

    /*create a new grid*/
    var grid = new DataGrid({
        id: 'grid',
        store: store,
        structure: layout,
        rowSelector: '20px'});

    /*append the new grid to the div*/
    grid.placeAt("gridDiv");

    /*Call startup() to render the grid*/
    grid.startup();
});
  • У меня есть программно созданный dojox/grid/DataGrid без данных (пустое хранилище) в нем... только макет.
  • И у меня есть кнопка вне сетки.
  • Мне нужно, нажав кнопку, мне нужно добавить одну пустую строку в сетку. эта пустая строка не должна быть из json. он должен быть из магазина.
  • это означает, что при нажатии кнопки в хранилище должна быть добавлена ​​пустая строка, а затем сетка загружается с этим хранилищем. Является ли это возможным?

person Rachel    schedule 17.04.2013    source источник


Ответы (1)


Эта скрипта добавляет новый элемент в магазин при нажатии кнопки. И сетка обновится, чтобы отразить новое содержимое магазина.

Суть кода такова:

var id = 0;

var button = new Button({
    onClick: function () {
        store.newItem({
            id: id,
            col2: "col2-" + id,
            col3: "col3-" + id,
            col4: "col4-" + id
        });
        id++;
    }
}, "addRow");

Скриншот (после 2-х нажатий кнопки):

введите здесь описание изображения

person Paul Grime    schedule 17.04.2013