简要咨询咨询QQ网站导航网站搜索手机站点联系我们设为首页加入收藏 

如何学好JavaScript(六) —— prototype的提出

来源:易贤网   阅读:745 次  日期:2015-04-22 11:33:17

温馨提示:易贤网小编为您整理了“如何学好JavaScript(六) —— prototype的提出”,方便广大网友查阅!

首先我们继续上文的代码,我们来把这段代码延伸一下:

<script type="text/javascript">

var Person = function (name, age) {

this.name = name;

this.age = age;

this.Introduce = function () {

alert("My name is " + this.name + ".I'm " + this.age);

};

};

var person1 = new Person("飞林沙", 21);

var person2 = new Person("kym", 26);

alert(person1.Introduce == person2.Introduce);

script>

  结果弹出false。也就是说,这两个对象的方法是不同的方法。那么我们知道,在C#中,每个对象会维护着一个方法表,可是方法表应该指向同一块地址。如果是这样的话,那当我们声明了100个对象,是不是要建立100个对象拷贝,对空间是不是一个很大的浪费呢?

  于是我们就想了这样的解决办法,用prototype:

<script type="text/javascript">

var Person = function (name, age) {

this.name = name;

this.age = age;

};

Person.prototype.Introduce = function () {

alert("My name is " + this.name + ".I'm " + this.age);

}

var person1 = new Person("飞林沙", 21);

var person2 = new Person("kym", 26);

alert(person1.Introduce == person2.Introduce);

script>

  这样就可以了。所以你还会再说是否用prototype都是一样的么?其实我以前也是这么理解的,在这次偶然的试验中看到了这个问题。

更多信息请查看IT技术专栏

更多信息请查看脚本栏目
点此处就本文及相关问题在本站进行非正式的简要咨询(便捷快速)】     【点此处查询各地各类考试咨询QQ号码及交流群
上一篇:如何学好JavaScript(八) —— 用JSON做原型
下一篇:如何学好JavaScript(七) —— 原型链的原理
易贤网手机网站地址:如何学好JavaScript(六) —— prototype的提出
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!