手机
当前位置:查字典教程网 >编程开发 >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中Cookies的相关使用教程

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

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

Javascript客户端脚本的设计和应用

javascript的事件描述

关于JavaScript作用域你想知道的一切

javascript实现设置、获取和删除Cookie的方法

JavaScript编程学习技巧汇总

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

精品推荐
分类导航