最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JS类中定义原型方法的两种实现的区别_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 20:36:06
文档

JS类中定义原型方法的两种实现的区别_javascript技巧

JS类中定义原型方法的两种实现的区别_javascript技巧:我们知道,给JavaScript类添加原形(prototype)方法是很简单的。而且常用的有下面这两种方法,可是这两种方法在使用时有区别吗? JScript Class: function JSClass() { } Extends prototype method: JSClass.protot
推荐度:
导读JS类中定义原型方法的两种实现的区别_javascript技巧:我们知道,给JavaScript类添加原形(prototype)方法是很简单的。而且常用的有下面这两种方法,可是这两种方法在使用时有区别吗? JScript Class: function JSClass() { } Extends prototype method: JSClass.protot


我们知道,给JavaScript类添加原形(prototype)方法是很简单的。而且常用的有下面这两种方法,可是这两种方法在使用时有区别吗?

JScript Class:
function JSClass()
{

}
Extends prototype method:
JSClass.prototype.MethodA = function()
{

};
Or

function = JSClass.prototype.MethodA()
{

};
其实这两个原形定义方式可以简化一下来讨论,先把它们看作是两个函数,如下:
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()),完全是因为它指向的是一个函数对象的实例而已。
再来看原形方法导入里的两种方式,就很简单了。并且不同的执行优先循序,也决了它们在使用中的不同,看如下示例:

function NormalClass()
{
this.m_Property1 = ’P1 in Normal Class.’;
this.m_Property2 = ’P2 in Normal Class.’;

this.toString = function()
{
return ’[class NormalClass]’;
}

return new InnerClass();

function InnerClass()
{
this.m_Property1 = ’P1 in Inner Class.’;
this.m_Property2 = ’P2 in Inner Class.’;

this.toString = function()
{
return ’[class InnerClass]’;
}
}

InnerClass.prototype.Method1 = function()
{
alert(this.m_Property1);
};

function InnerClass.prototype.Method2()
{
alert(this.m_Property2);
};
}

执行:
var nc = new NormalClass();
nc.Method1();
nc.Method2();

是什么效果?为什么?

文档

JS类中定义原型方法的两种实现的区别_javascript技巧

JS类中定义原型方法的两种实现的区别_javascript技巧:我们知道,给JavaScript类添加原形(prototype)方法是很简单的。而且常用的有下面这两种方法,可是这两种方法在使用时有区别吗? JScript Class: function JSClass() { } Extends prototype method: JSClass.protot
推荐度:
标签: js 方式 的区别
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top