介绍
这篇文章主要为大家展示了“js中使用原型对象原型需要注意的地方有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“js中使用原型对象原型需要注意的地方有哪些”这篇文章吧。
我们先来一个简单的构造函数+原型对象的小程序
function CreateObj (uName的不同之处是,uAge ), { ,,,,,this.userName =, uName; ,,,,,this.userAge =, uAge; ,,,} ,,,CreateObj.prototype.showUserName =, function (), { ,,,,,return this.userName; ,,,} ,,,CreateObj.prototype.showUserAge =, function (), { ,,,,,return this.userAge; ,,,}
这个程序,没有什么问题,但是非常的冗余,每次扩展一个方法,都要写一次原型对象,我们可以<强>把原型对象当原型做一个字面量对象,所有的方法都在字面量对象中扩展,强>可以达到同样的效果:
CreateObj.prototype =, { ,,,,,showUserAge :,函数(){ ,,,,,,,return this.userAge; ,,,,,}, ,,,,,showUserName :,函数(){ ,,,,,,,return this.userName; ,,,,,}, ,,,} ,,,var obj1 =, new CreateObj (, & # 39; ghostwu& # 39;,, 22,); ,,,var obj2 =, new CreateObj(, & # 39;卫庄& # 39;,,24,); ,,,console.log (, obj1.showUserName (),, obj1.showUserAge (),),,//ghostwu 22 ,,,console.log (, obj2.showUserName (),, obj2.showUserAge(),),,//卫庄,24
但是这种原型(原型)对象的写法,属于重写了CreateObj的默认原型对象,造成的第一个问题就是构造函数不再指向CreateObj。
没有重写之前,构造函数指向CreateObj
function CreateObj (uName的不同之处是,uAge ), { ,,,,,this.userName =, uName; ,,,,,this.userAge =, uAge; ,,,} ,,,CreateObj.prototype.showUserName =, function (), { ,,,,,return this.userName; ,,,} ,,,CreateObj.prototype.showUserAge =, function (), { ,,,,,return this.userAge; ,,,} ,,,console.log (===,, CreateObj.prototype.constructor  CreateObj );,//真正的
重写之后,构造函数指向对象
CreateObj.prototype =, { ,,,,,showUserAge :,函数(){ ,,,,,,,return this.userAge; ,,,,,}, ,,,,,showUserName :,函数(){ ,,,,,,,return this.userName; ,,,,,}, ,,,} ,,,console.log (===,, CreateObj.prototype.constructor  CreateObj );//错误 ,,,console.log (===,, CreateObj.prototype.constructor  Object );,//真正的
所以说,<强>构造函数不能准确的标识对象,因为他会被修改强>
我们之前写的程序,基本都是在原型对象(原型)上扩展完了方法之后,再实例化对象,我们看下,先实例化对象,再在原型对象(原型)上扩展函数,
实例对象是否能正常的调用到扩展的方法?
function CreateObj (uName的不同之处是,uAge ), { ,,,,,this.userName =, uName; ,,,,,this.userAge =, uAge; ,,,} ,,,var obj1 =, new CreateObj (, & # 39; ghostwu& # 39;,, 22,); ,,,CreateObj.prototype.showUserName =,函数(){ ,,,,,return this.userName; ,,,} ,,,console.log (, obj1.showUserName (),),,//ghostwu
可以正常调用,但是,如果原型对象是重写的,就调用不到了
function CreateObj (uName的不同之处是,uAge ), { ,,,,,this.userName =, uName; ,,,,,this.userAge =, uAge; ,,,} ,,,var obj1 =, new CreateObj (, & # 39; ghostwu& # 39;,, 22,); ,,,CreateObj.prototype =, { ,,,,,showUserName :,函数(){ ,,,,,,,return this.userName; ,,,,,} ,,,} null null null null null null null null null null null null null null null null null null nulljs中使用原型对象原型需要注意的地方有哪些