出处:
JavaScript 是面向对象的。但是不少人对这一点理解得并不全面。
在 JavaScript 中,对象分为两种。一种可以称为“普通对象”,就是我们所普遍理解的那些:数字、日期、用户自定义的对象(如:{})等等。 还有一种,称为“方法对象”,就是我们通常定义的 function。你可能觉得奇怪:方法就是方法,怎么成了对象了?但是在 JavaScript 中,方法的确是被当成对象来处理的。下面是一个简单的例子: Js代码
- function func() {alert('Hello!');}
- alert(func.toString());
Js代码
- func.name = “I am func.”;
- alert(func.name);
Js代码
- func();
Js代码
- function invoke(f) {
- f();
- }
- invoke(func);
Js代码
- func.prototype.name=”prototype of func”;
- var f = new func();
- alert(f.name);
Js代码
- function func() {
- this.name=”name has been changed.”
- }
- func.prototype.name=”prototype of func”;
- var f = new func();
- alert(f.name);
- 创建一个新的普通对象;
- 将方法对象的 prototype 属性的所有属性复制到新的普通对象中去。
- 以新的普通对象作为上下文来执行方法对象。
对于“new func()”这样的语句,可以描述为“从 func 创建一个新对象”。总之,prototype 这个属性的唯一特殊之处,就是在创建新对象的时候了。
那么我们就可以利用这一点。比如有两个方法对象 A 和 B,既然从 A 创建的新对象包含了所有 A.prototype 的属性,那么我将它赋给 B.prototype,那么从 B 创建的新对象不也有同样的属性了?写成代码就是这样:
Js代码
- A.prototype.hello = function(){alert('Hello!');}
- B.prototype = new A();
- new B().hello();
Js代码
- var o = {}; // 我发现了一个东西。
- o.eat = function(){return "I am eating."} // 我发现它会吃;
- o.sleep = function(){return "ZZZzzz..."} // 我发现它会睡;
- o.talk = function(){return "Hi!"} // 我发现它会说话;
- o.think = function(){return "Hmmm..."} // 我发现它还会思考。
- var Human = new Function(); // 我决定给它起名叫“人”。
- Human.prototype = o; // 这个东西就代表了所有“人”的概念。
- var h = new Human(); // 当我发现其他同它一样的东西,
- alert(h.talk()) // 我就知道它也是“人”了!