0

データを取得して要素のリストを作成する Object クラスを作成しようとしています。また、クラスのメソッドを起動する新しい LI にクリック イベントを追加したいと考えています。ただし、

el.click(function() {
    this.method();
});

thisクラスを参照しなくなったため、 をクリックするとli未定義のメソッド エラーが発生します。新しく作成された要素にクラス メソッドをアタッチする方法についての提案はありますか?

JS コード:

if (typeof Object.create !== 'function') {
    Object.create = function(o) {
        function F() {}
        F.prototype = o;
        return new F();
    };
}

var base = {
    init: function(data) {
        this.data = data;
        this.show_data();
    },


    show_data: function() {

        for (i = 0; i < this.data.bindings.length; i++) {

            var $item = $('<li>' + this.data.bindings[i].ircEvent + '</li>');
            $item.click(function() {
                this.show_clicked(i);
            });
            $('#it').append($item);
        }
    },

    show_clicked: function(index) {
        console.log('clicked in method');
    }
};

var extended = {

    show_alert: function() {
        alert('second class');
    }
};


var myObj = {
    "bindings": [
        {
        "ircEvent": "PRIVMSG",
        "method": "newURI",
        "regex": "^http://.*"},
    {
        "ircEvent": "PRIVMSG",
        "method": "deleteURI",
        "regex": "^delete.*"},
    {
        "ircEvent": "PRIVMSG",
        "method": "randomURI",
        "regex": "^random.*"}
    ]
};

$(document).ready(function() {

    var baseObj = Object.create(base);
    baseObj.init(myObj);

});

フィドル: http://jsfiddle.net/kmfstudios/EwC3r/5/

4

1 に答える 1

1

クリック関数でメソッドを機能させるには、オブジェクトを含むグローバル変数を参照するだけです。

この線:

    this.show_clicked(i);

次のように変更する必要があります。

   base.show_clicked(i);

インデックス値を最終結果に表示したい場合は、それをデータとして渡すか、jquery を使用してクリックされたインデックスを特定する必要があります。

これは動作する更新されたフィドルです - http://jsfiddle.net/EwC3r/4/

于 2012-07-16T19:07:16.793 に答える