3

initialize()函数内部有一个 jQueryeach循环。在该循环内部是一个引用,由于 jQuery 已重新分配给当前循环元素,因此该引用this.dbcolumns显然不起作用。this那么如何this.dbcolumns从循环内部引用呢?它可以在循环之外工作。

function datatable() {
    this.url = '';
    this.htmltable = '';
    this.dbtable = '';
    this.dbcolumns = new Array();
    this.idfield = 'id';
    this.pageno = 0;
    this.pagesize = 15;
    this.totalpages = 0;
    this.totalrecords = 0;
    this.searchterm = '';

    this.initialize = function() {
        this.dbtable = $(this.htmltable).attr('data-table');
        this.dbcolumns.push(this.idfield);
        $(this.htmltable + ' th[data-field]').each(function(i, col){
            this.dbcolumns.push( $(col).attr('data-field') ); /* <<<<<<<<<< this line */
        });
        return this;
    }
} 
4

3 回答 3

14

引用您想要在循环之外保留的“this”。

var self = this;

然后你可以在循环中使用“self”。

于 2012-06-17T10:02:45.637 回答
4

存储对回调this外部的引用each,或使用 ES5bind方法

$(this.htmltable + ' th[data-field]').each(function(i, col){
     this.dbcolumns.push( $(col).attr('data-field') );
}.bind(this));

或者,如评论中所述,使用$.proxy

$(this.htmltable + ' th[data-field]').each($.proxy(function(i, col){
     this.dbcolumns.push( $(col).attr('data-field') );
}, this));
于 2012-06-17T10:03:04.543 回答
3

要解决的常见 JS 模式是使用闭包:

this.initialize = function() {
    var that = this;

    this.dbtable = $(this.htmltable).attr('data-table');
    this.dbcolumns.push(this.idfield);
    $(this.htmltable + ' th[data-field]').each(function(i, col){
        that.dbcolumns.push( $(col).attr('data-field') ); /* <<<<<<<<<< this line */
    });
    return this;
}
于 2012-06-17T10:04:08.693 回答