浅谈JavaScript 覆盖原型以及更改原型
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了浅谈JavaScript 覆盖原型以及更改原型,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1533字,纯文字阅读大概需要3分钟。
内容图文
![浅谈JavaScript 覆盖原型以及更改原型](/upload/InfoBanner/zyjiaocheng/350/865370ff4a9b4f14bc255d94a60de12a.jpg)
覆盖原型
//囚犯示例 //1.定义原型对象 var proto = { sentence : 4, //监禁年限 probation: 2 //缓刑年限 }; //2.定义原型对象的构造函数 var Prisoner = function(name, id) { this.name = name; this.id = id; }; //3.将构造函数关联到原型 Prisoner.prototype = proto; //4.实例化对象——采用工厂函数实例化对象 var makePrisoner = function(name, id) { //采用工厂函数实力化对象prisoner var prisoner = Object.create( proto ); prisoner.name = name; prisoner.id = id; return prisoner; }; var firstPrisoner = makePrisoner( 'Joe', '12A' ); //firstPrisoner.sentence在firstPrisoner对象找不到sentence属性, //所以查找对象的原型并找到了Both of these output 4 console.log( firstPrisoner.sentence ); console.log( firstPrisoner.__proto__.sentence ); //把对象的sentence属性设置为10 firstPrisoner.sentence = 10; //outputs 10 //确定对象上的属性值已设置为10 console.log( firstPrisoner.sentence ); //但是对象的原型并没有变化,值仍然为4 console.log( firstPrisoner.__proto__.sentence ); //为了使获取到的属性回到原型的值,将属性从对象上删除 delete firstPrisoner.sentence; //接下来,JavaScript引擎在对象上不能再找到该属性, //必须回头去查找原型链,并在原型对象上找到该属性 // Both of these output 4 console.log( firstPrisoner.sentence ); console.log( firstPrisoner.__proto__.sentence );
ubuntu 终端node输出
xxh@xxh-E440:~/workspace$ node t6 4 4 10 4 4 4
那么如果改变了原型对象的属性值,会发生什么呢?我知道你在思考。
以上这篇浅谈JavaScript 覆盖原型以及更改原型就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
内容总结
以上是互联网集市为您收集整理的浅谈JavaScript 覆盖原型以及更改原型全部内容,希望文章能够帮你解决浅谈JavaScript 覆盖原型以及更改原型所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。
来源:【匿名】