5

たとえば、ボタンからJavaScript関数から行を削除する方法

4

7 に答える 7

16

DataViewを使用している場合は、以下を使用してください。

DataView.deleteItem(RowID);//RowID is the actual ID of the row and not the row number
Grid.invalidate();
Grid.render();

行番号しかわからない場合は、次を使用してRowIDを取得できます。

var item = DataView.getItem(RowNum);//RowNum is the number of the row
var RowID = item.id
于 2011-01-24T16:07:47.653 に答える
6

jQueryを使用しているとします

var grid;
$(function () {
   // init options, load data  
   ...

   var columns = [];
   columns[0] = { 
     id: 'id',
     name: '#', 
     field: 'id', // suppose you have an id column in your data model
     formatter: function (r, c, id, def, datactx) { 
        return '<a href="#" onclick="RemoveClick(' + id + ',' + r + ')">X</a>'; }
   }
   // init other columns
   ...

   grid = new Slick.Grid($('#gridDiv'), data, columns, options);
}
function RemoveClick(databaseId, gridRow) {
   // remove from serverside using databaseId
   ...
   // if removed from serverside, remove from grid using
   grid.removeRow(gridRow);
}
于 2010-10-14T09:14:09.420 に答える
5

これは私がそれを行う方法です(ただし、データプロバイダーは使用しません):

//assume that "grid" is your SlickGrid object and "row" is the row to be removed
var data = grid.getData(); 
data.splice(row, 1);
grid.setData(data);
grid.render();

これをライブプロジェクトで使用していますが、うまく動作します。もちろん、複数の行を削除したい場合は、いくつかの調整を行う必要があります。または、データ プロバイダーを使用している場合は、データ プロバイダーからのみ行を削除し、SlickGrid で行を更新するだけにすることもできます。

それが役に立てば幸い :)

于 2011-05-23T08:25:48.110 に答える
4
function deleteRows() {
    var selectedIndexes = grid.getSelectedRows().sort().reverse();
    var result = confirm("Are you sure you want to delete " + grid.getSelectedRows().length + " row(s)?");
    if (result) {

      $.each(selectedIndexes, function (index, value) {
        var item = dataView.getItem(value); //RowNum is the number of the row
        if (item)
          dataView.deleteItem(item.id); //RowID is the actual ID of the row and not the row number
      });

      grid.invalidate();
      grid.render();
    }
  }
于 2014-12-16T19:20:37.023 に答える
1
var rowsToDelete = grid.getSelectedRows().sort().reverse();
for (var i = 0; i < rowsToDelete.length; i++) {
    data.splice(rowsToDelete[i], 1);
}
grid.invalidate();
grid.setSelectedRows([]);
于 2014-10-22T08:10:52.290 に答える
-2

はい、もちろん、私はそれをこのように使用します

var selrow = grid.getSelectedRows (); 
data.splice(selrow, 1); 
grid.invalidateAllRows();
grid.render ();

ご挨拶

于 2011-05-24T04:17:32.567 に答える
-3

こんにちは、SlickGrid の行を削除するためにこのスクリプトを使用しています

関数 deletefila(numrow) {

  alert("delete row"+numrow);

  data.splice(numrow,1); 

    grid.removeAllRows(); 

    grid.render(); 

        //grid.removeRow(5);

        //grid.updateRowCount();

        //and then invalidate and re-render the grid by calling grid.removeAllRows() followed by grid.render(). 

}

于 2010-10-18T00:12:19.680 に答える