我在c#中构建了一个infragistics webdatagrid:
var columnOne = new BoundDataField();
columnOne.DataFieldName = "ColumnOne";
columnOne.Key = "columnOne";
columnOne.Header.Text = "columnOne";
var columnTwo = new BoundDataField();
columnTwo.DataFieldName = "ColumnTwo";
columnTwo.Key = "columnTwo";
columnTwo.Header.Text = "columnTwo";
WebDataGridObject.DataKeyFields = "ColumnOne";
WebDataGridObject.Columns.Add(columnOne);
WebDataGridObject.Columns.Add(columnTwo);
我想从javascript更新第二列中的单元格,当在第一列的单元格中输入内容时。
例如,我的用户开始在第3行和第1列的单元格中键入值,第2行和第2列的单元格必须使用常量值自动更新,例如“已更新”。
要做到这一点,我有点挣扎,我从c#附加了很多客户事件,我认为有用的是keydown:
WebDataGridObject.ClientEvents.MouseDown = "WebDataGridView_MouseDown";
WebDataGridObject.ClientEvents.KeyDown = "WebDataGridView_KeyDown";
WebDataGridObject.Behaviors.EditingCore.Behaviors.CellEditing.CellEditingClientEvents.EnteredEditMode = "enteredEditMode";
WebDataGridObject.Behaviors.EditingCore.Behaviors.CellEditing.CellEditingClientEvents.ExitedEditMode = "exitedEditMode";
我想要我的js keydown事件处理程序,获取当前编辑的单元格的列键,如果它等于“columnOne”,则在同一行和第二列更新单元格的值。这是我的js:
function WebDataGridView_KeyDown(webDataGrid, evntArgs) {
}
function WebDataGridView_MouseDown(webDataGrid, evntArgs) {
// this is where I am trying to get the column key of the currently edited cell
webDataGrid.get_behaviors().get_selection().get_selectedRowsResolved() [0].get_cell(3).get_text()
}
var gridRef;
var cellRef;
function enteredEditMode(grid, args) {
gridRef = grid;
cellRef = args.getCell();
if (cellRef._column._key === "headerName") {
alert('toto');
}
}
function exitedEditMode(grid, args) {
gridRef = null;
cellRef = null;
}
答案 0 :(得分:0)
要获取列键,您应该尝试:
webDataGrid.get_behaviors().get_selection().get_selectedRowsResolved()[0].get_cell(3).get_column().get_key();
或者这个:
webDataGrid.get_behaviors().get_selection().get_selectedRowsResolved()[0].get_cell(3).get_column()._dataFieldName
答案 1 :(得分:0)
为了获得将要进入编辑模式的单元格的列键,建议使用 eventArgs 参数。
您将在下面找到可以访问此信息的两个客户端事件(列密钥)
function WebDataGrid1_CellEditing_EnteringEditMode(sender, eventArgs)
{
// Get the key of the currently edited cell
var columnKey = eventArgs.getCell().get_column().get_key();
}
function ClientEvents_MouseDown(sender, eventArgs) {
// Get the key of the currently edited cell
var columnKey = eventArgs.get_item().get_column().get_key();
}
正如您将看到 eventArgs
中的 getCell 和 getItem 方法的不同之处