您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

JS类定义原型方法的两种实现的区别评论很多_js面向对象

2025/8/20 8:56:25发布25次查看
我们知道,给javascript类添加原形(prototype)方法是很简单的。而且常用的有下面这两种方法,可是这两种方法在使用时有区别吗? 
    jscript class:
复制代码 代码如下:
function jsclass() 
 {       
 }
extends prototype method: 
复制代码 代码如下:
jsclass.prototype.methoda = function() 
 {
};
or 
 复制代码 代码如下:
function = jsclass.prototype.methoda() 
 {
};
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
我先来说一个简单的区别:这两个方法导入的原型方法,第一个是一个匿名方法;第二个方法有方法名jsclass.prototype.methoda。 
2005-03-01 10:52 | birdshome 
# re: js类定义原型方法的两种实现的区别  回复  更多评论
提示出错乜。 
2005-03-01 13:51 | 阮 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
faint,我发现freetextbox修改少量数据(一两个字符)提交有时会没有效果:( 
我那个是手误多写了个=,可是我记得我修改过了的。 
2005-03-01 14:00 | birdshome 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
     其实这两个原形定义方式可以简化一下来讨论,先把它们看作是两个函数,如下:
  foo1();
function foo1() 
  { 
      alert('this is foo1.'); 
  }
     和   foo2(); 
  var foo2 = function() 
  { 
      alert('this is foo2.'); 
  }
运行第一个显然是不会有任何错误的,可是运行第二个就有问题了,这时系统会说:microsoft jscript runtime error: object expected。这就是说函数定义(foo1)在脚本解析器中有最高的初始化优先级,这个很好理解。如果不优先处理函数,那么对于函数中的函数调用就没有办法处理了,假使我们先定fn1()再定义fn2(),却从fn1中调fn2,那么就通不过解析了。为什么foo2不能被初始化,foo2的定义根本不是函数定义,它是一个标准的赋值语句,之所以能象标准函数一样的使用foo2(foo2()),完全是因为它指向的是一个函数对象的实例而已。
2005-03-03 22:17 | birdshome 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
     再来看原形方法导入里的两种方式,就很简单了。并且不同的执行优先循序,也决了它们在使用中的不同,看如下示例:
执行: 
var nc = new normalclass(); 
nc.method1(); 
nc.method2();
是什么效果?为什么?
2005-03-03 22:21 | birdshome 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
最后结果居然是nc.method1()没有定义,nc.method2()运行正常。
其实不奇怪了,innerclass.prototype.method1 = function()依赖于赋值语句的执行,而 function innerclass.prototype.method2() 以最高优先级被脚本引擎初始化。 
2005-03-05 02:43 | birdshome 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
我在antechinus javascript editor测试你的代码在:
function innerclass.prototype.method2()报错,
syntaxerror:missing( before formal parameters see: .prototype.method2( 
2005-05-10 17:11 | error 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
@error 
用ie来试过吗? 
2005-05-10 17:30 | birdshome 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
我用ff也是一样的报错: missing( before formal parameters see: .prototype.method2( 
2006-08-19 22:40 | jzz 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
return new innerclass(); 把这行移到 
function innerclass.prototype.method2() 

alert(this.m_property2); 
}; 
后面ie执行正常.ff报错: missing( before formal parameters see: .prototype.method2( 
ie是安顺序执行下来的,而ns系列不是! 
ff在执行到function innerclass.prototype.method2() 这个的时候它根本不知道有这个innerclass类,自然就不能无缘无故的来个prototype.xxx的东东 
2006-11-13 00:57 | doutu 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
@doutu 
把return new innerclass();放到function innerclass.prototype.method2()这个方法之后,就完全违背了我编写这个示例的初衷。这个示例恰好说明了,ie对function foo()这种函数定义格式有较高的解析优先级,而foo = function()只是一个普通的赋值语句。至于ff中的情况我没有研究过,既然你说ff找不到return后的innerclass,那么就说明是顺序的解析function foo()这种还属定义格式的。 
2006-11-13 01:29 | birdshome 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
唉。可怜的只会用ie的人呀。 function x.y.z() {} 的写法根本就是不标准的写法,只有ie支持,其他js引擎中如ff或opera都会报错。符合标准的写法只有 x.y.z = function () {};
当然,就语法层面来说,我挺喜欢这种写法的,希望以后的标准能采纳这种写法。 
2006-11-28 11:04 | hax 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
呵呵 hax说得对啊。 只有ie才会像妈妈一样包容孩子的各种错误
标准的写法只有 x.y.z = function () {};
其实,ie还支持更诡异的写法。
看看这个 
function window::onload(){ 
alert(go_rush) 

2006-11-28 14:39 | go_rush 
# re: js类定义原型方法的两种实现的区别  回复  更多评论    
@hax 
标准再好,也是为人服务的,争论这个是学院派和工程派之间的事情,我们实现好我们自己系统就可以了,何必过分在神仙打架。 
// 你的评论其实挺好的。sigh,只可惜因为ie,我好可怜啊~~~
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product