JavaScript中isPrototypeOf函数


Posted in Javascript onNovember 07, 2021

 有时看一些框架源码的时候,会碰到 isPrototypeOf() 这个函数,那么这个函数有什么作用呢?

1、isPrototypeOf()

isPrototypeOf() Object函数(类)的下的一个方法,用于判断当前对象是否为另外一个对象的原型,如果是就返回 true,否则就返回 false

这个函数理解的关键是在原型链上,这个据说是JavaScript的三座大山之一。

这里不详述其中的原理,简单的来讲就是3点:

  • 1. 函数对象,都会天生自带一个prototype原型属性。
  • 2. 每一个对象也天生自带一个属性__proto__指向生成它的函数对象的prototype
  • 3. 函数对象的prototype也有__proto__指向生成它的函数对象的prototype

示例1,Object类实例:

let o = new Object();
console.log(Object.prototype.isPrototypeOf(o)); // true

因为o对象是Object的实例,所以o对象的原型(__proto__)指向Object的原型(prototype),上面会输出true。

示例2,自己定义Human类:

function Human() {}
let human = new Human();
 
console.log(Human.prototype.isPrototypeOf(human)); // true

这例和上例类似,因为human对象是Human的实例,所以human对象的原型(__proto__)指向Human的原型(prototype),上面会输出true

示例3,再来看看Object的原型(prototype)是否是human的原型:

console.log(Object.prototype.isPrototypeOf(human)); // true

为什么呢?,用代码可能更好解释,请看下面推导:

// 因为 Human 的原型(prototype)中的原型(__proto__)指向 Object 的原型(prototype)
Human.prototype.__proto__ === Object.prototype
// 又因为 human 的原型(__proto__)指向 Human 的原型(prototype)
huamn.__proto__  === Human.prototype
// 所以human对象的原型(__proto__)的原型(__proto__)指向Object的原型(prototype)
huamn.__proto__.__proto__  === Object.prototype

如果查看human的结构就很容易清楚了:

JavaScript中isPrototypeOf函数

Object 的原型(prototype) 是不是就是 human 对象的原型呢?确切的说Object 的原型(prototype)是在 human 的原型链上。

示例4,Object.prototype是否是内置类的原型:

JavaScript中内置类NumberStringBooleanFunctionArray因为都是继承Object,所以下面的输出也都是true

console.log(Object.prototype.isPrototypeOf(Number)); // true
console.log(Object.prototype.isPrototypeOf(String)); // true
console.log(Object.prototype.isPrototypeOf(Boolean)); // true
console.log(Object.prototype.isPrototypeOf(Array)); // true
console.log(Object.prototype.isPrototypeOf(Function)); // true

自然Object.prototype也是NumberStringBooleanFunctionArray的实例的原型。

示例5,Object也是函数(类):

另外值得一提的是 Function.prototype 也是Object的原型,因为Object也是一个函数(类),它们是互相生成的。

请看下面输出:

console.log(Object.prototype.isPrototypeOf(Function)); // true
console.log(Function.prototype.isPrototypeOf(Object)); // true

2、和 instanceof 的区别

instanceof 是用来判断对象是否属于某个对象的实例。

例如:

function Human() {}
let human = new Human();
 
// human 是 Human 的实例,所以结果输出true
console.log(human instanceof Human); // true
 
// 因为所有的类都继承Object,所以结果也输出true
console.log(human instanceof Object); // true
 
// 因为 human 对象不是数组,所以结果输出false
console.log(human instanceof Array); // false

再来一些内置类的例子:

// 【1,2,3] 是 Array 的实例,所以输出true
console.log([1, 2, 3] instanceof Array); // true
 
// 方法 function(){} 是 Function的实例,所以输出true
console.log(function(){} instanceof Function);

instanceof 作用的原理就是判断实例的原型链中能否找到类的原型对象(prototype),而 isPrototypeOf 又是判断类的原型对象(prototype)是否在实例的原型链上。

所以我的理解,这两个表达的意思是一致的,就是写法不同,下面两个输出应该是一致的:

console.log(A instanceof B);
console.log(B.prototype.isPrototypeOf(A));

小结

其实要理解 isPrototypeOf 函数,关键是要理解原型链这个玩意。

到此这篇关于JavaScriptisPrototypeOf函数的文章就介绍到这了,更多相关JavaScript中isPrototypeOf内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
关于js获取radio和select的属性并控制的代码
May 12 Javascript
JAVA四种基本排序方法实例总结
Jul 24 Javascript
jquery控制显示服务器生成的图片流
Aug 04 Javascript
jquery判断类型是不是number类型的实例代码
Oct 07 Javascript
微信公众号支付H5调用支付解析
Nov 04 Javascript
使用vue.js实现联动效果的示例代码
Jan 10 Javascript
老生常谈的跨域处理
Jan 11 Javascript
详解angularjs实现echart图表效果最简洁教程
Nov 29 Javascript
angular4应用中输入的最小值和最大值的方法
May 17 Javascript
微信小程序激励式视频广告组件使用详解
Dec 06 Javascript
jQuery实现影院选座订座效果
Apr 13 jQuery
详解Vue项目的打包方式(生成dist文件)
Jan 18 Vue.js
JavaScript原型链详解
JavaScript组合继承详解
详细聊聊vue中组件的props属性
教你一步步实现一个简易promise
Nov 02 #Javascript
一定要知道的 25 个 Vue 技巧
原型和原型链 prototype和proto的区别详情
Nov 02 #Javascript
浅谈克隆 JavaScript
Nov 02 #Javascript
You might like
2.PHP入门
2006/10/09 PHP
如何在PHP中使用Oracle数据库(2)
2006/10/09 PHP
yii实现CheckBox复选框在同一行显示的方法
2014/12/03 PHP
phpstudy默认不支持64位php的解决方法
2017/02/20 PHP
用Javascript实现锚点(Anchor)间平滑跳转
2009/09/08 Javascript
jQuery 中国省市两级联动选择附图
2014/05/14 Javascript
js字符串操作方法实例分析
2015/05/06 Javascript
JQuery 设置checkbox值二次无效的解决方法
2016/07/22 Javascript
本地Bootstrap文件字体图标引入却无法显示问题的解决方法
2020/04/18 Javascript
Js利用console计算代码运行时间的方法示例
2017/09/24 Javascript
原生JS实现萤火虫效果
2020/03/07 Javascript
vue 页面跳转的实现方式
2021/01/12 Vue.js
用Python的Django框架完成视频处理任务的教程
2015/04/02 Python
给Python初学者的一些编程技巧
2015/04/03 Python
python中__slots__用法实例
2015/06/04 Python
详解Python中表达式i += x与i = i + x是否等价
2017/02/08 Python
Python实现选择排序
2017/06/04 Python
Java与Python两大幸存者谁更胜一筹呢
2018/04/12 Python
深入浅析Python2.x和3.x版本的主要区别
2018/11/30 Python
python读取txt文件,去掉空格计算每行长度的方法
2018/12/20 Python
Django分组聚合查询实例分享
2020/04/29 Python
用Python开发app后端有优势吗
2020/06/29 Python
pytorch __init__、forward与__call__的用法小结
2021/02/27 Python
HTML5制作酷炫音频播放器插件图文教程
2014/12/30 HTML / CSS
使用HTML5 Geolocation实现一个距离追踪器
2018/04/09 HTML / CSS
JAVA代码查错题
2014/10/10 面试题
软件测试题目
2013/02/27 面试题
出纳试用期自我鉴定
2014/04/07 职场文书
高校群众路线教育实践活动剖析材料
2014/10/10 职场文书
2014年人事科工作总结
2014/11/19 职场文书
2014年小学数学工作总结
2014/12/12 职场文书
幼儿园小班开学寄语(2016秋季)
2015/12/03 职场文书
2019销售早会主持词
2019/06/27 职场文书
JavaScript中reduce()的用法
2022/05/11 Javascript
Win11 PC上的Outlook搜索错误怎么办?
2022/07/15 数码科技
微软发布Windows 11今年最大更新22H2(附 ISO 镜像官方下载)
2022/09/23 数码科技