我们知道,给JavaScript类添加原形(prototype)方法是很简单的。而且常用的有下面这两种方法,可是这两种方法在使用时有区别吗? JScript Class: Extends prototype method: Or # 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类定义原型方法的两种实现的区别 回复 更多评论 再来看原形方法导入里的两种方式,就很简单了。并且不同的执行优先循序,也决了它们在使用中的不同,看如下示例:
Javascript 是一种由Netscape的LiveScript发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
来源: http://www.phperz.com/article/16/1208/288620.html