iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript中isPrototypeOf函数
  • 419
分享到

JavaScript中isPrototypeOf函数

2024-04-02 19:04:59 419人浏览 安东尼
摘要

目录1、isPrototypeOf()示例1,Object类实例:示例2,自己定义Human类:示例3,再来看看Object的原型(prototype)是否是human的原型:示例4

 有时看一些框架源码的时候,会碰到 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的结构就很容易清楚了:

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内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaScript中isPrototypeOf函数

本文链接: https://www.lsjlt.com/news/156467.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中isPrototypeOf函数
    目录1、isPrototypeOf()示例1,Object类实例:示例2,自己定义Human类:示例3,再来看看Object的原型(prototype)是否是human的原型:示例4...
    99+
    2024-04-02
  • JavaScript中isPrototypeOf函数有什么作用
    本篇内容主要讲解“JavaScript中isPrototypeOf函数有什么作用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript中isPrototypeOf函数有什么作用”吧!...
    99+
    2023-06-25
  • JavaScript中isPrototypeOf、instanceof和hasOwnProperty函数怎么使用
    本篇内容主要讲解“JavaScript中isPrototypeOf、instanceof和hasOwnProperty函数怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScrip...
    99+
    2023-07-02
  • JavaScript中isPrototypeOf、instanceof和hasOwnProperty函数的用法详解
    isPrototypeOf 作用:检测一个对象是否是另一个对象的原型。或者说一个对象是否被包含在另一个对象的原型链中 var p = {x:1};//定义一个原型对象 var o =...
    99+
    2024-04-02
  • 【转】eval()函数(javascript) - [javaScript]
    版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明http://bywind.yourblog.org/logs/227398.htmleval()函数JavaScript有许多小窍门来使编程更加容易。其中之一就是eval()...
    99+
    2023-06-03
  • 怎么声明JavaScript中函数
    本篇内容主要讲解“怎么声明JavaScript中函数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么声明JavaScript中函数”吧! ...
    99+
    2024-04-02
  • JavaScript中function函数怎么用
    这篇文章主要介绍JavaScript中function函数怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!通过函数来封装任意多条语句,而且可以在任何地方、任何时间调用执行。而我们的JavaScript脚本语言比较...
    99+
    2023-06-25
  • JavaScript中map函数怎么用
    这篇文章主要介绍了JavaScript中map函数怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。map 函数语法: var new_array = arr.m...
    99+
    2023-06-17
  • 详解JavaScript中的replace()函数
    JavaScript中的replace()函数是用于替换字符串中的某个子串的方法。该方法接受两个参数:要替换的子串和替换后的字符串。...
    99+
    2023-09-09
    java
  • Javascript中的async函数详解
    前言:async 是“异步”的简写,async 用于申明一个 function 是异步的,而 await 用于等待一个异步方法执行完成,await 只能出现在...
    99+
    2024-04-02
  • JavaScript 中的 parseInt() 函数详解
    目录参数描述总结parseInt() 函数可解析一个字符串,并返回一个整数。 parseInt 可以接受 2 个函数。 parseInt(string, radix)&nb...
    99+
    2023-05-19
    js parseInt() 函数 js parseInt()
  • JavaScript中eval()函数怎么用
    小编给大家分享一下JavaScript中eval()函数怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. eval函数有什么用?调用eval函数,可以将其...
    99+
    2023-06-15
  • javascript中如何调用函数
    这篇文章将为大家详细讲解有关javascript中如何调用函数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。javascript中调用函数的方法:1、使用“对象.函数名(...
    99+
    2024-04-02
  • JavaScript中如何定义函数
    这篇文章给大家介绍JavaScript中如何定义函数,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、 函数式声明function  ...
    99+
    2024-04-02
  • javascript函数中with的用法
    这篇文章主要介绍“javascript函数中with的用法”,在日常操作中,相信很多人在javascript函数中with的用法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
  • JavaScript中fill函数怎么用
    这篇文章主要介绍了JavaScript中fill函数怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。fill函数语法: arr.fill(value[, sta...
    99+
    2023-06-17
  • JavaScript中find函数怎么用
    这篇文章主要介绍了JavaScript中find函数怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。find 函数语法: arr.find(callbackFn...
    99+
    2023-06-17
  • javascript中有没有split函数
    这期内容当中小编将会给大家带来有关javascript中有没有split函数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 javascrip...
    99+
    2024-04-02
  • 在 PHP 中调用 JavaScript 函数
    在本文中,我们将介绍一种从 PHP 调用 JavaScript 函数的方法。我们实际上无法使用 PHP 调用 JavaScript 函数,因为这两种语言互不理解。唯一可能的选择是在 PHP 中输​​出 ...
    99+
    2024-02-27
  • JavaScript中JSON.parse函数和JSON.stringify函数有什么用
    这篇文章主要为大家展示了“JavaScript中JSON.parse函数和JSON.stringify函数有什么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作