EasyUI中datagrid的行编辑模式中,找到特定的Editor,并为其添加事件

// 绑定事件, index为当前编辑行

var editors = $('#staffLogDetailGrid').datagrid('getEditors', index);     
console.info(editors[5]);
var sfgzEditor = editors[5];
sfgzEditor.target.bind('change',function () {
    console.info("111");
    console.info(sfgzEditor.target.val());
});

以上的edit类型是: 'validatebox',如下所示;

editor : {
    type : 'validatebox',
    options : {
       required : true
    }
}

绑定的是change事件;即单元格的内容改变时(无须失去焦点,只要内容改变就行了);

当然也可以绑定其他时间: 比如”blur”: 失去焦点的时候,实际中也有这种需求的, 比如一个单元格编辑完成后, 同时其他某些单元格的内容也会随之变化;

Bind是绑定的意识,即绑定事件的功能;Change, blur, bind这些方法都在edit(Object).target里面; 

Type为'validatebox'也是可以的; 可是type为’combobox’好像change和blur事件都无法正常触发;

可是 console.info(editors[5]),输出的target 属性值为: Object[input.combobox-f],这是一个combobox对象;可以直接对其赋事件的; 所以代码如下:

 

// 绑定事件

var editors = $('#staffLogDetailGrid').datagrid('getEditors', lastIndex);     
console.info(editors[3]);
var sfgzEditor = editors[3];
var sfgzCobobox = sfgzEditor.target;
console.info(sfgzCobobox);
sfgzCobobox.combobox({  
    onChange : function(n,o){
console.info("111");
    }
});

这样就可以给typecomboboxedit绑定事件了;

EasyUI,点击开启编辑框,并且编辑框获得焦点的方法

onClickRow : function(rowIndex, rowData){
     var editor = $('#datagrid').datagrid('getEditor', {index:rowIndex,field:"buyNum"});
     editor.target.focus();
 }

有时候在行编辑的时候,一个编辑框的值要根据其它编辑框的值进行变化,那么可以通过在开启编辑时,找到特定的Editor,为其添加事件

function editrow(index) {    
if (rowedit == 0) {        
$('#ZCEditList').datagrid('beginEdit', index);        
rowedit = 1;
var editors = $('#ZCEditList').datagrid('getEditors', index);            
var TonsEditor = editors[3];        
var HorsepowerEditor = editors[4];           
var StandardEditor = editors[10];         
TonsEditor.target.bind('blur', function () {            
HorsepowerEditor.target.val('');            
var sum = TonsEditor.target.val() * 10;                    
StandardEditor.target.val(sum);
        });        
} }





转载于:https://my.oschina.net/u/2331760/blog/403105

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 WPF DataGrid 编辑单元格,可以使用以下步骤: 1. 将 DataGrid 的属性 `IsReadOnly` 设置为 `False`,这样就可以允许用户编辑单元格。 2. 在 XAML ,使用 DataGridTemplateColumn 模板列来定义一个可以编辑的单元格。例如: ```xml <DataGridTemplateColumn Header="Name"> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <TextBlock Text="{Binding Name}" /> </DataTemplate> </DataGridTemplateColumn.CellTemplate> <DataGridTemplateColumn.CellEditingTemplate> <DataTemplate> <TextBox Text="{Binding Name, UpdateSourceTrigger=PropertyChanged}" /> </DataTemplate> </DataGridTemplateColumn.CellEditingTemplate> </DataGridTemplateColumn> ``` 上述代码,我们定义了一个 DataGridTemplateColumn 列,其包含一个 CellTemplate 和一个 CellEditingTemplate。CellTemplate 用于显示单元格的值,而 CellEditingTemplate 用于编辑单元格的值。在这个例子,我们显示了一个 TextBlock 来显示单元格的值,并且在编辑模式下使用了一个 TextBox 来允许用户编辑单元格的值。 3. 在 ViewModel 实现 INotifyPropertyChanged 接口,并确保属性的 setter 调用 PropertyChanged 事件。这是为了确保在单元格编辑时能够正确地更新数据源。 ```csharp public class PersonViewModel : INotifyPropertyChanged { private string _name; public string Name { get { return _name; } set { if (_name != value) { _name = value; OnPropertyChanged("Name"); } } } public event PropertyChangedEventHandler PropertyChanged; protected virtual void OnPropertyChanged(string propertyName = null) { PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName)); } } ``` 上述代码,我们实现了一个 PersonViewModel,它包含一个 Name 属性,并且当 Name 属性发生变化时会触发 PropertyChanged 事件。 4. 在 DataGrid 的 ItemsSource 绑定数据源,并确保每个单元格的 DataContext 都是一个 ViewModel 实例。这样,在编辑单元格时,WPF 就会自动更新 ViewModel 的属性,并且在更新后重新绑定单元格的值。 ```xml <DataGrid ItemsSource="{Binding People}" AutoGenerateColumns="False"> <DataGrid.Columns> <DataGridTemplateColumn Header="Name" Width="*"> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <TextBlock Text="{Binding Name}" /> </DataTemplate> </DataGridTemplateColumn.CellTemplate> <DataGridTemplateColumn.CellEditingTemplate> <DataTemplate> <TextBox Text="{Binding Name, UpdateSourceTrigger=PropertyChanged}" /> </DataTemplate> </DataGridTemplateColumn.CellEditingTemplate> </DataGridTemplateColumn> </DataGrid.Columns> </DataGrid> ``` 上述代码,我们绑定了一个名为 People 的集合到 DataGrid 的 ItemsSource 属性,并且在 CellTemplate 和 CellEditingTemplate 使用了 Name 属性来绑定单元格的值。注意,在编辑单元格时,我们使用了 UpdateSourceTrigger=PropertyChanged,这样在用户输入时可以立即更新数据源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值