浅谈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 相关文章推荐
Javascript 表单之间的数据传递代码
Dec 04 Javascript
juqery 学习之三 选择器 可见性 元素属性
Nov 25 Javascript
jQuery固定浮动侧边栏实现思路及代码
Sep 28 Javascript
JavaScript Math.floor方法(对数值向下取整)
Jan 09 Javascript
jQuery+CSS3实现树叶飘落特效
Feb 01 Javascript
JavaScript 浏览器对象模型BOM使用介绍
Apr 13 Javascript
JavaScript实现自动跳转文本功能
May 25 Javascript
jQuery接受后台传递的List的实例详解
Aug 02 jQuery
vue使用监听实现全选反选功能
Jul 06 Javascript
jQuery提示框插件SweetAlert用法分析
Aug 05 jQuery
jQuery 选择器用法实例分析【prev + next】
May 22 jQuery
Axios取消重复请求的方法实例详解
Jun 15 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写的采集程序
2007/03/16 PHP
PHP管理依赖(dependency)关系工具 Composer 安装与使用
2014/08/18 PHP
PHP中的output_buffering详细介绍
2014/09/27 PHP
PHP获取数组的键与值方法小结
2015/06/13 PHP
WordPress中使主题支持小工具以及添加插件启用函数
2015/12/22 PHP
tp5.1 实现setInc字段自动加1
2019/10/18 PHP
ExtJS Window 最小化的一种方法
2009/11/18 Javascript
JS对话框_JS模态对话框showModalDialog用法总结
2014/01/11 Javascript
一个JavaScript用逗号分割字符串实例
2014/09/22 Javascript
JavaScript实现穷举排列(permutation)算法谜题解答
2014/12/29 Javascript
IE10中flexigrid无法显示数据的解决方法
2015/07/26 Javascript
AngularJS中update两次出现$promise属性无法识别的解决方法
2017/01/05 Javascript
原生js实现打字动画游戏
2017/02/04 Javascript
Vue resource中的GET与POST请求的实例代码
2017/07/21 Javascript
Angular4实现动态添加删除表单输入框功能
2017/08/11 Javascript
Vue使用json-server进行后端数据模拟功能
2018/04/17 Javascript
微信小程序前端promise封装代码实例
2019/08/24 Javascript
JS造成内存泄漏的几种情况实例分析
2020/03/02 Javascript
[03:17]DOTA2-DPC中国联赛1月29日Recap集锦
2021/03/11 DOTA
Python实现的金山快盘的签到程序
2013/01/17 Python
Python爬取国外天气预报网站的方法
2015/07/10 Python
Python实现文件复制删除
2016/04/19 Python
Python基于socket实现简单的即时通讯功能示例
2018/01/16 Python
tensorflow学习笔记之mnist的卷积神经网络实例
2018/04/15 Python
详解pytorch 0.4.0迁移指南
2019/06/16 Python
python 解决mysql where in 对列表(list,,array)问题
2020/06/06 Python
python + selenium 刷B站播放量的实例代码
2020/06/12 Python
Python pip安装第三方库实现过程解析
2020/07/09 Python
Matplotlib配色之Colormap详解
2021/01/05 Python
使用 CSS3 中@media 实现网页自适应的示例代码
2020/03/24 HTML / CSS
美国彩妆品牌:Coastal Scents
2017/04/01 全球购物
餐厅总经理岗位职责
2013/12/31 职场文书
新学期标语
2014/06/30 职场文书
解除劳动合同协议书(样本)
2014/10/02 职场文书
在人间读书笔记
2015/06/30 职场文书
2016年秋季运动会加油稿
2015/12/21 职场文书