浅谈JavaScript 覆盖原型以及更改原型


Posted in Javascript onAugust 31, 2016

覆盖原型

//囚犯示例 
//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 相关文章推荐
validator验证控件使用代码
Nov 23 Javascript
js禁止小键盘输入数字功能代码
Aug 01 Javascript
jQuery中的height innerHeight outerHeight区别示例介绍
Jun 15 Javascript
C++中的string类的用法小结
Aug 07 Javascript
jquery动态导航插件dynamicNav用法实例分析
Sep 06 Javascript
学习javascript面向对象 javascript实现继承的方式
Jan 04 Javascript
JavaScript中三种异步上传文件方式
Mar 06 Javascript
JavaScript基于对象去除数组重复项的方法
Oct 09 Javascript
JS如何生成一个不重复的ID的函数
Dec 25 Javascript
微信小程序实现带刻度尺滑块功能
Mar 29 Javascript
浅谈基于Vue.js的移动组件库cube-ui
Dec 20 Javascript
原生js实现瀑布流效果
Mar 09 Javascript
javascript 将共享属性迁移到原型中去的实现方法
Aug 31 #Javascript
使用vue编写一个点击数字计时小游戏
Aug 31 #Javascript
原生js实现tab选项卡切换
Mar 23 #Javascript
jquery的checkbox,radio,select等方法小结
Aug 30 #Javascript
Javascript日期格式化format函数的使用方法
Aug 30 #Javascript
浅析ES6的八进制与二进制整数字面量
Aug 30 #Javascript
AngularJS轻松实现双击排序的功能
Aug 30 #Javascript
You might like
php单例模式实现(对象只被创建一次)
2012/12/05 PHP
PHP闭包定义与使用简单示例
2018/04/13 PHP
jquery 日期分离成年月日的代码
2010/05/14 Javascript
js判断是否为数组的函数: isArray()
2011/10/30 Javascript
JS+CSS实现感应鼠标渐变显示DIV层的方法
2015/02/20 Javascript
jQuery()方法的第二个参数详解
2015/04/29 Javascript
javascript实现十秒钟后注册按钮可点击的方法
2015/05/13 Javascript
JavaScript使用RegExp进行正则匹配的方法
2015/07/11 Javascript
JavaScript使用键盘输入控制实现数字验证功能
2016/08/19 Javascript
bootstrap模态框跳转到当前模板页面 框消失了而背景存在问题的解决方法
2020/11/30 Javascript
使用DeviceOne实现微信小程序功能
2016/12/29 Javascript
微信小程序小组件 基于Canvas实现直播点赞气泡效果
2020/05/29 Javascript
js 获取今天以及过去日期
2017/04/11 Javascript
vue.js删除动态绑定的radio的指定项
2017/06/02 Javascript
在页面中引入js的两种方法(推荐)
2017/08/29 Javascript
完美解决axios在ie下的兼容性问题
2018/03/05 Javascript
JQuery搜索框自动补全(模糊匹配)功能实现示例
2019/01/08 jQuery
Vue运用transition实现过渡动画
2019/05/06 Javascript
解决vue打包后vendor.js文件过大问题
2019/07/03 Javascript
python中的常量和变量代码详解
2018/07/25 Python
Python实现基于SVM的分类器的方法
2019/07/19 Python
django admin 自定义替换change页面模板的方法
2019/08/23 Python
pyqt5、qtdesigner安装和环境设置教程
2019/09/25 Python
Tensorflow 1.0之后模型文件、权重数值的读取方式
2020/02/12 Python
Python识别处理照片中的条形码
2020/11/16 Python
python 利用matplotlib在3D空间绘制二次抛物面的案例
2021/02/06 Python
html5 canvas-1.canvas介绍(hello canvas)
2013/01/07 HTML / CSS
一套Java笔试题
2016/08/20 面试题
八皇后问题,输出了所有情况,不过有些结果只是旋转了90度
2016/08/15 面试题
如何用JQuery进行表单验证
2013/05/29 面试题
什么是servlet链?
2014/07/13 面试题
大学生党员自我评价范文
2014/04/09 职场文书
课外访万家心得体会
2014/09/03 职场文书
业绩倒数第一的检讨书
2014/09/24 职场文书
迎新生标语大全
2014/10/06 职场文书
javascript数组includes、reduce的基本使用
2021/07/02 Javascript