JS类定义原型方法的两种实现的区别评论很多_js面向对象
我们知道,给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类定义原型方法的两种实现的区别 回复 更多评论
<script> <BR>function JSClass() <BR>{ <BR>} <br><br>function = JSClass.prototype.MethodA() <BR>{ <br><br>}; <BR></script>
提示出错乜。
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类定义原型方法的两种实现的区别 回复 更多评论
再来看原形方法导入里的两种方式,就很简单了。并且不同的执行优先循序,也决了它们在使用中的不同,看如下示例:
<script> <BR>function NormalClass() <BR>{ <BR> this.m_Property1 = 'P1 in Normal Class.'; <BR> this.m_Property2 = 'P2 in Normal Class.'; <br><br> this.toString = function() <BR> { <BR> return '[class NormalClass]'; <BR> } <br><br> return new InnerClass(); <br><br> function InnerClass() <BR> { <BR> this.m_Property1 = 'P1 in Inner Class.'; <BR> this.m_Property2 = 'P2 in Inner Class.'; <br><br> this.toString = function() <BR> { <BR> return '[class InnerClass]'; <BR> } <BR> } <br><br> InnerClass.prototype.Method1 = function() <BR> { <BR> alert(this.m_Property1); <BR> }; <br><br> function InnerClass.prototype.Method2() <BR> { <BR> alert(this.m_Property2); <BR> }; <BR>} <BR></script>
执行:
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,我好可怜啊~~~

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

利用轻松的网页布局:8个基本插件 jQuery大大简化了网页布局。 本文重点介绍了简化该过程的八个功能强大的JQuery插件,对于手动网站创建特别有用

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

该帖子编写了有用的作弊表,参考指南,快速食谱以及用于Android,BlackBerry和iPhone应用程序开发的代码片段。 没有开发人员应该没有他们! 触摸手势参考指南(PDF) Desig的宝贵资源

jQuery是一个很棒的JavaScript框架。但是,与任何图书馆一样,有时有必要在引擎盖下发现发生了什么。也许是因为您正在追踪一个错误,或者只是对jQuery如何实现特定UI感到好奇

10款趣味横生的jQuery游戏插件,让您的网站更具吸引力,提升用户粘性!虽然Flash仍然是开发休闲网页游戏的最佳软件,但jQuery也能创造出令人惊喜的效果,虽然无法与纯动作Flash游戏媲美,但在某些情况下,您也能在浏览器中获得意想不到的乐趣。 jQuery井字棋游戏 游戏编程的“Hello world”,现在有了jQuery版本。 源码 jQuery疯狂填词游戏 这是一个填空游戏,由于不知道单词的上下文,可能会产生一些古怪的结果。 源码 jQuery扫雷游戏

本教程演示了如何使用jQuery创建迷人的视差背景效果。 我们将构建一个带有分层图像的标题横幅,从而创造出令人惊叹的视觉深度。 更新的插件可与JQuery 1.6.4及更高版本一起使用。 下载
