4

dgridの複数のセルを同時に編集することは可能ですか?

セルをダブル/シングルクリックして更新することで、一度に1つのセルを編集できることを知っています。そして、onBlurそのセルので、編集されたデータがそのセルに対して更新されます。

しかし、私の要件は次のとおりです。

  1. 各行の編集リンク/編集ボタンをクリックすると、その行の編集可能なすべてのセルのエディターが表示されます。
  2. セルを更新/編集し、
  3. 次に、同じ行の保存ボタン(編集ボタンの横にあります)をクリックします。
  4. [保存]リンク/アイコンをクリックすると、編集したセルの値がストア/サーバーに保存されます。

以下は、グリッドの列の一部です。

// one of the editable columns others are also similar to this one.. 
          editor({
                    label:"Outcome", 
                    field:"outcome", 
                    sortable: false, 
                    editorArgs: {
                        options:[
                                  {value: "1", label: "Opt1"},
                                  {value: "2", label: "Opt2"},
                                  {value: "3", label: "Opt3"},
                                ]
                    }, 
                    renderCell: function(row, value, td, options){
                        put(td, "div", outcomeOptionsMap[value] || '');
                    }
                }, Select, "dblclick" ),


// last column
                {label:"Actions", field:"actions",sortable: false, 
            renderCell: function(row, value, td, options){
            newValue = "<a href=\"#\" title=\"Edit\" onclick='editEntireRow(testgrid,event);'><img src='../static/images/edit.gif'/></a>";
            newValue = "<a href=\"#\" title=\"Save\" onclick='saveRow(testgrid,event);'><img src='../static/images/edit.gif'/></a>";
            newValue += "  <a href=\"#\" title=\"Delete\" onclick='testgrid.store.remove("+row.id+");'><img src='../static/images/delete_icon.png'/></a>";
            td.innerHTML = newValue;
            }   

ところで、私はdojo.store.JsonRestをストアとして使用しています。
グリッド宣言

var MyGrid = declare([Grid, Selection, Keyboard]);
window.testgrid = new MyGrid( 
    {
        store       : Observable(Cache(jsonRest, Memory())),
        selectionMode : "none",
        getBeforePut: false,
        columns: getColumns,
        allowSelectAll: true,
        minRowsPerPage: 5,
        maxRowsPerPage: 20,
    }, "gridContainer");

現在、私はこのようなことを試みていますが、機能していません...

function editEntireRow(grid,event){
// cols 3,5,7,8 steps to the left of the Action column are editable
grid.edit(grid.left(grid.cell(event),3));
grid.edit(grid.left(grid.cell(event),5));
grid.edit(grid.left(grid.cell(event),7));
//grid.edit(grid.left(grid.cell(event),8));
}
4

0 に答える 0