JS类定义原型方法的两种实现的区别
来源:互联网 发布:nginx shtml 编辑:程序博客网 时间:2024/06/05 19:36
我们知道,给JavaScript类添加原形(prototype)方法是很简单的。而且常用的有下面这两种方法,可是这两种方法在使用时有区别吗?
JScript Class:
Extends prototype method:
Or
function = JSClass.prototype.MethodA()
{
};
JScript Class:
function JSClass()
{
}
{
}
Extends prototype method:
JSClass.prototype.MethodA = function()
{
};
{
};
Or
function = JSClass.prototype.MethodA()
{
};
我先来说一个简单的区别:这两个方法导入的原型方法,第一个是一个匿名方法;第二个方法有方法名"JSClass.prototype.MethodA"。
其实这两个原形定义方式可以简化一下来讨论,先把它们看作是两个函数,如下:
Foo1();
function Foo1()
{
alert('This is Foo1.');
}
function Foo1()
{
alert('This is Foo1.');
}
和
Foo2();
var Foo2 = function()
{
alert('This is Foo2.');
}
var Foo2 = function()
{
alert('This is Foo2.');
}
运行第一个显然是不会有任何错误的,可是运行第二个就有问题了,这时系统会说:Microsoft JScript runtime error: Object expected。这就是说函数定义(Foo1)在脚本解析器中有最高的初始化优先级,这个很好理解。如果不优先处理函数,那么对于函数中的函数调用就没有办法处理了,假使我们先定fn1()再定义fn2(),却从fn1中调fn2,那么就通不过解析了。为什么Foo2不能被初始化,Foo2的定义根本不是函数定义,它是一个标准的赋值语句,之所以能象标准函数一样的使用Foo2(Foo2()),完全是因为它指向的是一个函数对象的实例而已。
再来看原形方法导入里的两种方式,就很简单了。并且不同的执行优先循序,也决了它们在使用中的不同,看如下示例:
执行:
是什么效果?为什么?
<script language="javascript">
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);
};
}
</script>
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);
};
}
</script>
执行:
var nc = new NormalClass();
nc.Method1();
nc.Method2();
nc.Method1();
nc.Method2();
是什么效果?为什么?
最后结果居然是nc.Method1()没有定义,nc.Method2()运行正常。
其实不奇怪了,InnerClass.prototype.Method1 = function()依赖于赋值语句的执行,而 function InnerClass.prototype.Method2() 以最高优先级被脚本引擎初始化。
- JS类定义原型方法的两种实现的区别
- JS类定义原型方法的两种实现的区别
- js定义对象的两种方法以及js用call来实现类的继承
- JS两种定义方式的区别
- String 两种定义方法的区别
- String定义的两种方法的区别
- java中的string定义的两种方法和区别
- 原型链(一):辨别原型链的两种方法
- 重定义键盘的两种实现方法
- C#定义系统常量的两种实现方法对比
- js 创建对象的两种主要方法 构造函数 和 原型+构造函数组合
- js中截取字符串的两种方法的区别
- js中方法定义的区别
- js 对象方法、类方法、原型方法的区别;私有属性、公有属性、公有静态属性
- Javascript 两种 function 定义的区别
- js 对象方法、类方法、原型方法的区别;私有属性、公有属性、公有静态属性的区别
- JS中的phototype JS的三种方法(类方法、对象方法、原型方法)
- 原型链的两种继承方式及区别
- sql有用函數
- 用VC编程阻止全局钩子的加载
- function, new function, new Function
- ASCII 编码
- JScript中的undefined和"undefined"
- JS类定义原型方法的两种实现的区别
- JDBC中BLOB/long raw字段的读写
- 软件开发技术趋势分析
- 诺基亚面试题目
- 了解Ruby on Rails
- 杂七杂八
- JavaScript语句可以不以;结尾的烦恼
- 保护你的DLL和Code不被别人使用 -C#篇
- Develop Log - Qooxdoo Widget