在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中对对象的处理机制
感谢大家的帮助
[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造成的两个对象使用这个方法,当然属于不同对象的变量是不一样的。
不是同一个对象,当然不一样了。