您好,欢迎访问一九零五行业门户网

javascript prototype,executing,context,closure_prototype

要学好javascript,有几个基本概念必须搞清楚:prototype,executing,context,closure。
prototype
在javascript语言中,通常使用prototype来实现oo。在这里,我们不对javascript的oo实现进行过多的探讨,着重来看一下js中对象的内存模型。在开始之前,需要先明确以下几点:
1. js中,存在以下几种数据类型:string,number,boolean,object,function(注意:首字母均为小写)。
2 “object”, “string”, “date”等内置数据类型,在js中实际上是函数名称(使用alert(typeof object)可以验证,输出为function)。我们通常指的类型为date的数据类型,实际上是通过new date所产生的对象。
3. 在javascript中,对象都是associative array (hash table),可以动态指定对象的property。
4. 在firefox中可以使用__proto__属性来查看一个对象的prototype。
下面我们来看一个简单的例子:
function person() { this.age = 10; this.name = test;}person.prototype = new object;var p = new person;alert(p); // output [object object]alert(p.__proto__); // output [object object]
可以看出person数据类型具有一个“prototype”,如果更改这个prototype,会影响到所有已经产生的person类型的对象,同时也会影响到以后建立的person类型的对象。如果指定一个function的prototype属性,则所有使用该function生成的对象实例中(使用new操作符)都具有该prototype,在firefox 中,可以使用__proto__属性访问。
通常情况下,我们讲js中的对象都继承object数据类型,这是如何体现的呢?我们把以上的程序稍微修改一下:
function person() { this.age = 10; this.name = test;}var p = new person;alert(p); // output [object object]alert(p.__proto__); // output [object object]alert(p.__proto__.__proto__); // output [object object]alert(p.__proto__.__proto__ == object.prototype); // output truealert(p.__proto__.__proto__.__proto__); // output null
由以上程序可以看到,person的prototype(在这里,没有明确指定person.prototype, 而是使用缺省值)的prototype (p.__proto__.__proto__)正是object.prototype, object.prototype是prototype chain的终点(其自己的祖先为null)。
在js中,object是function,同时,所有function的实例,也都是object。请看如下程序:
/* object, function都是function数据类型 */alert(typeof object); // output functionalert(typeof function); // output function/* function的prototype是一个空function */alert(function.prototype); // output function() {}alert(function.__proto__ == function.prototype); // output true/* function是object, 其prototype chain的终点是object.prototype */alert(function.__proto__.__proto__ == object.prototype); //output true/* object是function的实例 */ alert(object.__proto__ == function.prototype); // output truealert(object.__proto__.__proto__ == object.prototype); // output true改变function.prototype会影响到“object”,改变object.prototype会影响到所有function的实例。
其它类似信息

推荐信息