例は、このJSFiddleで見ることができます
インスタンスを作成し、そのインスタンスの関数の 1 つを変更してから、そのインスタンスの別の関数内でその関数を呼び出しています。更新された関数内のローカル変数とインスタンス変数にアクセスできません。
コード
var MyObj = function (name) {
var that = this;
MyObj.myObjs = (MyObj.myObjs || []),
this.objName = name,
this.objIdx = MyObj.myObjs.length;
MyObj.myObjs.push(this.objName);
this.doOnSetName = function () {};
this.setName = function (name) {
that.doOnNameSet();
that.objName = name;
MyObj.myObjs[that.objIdx] = name;
}
}
var obj1 = new MyObj("obj1");
//obj1.doOnNameSet = function() { alert("objName: "+this.objName) };
//obj1.setName("obj1");
var obj2 = new MyObj("obj2");
obj2.doOnNameSet = function () {
$("#console").append("Old objName: " + this.name
+ "<br />New objName: " + name + "<br />")
};
obj2.setName("obj2 - changed");
$("#console ").append("Objects: <br />*" + MyObj.myObjs.join(", <br />*"));
実際の結果
Old objName: undefined
New objName: result
Objects:
*obj1,
*obj2 - changed
望ましい結果
Old objName: obj2
New objName: obj2 - changed
Objects:
*obj1,
*obj2 - changed