javascript中对象的理解

在javascript中,定义了这样一个简单的类
function FlagCtlTools()
{
this.canSelectFlag = true;

this.canSelectCheck = function()
{
    return this.canSelectFlag;
}

this.setCanSelectFlag = function(canSelectBool)
{
    this.canSelectFlag = canSelectBool;
}

}

在一个frame结构的页面中使用到这个类,此类放在common.js文件中,此文件共同被leftframe和rightframe引用
leftframe中通过调用var flag = new FlagCtlTools() 定义了对象flag
在rightframe中通过parent.window.leftframe.flag .setCanSelectFlag(false);设定this.canSelectFlag 为false,此时,在leftframe调用flag.canSelectCheck()仍然返回true

为何?实在是不太理解javascript中对对象的处理机制
感谢大家的帮助

5个回答

[quote="fxhnkf"][code="js"]function FlagCtlTools() {
this.canSelectFlag = true;

this.canSelectCheck = function() {
return this.canSelectFlag;
}

this.setCanSelectFlag = function(canSelectBool) {
this.canSelectFlag = canSelectBool;
}
}[/code][/quote]
首先这不是一个“类”,其次“this”在嵌套函数的内外并不一定总指向一个对象。如果要保证总指向一个对象,你需要显式把this赋值给别的变量备份起来:
[code="js"]function FlagCtlTools() {
var thisObj = this
thisObj.canSelectFlag = true

this.canSelectCheck = function() {
return thisObj.canSelectFlag
}

this.setCanSelectFlag = function(canSelectBool) {
thisObj.canSelectFlag = canSelectBool
}
}[/code]

楼主或许会有兴趣读读我以前记过的一篇,[url=http://rednaxelafx.iteye.com/blog/176500]JavaScript的"this"[/url]

你用firebug跟踪一下,设置值的时候你用到了this引用,可是当你实际调用的时候this发生了变化,可能是iframe的原因,所以很多js库都不推荐使用iframe,具体情况还要取决于浏览器

不错啊,楼上的文章讲得很不错!

估计是iframe造成的两个对象使用这个方法,当然属于不同对象的变量是不一样的。

不是同一个对象,当然不一样了。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问