对象方法为jqGrid回调

时间:2011-10-14 09:46:15

标签: javascript methods jqgrid callback

我有一个带有方法的对象,我想成为网格中的回调。我该怎么办?

非工作示例代码:

var GridHolder = function() {
    //...
    this.lastSel = null;
    //...
};
GridHolder.prototype = {
   //...
    someAction : function(id){ /*doSomeWork();*/},
    rowSelect : function(id){
        this.someAction(id); // failed
        if(id && id !== this.lastSel){
            jQuery('#grid_id').restoreRow(this.lastSel);
            this.lastSel=id;
        }
        jQuery('#grid_id').editRow(id, true);
    }
   //...
};
var gridHolder = new GridHolder();
jQuery('#grid_id').jqGrid({
    //...
    onSelectRow: gridHolder.rowSelect,
    //...
});

现在,jqGrid使用'call'调用回调,并在方法中替换'this'。

即:

if( $t.p.onSelectRow && onsr) { $t.p.onSelectRow.call($t, pt.id , stat); } // this === $t in callback instead of gridHolder

1 个答案:

答案 0 :(得分:0)

var gridHolder = new GridHolder();
jQuery('#grid_id').jqGrid({
    //...
    onSelectRow: function(id) { gridHolder.rowSelect(id); },
    //...
});

应该在正确的上下文中执行。