在ExtJS Grid中选中复选框时,如何关注可编辑的文本字段?

时间:2013-04-18 10:01:05

标签: extjs grid extjs4

我正在使用checkcolumn和celledit创建一个网格。我有3列1用于复选框,其他是可编辑的文本字段,第3列是productname,使用celledit编辑价格。

当我检查记录上的复选框时,焦点应该在该特定记录的文本字段上。

以下是代码示例:

Ext.define('MyApp.view.EntryPage',
{
extend : 'Ext.grid.Panel',
alias : 'widget.entryPage',
title : 'Product Price Entry',
store : 'ProductStore',
loadMask: true,

plugins: [Ext.create('Ext.grid.plugin.CellEditing', {clicksToEdit: 1})],

initComponent:function(){

    var me = this;
    this.selModel = {xtype:'cellmodel'},

    this.columns = {
                defaults:{sortable : true,hideable : true,menuDisabled : true,align : 'left',style : 'text-align:left'},
                items:[
                          {

                              xtype: 'checkcolumn',
                              header: 'Check Me',
                              dataIndex : 'active',
                              listeners:{

                              checkchange : function( CheckColumn, rowIndex, checked, eOpts ){
                              // Select the textfield

                              }}
                          },
                          {
                               text : 'Price',
                               flex:0.75,
                               sortable : false,
                               hideable : false,
                               dataIndex : 'unitprice',
                               editor: 'textfield'
                          },
                          {
                               text : 'Product Name',
                               flex:2,
                               dataIndex : 'pname'
                          }
                    ]};

        //this.features = [];
        this.callParent(arguments);

} 
});

2 个答案:

答案 0 :(得分:1)

在侦听器的帮助下(使用编辑事件),如果已经选中,则获取记录的引用并应用focus()方法。

请参阅以下链接以供参考。

http://docs.sencha.com/extjs/4.0.7/#!/api/Ext.grid.plugin.CellEditing-event-edit

查看上述链接中的编辑事件。

由于

答案 1 :(得分:0)

我解决了这个问题如下:

  checkchange : function( CheckColumn, rowIndex, checked, eOpts ){

         //me.getPlugin('cellplugin').startEdit(record,1);     
         me.getPlugin('cellplugin').startEditByPosition({row: rowIndex, column: 1});        

   }}

这很有效...... Hariharan感谢您的回答!!