js修改原型的属性使用介绍

时间:2024-04-10 10:51:03 

在javascript中原型(prototype)定义了特定类型的所有实例都可以访问的属性和方法,很多些情况下需要重新对原型中的属性赋值,如果方法错误会导致一些意想不到的情况(仅仅是对像我这样的新手奋斗),下面通过测试对这部分知识做一个简单的总结。

基本类型定义如下:


function Person(){}

Person.prototype={
constructor:Person,
name:"person",
age:100,
friends:["a","b"],
getName:function(){
return this.name;
}
};


定义两个Person的实例,修改实例中的name属性(该属性是在prototype中定义的),测试代码如下


var p1=new Person();
var p2=new Person();

document.write(p1.name+"<br/>"); //person
document.write(p2.name+"<br/>"); //person

p1.name="p1";
document.write(p1.name+"<br/>"); //p1
document.write(p2.name+"<br/>"); //person

document.write(p1.hasOwnProperty("name")+"<br/>"); //true 属于对象
document.write(p2.hasOwnProperty("name")+"<br/>"); //false 属于原型

document.write(Object.keys(p1)+"<br/>"); //name
document.write(Object.keys(p2)+"<br/>"); // 空
document.write(Object.getOwnPropertyNames(Person.prototype)+"<br/>"); //constructor,name,age,friends,getName
document.write(Person.prototype.name+"<br/>"); //person


经过测试可以发现p1.name="p1"并不是修改了name的值而是在实例p1中新增加了一个name属性覆盖了prototype中的name属性,从后续的判断中就可以看出这时候p1的name属性已经是一个实例属性而不是原型属性,后面的Object.keys(p1)也可以看出p1这个实例中多了一个name属性而p2中没有。在js中所有的传递都是值传递,这个值可以是个指向引用类型的指针,所以等号并不意味着修改这个引用对象,而是切换了原来的引用关系,下面再通过代码说明这个问题


var obj=new Object();
obj.name="obj";

function changeObj(o){
o.name="changed";
o=new Object();
o.name="newObj";
}
changeObj(obj);

document.write(obj.name); //changed


在changedObj方法中o=new Object()并没有修改参数o的值,而是切断了原来的引用关系,所以结果并不是newObj而是changed

接下来测试一下修改第一个例子中prototype中的friends属性,这个属性是一个引用类型


p1.friends.push("c");
document.write(p1.friends+"<br/>"); //a,b,c
document.write(p2.friends+"<br/>"); //a,b,c

p1.friends=["x","y","z"];
document.write(p1.friends+"<br/>"); //x,y,z
document.write(p2.friends+"<br/>"); //a,b,c

document.write(p1.hasOwnProperty("friends")+"<br/>"); //true 属于对象
document.write(p2.hasOwnProperty("friends")+"<br/>"); //false 属于原型

document.write(Object.keys(p1)+"<br/>"); //name,friend
document.write(Object.keys(p2)+"<br/>"); //空
document.write(Object.getOwnPropertyNames(Person.prototype)+"<br/>"); //constructor,name,age,friends,getName
document.write(Person.prototype.friends+"<br/>"); //a,b,c


这次测试结果与第一次的测试基本相同,当通过等号修改时,这时候会切断原来的引用并为实例创建一个新的属性且覆盖了prototype中的同名属性

基于这两个测试结果发现在实例中不能直接修改prototype中的值类型属性(当然这种值类型不应该定义在prototype,这里的代码实例仅仅说明这个知识点,并无实际意义)

标签:js修改原型
0
投稿

猜你喜欢

  • Django ORM 聚合查询和分组查询实现详解

    2023-03-21 16:27:13
  • Python 定义只读属性的实现方式

    2023-04-28 01:11:22
  • python实现用户答题功能

    2022-01-05 21:38:02
  • 使用Python项目生成所有依赖包的清单方式

    2022-02-18 19:14:49
  • Python字符串中查找子串小技巧

    2022-04-16 10:58:04
  • 用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备份等

    2011-12-01 07:53:11
  • 详解scrapy内置中间件的顺序

    2023-10-22 07:13:38
  • SQLServer中的触发器基本语法与作用

    2024-01-25 18:18:02
  • python爬取51job中hr的邮箱

    2022-11-06 14:00:54
  • Python封装shell命令实例分析

    2022-03-11 13:39:37
  • SQL 外链接操作小结 inner join left join right join

    2024-01-19 21:06:39
  • 2020版Python学习路线图(附学习资料)

    2021-01-11 09:33:52
  • python 如何将字典写为json文件

    2021-07-22 18:39:39
  • Js实现粘贴上传图片的原理及示例

    2024-04-19 10:44:50
  • Mysql联合查询UNION和Order by同时使用报错问题的解决办法

    2024-01-12 18:44:35
  • 面向对象CSS FAQ[译]

    2009-10-27 15:59:00
  • 解决Python 写文件报错TypeError的问题

    2022-09-18 06:54:26
  • Windows+Anaconda3+PyTorch+PyCharm的安装教程图文详解

    2021-07-10 03:34:55
  • MySQL备份与恢复之保证数据一致性(5)

    2024-01-16 19:16:20
  • Python合并字符串的3种方法

    2021-08-13 00:33:33
  • asp之家 网络编程 m.aspxhome.com