手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >Javascript学习笔记6 prototype的提出
Javascript学习笔记6 prototype的提出
摘要:首先我们继续上文的代码,我们来把这段代码延伸一下:复制代码代码如下:varPerson=function(name,age){this.na...

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

复制代码 代码如下:

<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都是一样的么?其实我以前也是这么理解的,在这次偶然的试验中看到了这个问题。

【Javascript学习笔记6 prototype的提出】相关文章:

JavaScript实现简单的数字倒计时

Javascript获取统一管理的提示语(message)

Javascript中prototype属性实现给内置对象添加新的方法

javascript相关事件的几个概念

AngularJS学习笔记之ng-options指令

javascript制作的滑动图片菜单

javascript字符串与数组转换汇总

Javascript实现div的toggle效果实例分析

javascript实现控制的多级下拉菜单

JavaScript对传统文档对象模型的支持

精品推荐
分类导航