首页 > 代码库 > 原型讲解二:原型是干什么用的
原型讲解二:原型是干什么用的
前面说了这么多的原型的概念,那么原型用在哪里呢?
之前说过,直接在构造函数外面定义一个函数方法,势必会造成全局的变量污染,那么怎么避免这个问题呢?那么就要涉及到在原型上面定义一个方法了:
范例:
function Person(name,age,gender){
this.name=name;
this.age=age;
this.say=function(“我是”+this.name);
}
这是一个简单的构造函数,那么是怎么改进的呢?
改进1:为了防止每次建立一个对象,对象里包含一个say()函数方法
在构造函数的外面添加了一个say()含数,但是造成了全局的变量污染。
该进2:使用原型的方法
this.say方法就可以不定义了
看看这里的定义:
Person.prototype.say=function(){
alert(“我是”+this.name);
}
这样就完美的解决了上面构造函数外面直接定义函数方法从而污染全局变量的问题。
再补充几个专业的术语(其实就是为了让读者看不懂,从而达到吹NB的效果,国内学者把这个学的淋漓尽致了,呵呵了)
什么叫做实例化:
例如 var p=new Person();
就是用new创建了一个对象,该对象拥有构造函数的属性和方法,有木有感觉构造函数像一个模板呢?,结构是不变的,唯一变的就是实参的变化。
更专业的叫法:p是Person()这个构造函数的一个实例
原型讲解二:原型是干什么用的
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。