infragistics webdatagrid从客户端

时间:2016-09-07 13:33:00

标签: javascript c# webdatagrid

我在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;
}

2 个答案:

答案 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 方法的不同之处