js中使用原型对象原型需要注意的地方有哪些

  介绍

这篇文章主要为大家展示了“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   null

js中使用原型对象原型需要注意的地方有哪些