标题:<js高程>里面的对象冒充,不明白objB.sayColor();这句为什么会运行正确? ...
取消只看楼主
境善
Rank: 2
等 级:论坛游民
帖 子:76
专家分:16
注 册:2012-10-29
结帖率:86.21%
已结贴  问题点数:2 回复次数:3 
<js高程>里面的对象冒充,不明白objB.sayColor();这句为什么会运行正确?
问题:delete this.newMethod;这句已经删除了对ClassA中的方法和属性的引用,为什么objB.sayColor();还能执行正确?
function ClassA(sColor){objB.sayColor();
   this.color=sColor;
   this.sayColor=function(){
    alert(this.color);
   }
}

function  ClassB(sColor,sName){
   this.newMethod=ClassA;
   this.newMethod(sColor);
   delete this.newMethod;
   this.name=sName;
   this.sayName=function(){
    alert(this.name);
   }
}

var objA=new ClassA("red");
var objB=new ClassB("blue","Nick");
objA.sayColor();
objB.sayColor();
objB.sayName();

[ 本帖最后由 境善 于 2015-5-15 09:54 编辑 ]
搜索更多相关主题的帖子: function 
2015-05-15 09:52
境善
Rank: 2
等 级:论坛游民
帖 子:76
专家分:16
注 册:2012-10-29
得分:0 
回复 楼主 境善
代码的第一行右边的objB.sayColor();多写了。。
2015-05-15 10:52
境善
Rank: 2
等 级:论坛游民
帖 子:76
专家分:16
注 册:2012-10-29
得分:0 
回复 2楼 jsRank
明白了 谢谢~~
2015-05-15 10:54
境善
Rank: 2
等 级:论坛游民
帖 子:76
专家分:16
注 册:2012-10-29
得分:0 
回复 楼主 境善
function ClassA(sColor){
   this.color=sColor;
   this.sayColor=function(){
    alert(this.color);
   }
}

function  ClassB(sColor,sName){
   this.newMethod=ClassA;
   this.newMethod(sColor);
   delete this.newMethod;
   this.name=sName;
   this.sayName=function(){
    alert(this.name);
   }
}

var objA=new ClassA("red");
var objB=new ClassB("blue","Nick");
objA.sayColor();
objB.sayColor();
alert(objB.color);//根据二楼讲解 这一行也会正确执行,且是blue,注意体会!!
objB.sayName();
2015-05-15 10:56



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-445319-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 1.099413 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved