1

なぜの代わりにがconsole.log(Set.current_index)表示されるのかわかりません。03

var Set = (function() {
    var set = [];
    var index = 0;

    function contains(set, e) {
        for (var i = 0; i < set.length; i++) {
            if (set[i] === e) {
                return true;
            }
        }
        return false;
    }

    var add = function(e) {
        if (!contains(set, e)) {
            set[index++] = e;
        }
    }

    var show = function() {
        for (var i = 0; i < set.length; i++) {
            console.log(set[i]);
        }
    }

    return {
        add: add,
        show: show,
        current_index: index
    };
})();​

Set.add(20);
Set.add(30);
Set.add(40);
Set.show();
console.log(Set.current_index);
4

2 に答える 2

4

記述されているように、-の初期値をcurrent_index取得するだけです。その変数はプリミティブ型であるため、その値への変更は反映されません。index

'参照型'(つまり、オブジェクトまたは配列)がある場合、その内容への変更は、同じオブジェクトを参照する他の変数で表示されます。これはプリミティブ型では発生せず、「値によって」新しい変数にコピーされ、元の変数への変更はコピーに影響しません。

の現在の値を返す関数current_indexにするか、現在の値を返す関数を目に見えないように呼び出すことで読み取り専用プロパティとして扱うことができるように記述する必要があります。indexgetter.index

後者の方法の例(ES5、または機能を複製するためのシムが必要)については、 http://jsfiddle.net/alnitak/WAwUg/を参照してください。これにより、現在のreturnブロックが次のように置き換えられます。

var interface = {
    add: add,
    show: show
};

Object.defineProperty(interface, 'index', {
    get: function() {
        return index;
    },
    enumerable: true
});

return interface;
于 2012-10-20T22:42:37.270 に答える
1

Javascriptは、変数がオブジェクトを参照する場合を除いて、常に値を渡します。したがって、current_indexの初期化は、変数を永続的に指すのではなく、 indexの初期値を取得するだけです。したがって、その初期化後、2つの変数は別々の方向にあるため、 indexをインクリメントしてもcurrent_indexはインクリメントされません。

于 2012-10-20T22:54:11.517 に答える