How to update value of data in jqgrid

前端 未结 3 1847
清歌不尽
清歌不尽 2020-11-28 12:37

I\'m trying to update a cell in jqgrid permanently upon loading. I know I can use setCell but that only updates the value for that page. If I come back to the

相关标签:
3条回答
  • 2020-11-28 13:29

    For all who came here from google, here is an updated answer!

    important is the index, which you can get by calling getInd-Method. Because rowID != index of localRowData. (eq. rowId: jqg204, Index: 5)

    EDIT: if set "key : true" in colmodel you can set your own rowId (diffrent from my example "jqg###", usually a PK from a database table)

    var ind = myGrid.getInd(rowId);
    var localRowData  = myGrid.jqGrid('getLocalRow', ind);
    localRowData.myColumn = newValue;
    

    hope that helps!

    0 讨论(0)
  • 2020-11-28 13:33

    I had a similar issue:
    I needed to update a row upon a certain user-action (irrelevant).
    For that, I needed to know the exact row from the 'data' object, even after some filtering of the table.
    So I found a way to identify which row was changed - I added a RowID property for each item of the 'data' object, at the 'loadComplete' event:

    loadComplete: function () {
                if (firstRun) {
                    firstRun = false;
                    var dataArray = $('#jqGrid').jqGrid('getGridParam', 'data');
                    $(dataArray).each(function (index) {
                        dataArray[index].RowID = index + 1;
                    });
                }
            }
    

    And now, at the formatter code, I was able to access rData.RowID to identify the exact row on which the action was taken, and to get/set its 'data' representation

    0 讨论(0)
  • 2020-11-28 13:34

    If you use loadonce: true you should know where the local data will be hold by jqGrid. jqGrid has two options: data and _index. The data is array of items where every item has the name property as the name property of the columns from colModel. If you need find the item by id (rowid) you can use _index[rowid] to the the item with the rowid in the data array. So to change the data in the column 'myColumn' you should do the following:

    // first change the cell in the visible part of grid
    myGrid.jqGrid('setCell', rowid, 'myColumn', newValue);
    
    // now change the internal local data
    var dataArray = myGrid.jqGrid('getGridParam', 'data'),
        indexes = myGrid.jqGrid('getGridParam', '_index');
    dataArray[indexes[rowid]].myColumn = newValue;
    

    UPDATED: You can use documented getLocalRow method to change the local data:

    // first change the cell in the visible part of grid
    myGrid.jqGrid('setCell', rowid, 'myColumn', newValue);
    
    // now change the internal local data
    myGrid.jqGrid('getLocalRow', rowid).myColumn = newValue;
    
    0 讨论(0)
提交回复
热议问题