4

HTML:

<div data-bind="koGrid: gridOptions" style="height:600px;border:solid 1px #ccc;"></div>

JS:

列定义:

{ field: 'orderCatalogUpdateID', cellTemplate: '<button data-bind="click: $userViewModel.removeItem">X</button>', displayName: ' ', width: '2%' }`

ViewModel 上的 removeItem 函数:

self.removeItem = function (item) {
    self.list.remove(item);
}

item传递给函数的removeItem不是绑定到行的数据项,而是 KoGrid 列。如何获取绑定到行的数据项,以便将其传递给remove可观察数组上的函数?

我尝试使用 jQuery 和各种单元格模板连接单击事件,尝试传入绑定到行的数据项,但没有成功。

4

1 回答 1

5

默认情况下,当前数据上下文被传递给处理程序,它是文档click中描述的当前列对象:

$data: kg.Column: //列实体

您需要传入的是$parent.entity: //your data model当前行实体。

所以你需要改变你的绑定:

{ 
    field: 'orderCatalogUpdateID', 
    cellTemplate: '<button data-bind="click: ' + 
       ' function() { $userViewModel.removeItem($parent.entity); }">X</button>', 
    displayName: ' ', 
    width: '2%' 
}

演示JSFiddle

于 2013-08-22T09:19:04.793 回答