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 相关文章推荐
Javascript 不能释放内存.
Sep 07 Javascript
Jquery+CSS3实现一款简洁大气带滑动效果的弹出层
May 15 Javascript
实例详解ECMAScript5中新增的Array方法
Apr 05 Javascript
浅谈JS读取DOM对象(标签)的自定义属性
Nov 21 Javascript
Javascript基础回顾之(二) js作用域
Jan 31 Javascript
使用JS实现图片轮播的实例(前后首尾相接)
Sep 21 Javascript
webpack 样式加载的实现原理
Jun 12 Javascript
JS在if中的强制类型转换方式
Jul 15 Javascript
Vue实现6位数密码效果
Aug 18 Javascript
vue 微信扫码登录(自定义样式)
Jan 06 Javascript
JS+Canvas实现五子棋游戏
Aug 26 Javascript
vue3种table表格选项个数的控制方法
Apr 14 Vue.js
JavaScript原型链详解
JavaScript组合继承详解
详细聊聊vue中组件的props属性
教你一步步实现一个简易promise
Nov 02 #Javascript
一定要知道的 25 个 Vue 技巧
原型和原型链 prototype和proto的区别详情
Nov 02 #Javascript
浅谈克隆 JavaScript
Nov 02 #Javascript
You might like
国内php原创论坛
2006/10/09 PHP
用户的详细注册和判断
2006/10/09 PHP
php smarty模版引擎中变量操作符及使用方法
2009/12/11 PHP
PHP数据类型的总结分析
2013/06/13 PHP
php去除字符串中空字符的常用方法小结
2015/03/17 PHP
PHP中strpos、strstr和stripos、stristr函数分析
2016/06/11 PHP
javascript事件模型代码
2007/07/01 Javascript
兼容多浏览器的字幕特效Marquee的通用js类
2008/07/20 Javascript
JavaScript下利用fso判断文件是否存在的代码
2010/12/11 Javascript
解析使用JS 清空File控件的路径值
2013/07/08 Javascript
使用jQuery仿苹果官网焦点图特效
2014/12/23 Javascript
jQuery插件jFade实现鼠标经过的图片高亮其它变暗
2015/03/14 Javascript
AngularJS使用ngOption实现下拉列表的实例代码
2016/01/23 Javascript
js模拟百度模糊搜索的实例
2017/08/04 Javascript
使用InstantClick.js让页面提前加载200ms
2017/09/12 Javascript
原生JS与jQuery编写简单选项卡
2017/10/30 jQuery
JS实现贪吃蛇游戏
2019/11/15 Javascript
使用Python编写vim插件的简单示例
2015/04/17 Python
python导入csv文件出现SyntaxError问题分析
2017/12/15 Python
python使用代理ip访问网站的实例
2018/05/07 Python
python远程连接MySQL数据库
2019/04/19 Python
python集合常见运算案例解析
2019/10/17 Python
Python+Selenium+phantomjs实现网页模拟登录和截图功能(windows环境)
2019/12/11 Python
selenium+python实现自动登陆QQ邮箱并发送邮件功能
2019/12/13 Python
解决python-docx打包之后找不到default.docx的问题
2020/02/13 Python
HTML5 canvas基本绘图之绘制曲线
2016/06/27 HTML / CSS
中国海淘族值得信赖的海淘返利网站:55海淘
2017/01/16 全球购物
TripAdvisor土耳其网站:全球知名旅行社区,真实旅客评论
2017/04/17 全球购物
Hudson Jeans官网:高级精制牛仔裤
2018/11/28 全球购物
法国高保真音响和家庭影院商店:Son Video
2019/04/26 全球购物
美化环境标语
2014/06/20 职场文书
2016婚礼主持词开场白
2015/11/24 职场文书
浙江省杭州市平均工资标准是多少?
2019/07/09 职场文书
正能量励志演讲稿三分钟(范文)
2019/07/11 职场文书
Java数据结构之链表相关知识总结
2021/06/18 Java/Android
Java生成读取条形码和二维码的简单示例
2021/07/09 Java/Android