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 相关文章推荐
Firefox+FireBug使JQuery的学习更加轻松愉快
Jan 01 Javascript
SyntaxHighlighter语法高亮插件使用说明
Aug 14 Javascript
JS HTML5 音乐天气播放器(Ajax获取天气信息)
May 26 Javascript
jQuery链使用指南
Jan 20 Javascript
jQuery简单动画变换效果实例分析
Jul 04 Javascript
Node.js获取前端ajax提交的request信息
Feb 20 Javascript
Vue2.0 给Tab标签页和页面切换过渡添加样式的方法
Mar 13 Javascript
如何使node也支持从url加载一个module详解
Jun 05 Javascript
对Vue- 动态元素属性及v-bind和v-model的区别详解
Aug 27 Javascript
vue项目环境变量配置的实现方法
Oct 12 Javascript
利用Vconsole和Fillder进行移动端抓包调试方法
Mar 05 Javascript
JS数组中对象去重操作示例
Jun 04 Javascript
JavaScript原型链详解
JavaScript组合继承详解
详细聊聊vue中组件的props属性
教你一步步实现一个简易promise
Nov 02 #Javascript
一定要知道的 25 个 Vue 技巧
原型和原型链 prototype和proto的区别详情
Nov 02 #Javascript
浅谈克隆 JavaScript
Nov 02 #Javascript
You might like
php在多维数组中根据键名快速查询其父键以及父键值的代码
2011/05/07 PHP
md5 16位二进制与32位字符串相互转换示例
2013/12/30 PHP
Centos PHP 扩展Xchche的安装教程
2016/07/09 PHP
php微信开发之自定义菜单完整流程
2016/10/08 PHP
PHP构造二叉树算法示例
2017/06/21 PHP
Thinkphp5.0框架视图view的模板布局用法分析
2019/10/12 PHP
关于PHP中interface的用处详解
2020/07/26 PHP
javascript attachEvent和addEventListener使用方法
2009/03/19 Javascript
禁止js文件缓存的代码
2010/04/09 Javascript
使用jQuery避免鼠标双击的解决方案
2013/08/21 Javascript
关于jquery中全局函数each使用介绍
2013/12/10 Javascript
jquery动态增加删减表格行特效
2015/11/20 Javascript
Vue计算属性的学习笔记
2017/03/22 Javascript
echart简介_动力节点Java学院整理
2017/08/11 Javascript
JavaScript数据结构之栈实例用法
2019/01/18 Javascript
p5.js临摹旋转爱心
2019/10/23 Javascript
[08:42]DOTA2每周TOP10 精彩击杀集锦vol.2
2014/06/25 DOTA
Python单链表的简单实现方法
2014/09/23 Python
在Python的Flask框架中实现单元测试的教程
2015/04/20 Python
Python算法之求n个节点不同二叉树个数
2017/10/27 Python
python实时监控cpu小工具
2018/06/21 Python
python 调用有道api接口的方法
2019/01/03 Python
详解opencv Python特征检测及K-最近邻匹配
2019/01/21 Python
python实现移位加密和解密
2019/03/22 Python
python手写均值滤波
2020/02/19 Python
Python列表如何更新值
2020/05/27 Python
基于Python的接口自动化unittest测试框架和ddt数据驱动详解
2021/01/27 Python
NBA欧洲商店(英国):NBA Europe Store UK
2018/07/27 全球购物
初中音乐教学反思
2014/01/12 职场文书
大学社团活动策划书
2014/01/26 职场文书
粗加工管理制度
2014/02/04 职场文书
教师先进工作者事迹材料
2014/05/01 职场文书
新兵入伍心得体会
2014/09/04 职场文书
2014年预备党员端正入党动机思想汇报
2014/09/13 职场文书
《和时间赛跑》读后感3篇
2019/12/16 职场文书
对讲机知识
2022/04/07 无线电