isPrototypeOf、instanceof、hasOwnProperty函数整理
isPrototypeOf
- 作用:检测一个对象是否是另一个对象的原型。或者说一个对象是否被包含在另一个对象的原型链中
- var p = {x:1};//定义一个原型对象
- var o = Object.create(p);//使用这个原型创建一个对象
- p.isPrototypeOf(o);//=>true:o继承p
- Object.prototype.isPrototypeOf(p);//=> true p继承自Object.prototype
以上实例来自与《JavaScript权威指南》,简单解释一下就是每一个JavaScript
对象都和原型关联,每一个对象都从原型继承属性。所有通过对象直接量创建的对象都使用Object.prototype
作为他们的原型,因此p
是继承自Object.prototype
,因此在p
的原型链中一定存在Object.prototype
。
上面还提到了Object.create();
该方法创建一个新对象,第一个参数是这个对象的原型,所以上面创建的o
对象它的原型就是p
;
- function Animal(){
- this.species = "动物";
- };
- var eh = new Animal();
- Animal.prototype.isPrototypeOf(eh)//=>true
以上实例是通过new
创建了对象eh
,使用构造函数Animal
的prototype
作为它的原型。
综合上面的两个例子,我们发现在调用isPrototypeOf()
的时候有三种方式
- p.isPrototypeOf(o);//=>true
- Object.prototype.isPrototypeOf(p);
- Animal.prototype.isPrototypeOf(eh)//=>true
总结一下就是:
通过Object.create()
创建的对象使用第一个参数作为原型
通过对象直接量的对象使用Object.prototype
作为原型
通过new
创建的对象使用构造函数的prototype
属性作为原型
instanceof
instanceof运算符希望左操作数是一个对象,右操作数标识对象的类。如果左侧对象是右侧类的实例,则表达式返回为true,否则返回false。
- var d = new Date();
- d instanceof Date;//=>true d是Date的实例
- d instanceof Object;//=>true 所有对象都是Object的实例
当通过instanceof判断一个对象是否是一个类的实例的时候,这个判断也会包含对父类的检测。尽管instanceof的右操作数是构造函数,但计算过程实际是检测了对象的继承关系。
instanceOf与isPrototypeOf简单总结
- var d = new Date();
- Date.prototype.isPrototypeOf(d);//=>true
- d instanceof Date;//=>true
- 如果Date.prototype是d的原型,那么d一定是Date的实例。
- 缺点为无法同对象来获得类型,只能检测对象是否属于类名
- 在多窗口和多框架的子页面的web应用中兼容性不佳。其中一个典型代表就是instanceof操作符不能视为一个可靠的数组检测方法。
hasOwnProperty
检测集合成员的所属关系,判断某个属性是否存在于某个对象中。可以通过in运算符,hasOwnProperty()来完成。
in
运算符左侧是属性名,右侧是字符串,如果对象的自由属性或者继承属性中包含这个属性则返回true
。
对象的hasOwnProperty()
方法用来检测给定的名字是否是对象的自由属性,如果是继承属性则返回false。
- function Animal(){}//定义Animal构造函数
- Animal.prototype = {//定义Animal原型
- species:"动物",
- say:function(){
- console.log('i can say word');
- }
- }
- function Cat(name,color){//定义构造函数Cat
- this.name = name;
- this.color = color;
- }
- var F = function(){};
- F.prototype = Animal.prototype;
- Cat.prototype = new F();
- Cat.prototype.constructor = Cat;//Cat继承Animal 用F空对象作为媒介
- var eh = new Cat('lili','white');//实例化对象
- console.log('say' in eh)//=>true
- console.log('name' in eh)//=>true
- console.log('color' in eh)//=>true
- console.log('species' in eh)=>true
- console.log(eh.hasOwnProperty('say'))=>false 由于say为继承属性 非自有属性
- console.log(eh.hasOwnProperty('species'))=>false 由于species为继承属性 非自有属性
- console.log(eh.hasOwnProperty('name'))=>true
- console.log(eh.hasOwnProperty('color'))=>true
- for(var key in eh){
- console.log(key);
- if(eh.hasOwnProperty(key)){
- console.log(key) //=>species say name color
- }
- }
isPrototypeOf、instanceof、hasOwnProperty函数整理的更多相关文章
- 面向对象的程序设计(二)理解各种方法和属性typeof、instanceof、constructor、prototype、__proto__、isPrototypeOf、hasOwnProperty
//理解各种方法和属性typeof.instanceof.constructor.prototype.__proto__.isPrototypeOf.hasOwnProperty. //1.typeo ...
- javascript 中isPrototypeOf 、hasOwnProperty、constructor、prototype等用法
hasOwnProperty:是用来判断一个对象是否有你给出名称的属性或对象,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员. isPrototypeOf是用来判断要检查 ...
- JS中isPrototypeOf 和hasOwnProperty 的区别 ------- js使用in和hasOwnProperty获取对象属性的区别
JS中isPrototypeOf 和hasOwnProperty 的区别 1.isPrototypeOf isPrototypeOf是用来判断指定对象object1是否存在于另一个对象object2的 ...
- 常用的WinAPI函数整理
常用的WinAPI函数整理 一.进程 创建进程: CreateProcess("C:\\windows\\notepad.exe",0,0,0,0,0,0,0,&s ...
- NiosII常用函数整理
NiosII常用函数整理 IO操作函数函数原型:IORD(BASE, REGNUM) 输入参数:BASE为寄存器的基地址,REGNUM为寄存器的偏移量函数说明:从基地址为BASE的设备中读取寄存器中偏 ...
- PHP清理跨站XSS xss_clean 函数 整理自codeigniter Security
PHP清理跨站XSS xss_clean 函数 整理自codeigniter Security 由Security Class 改编成函数xss_clean 单文件直接调用.BY吠品. //来自cod ...
- Python内置的字符串处理函数整理
Python内置的字符串处理函数整理 作者: 字体:[增加 减小] 类型:转载 时间:2013-01-29我要评论 Python内置的字符串处理函数整理,收集常用的Python 内置的各种字符串处理 ...
- JavaScript hasOwnProperty() 函数详解
hasOwnProperty()函数用于指示一个对象自身(不包括原型链)是否具有指定名称的属性.如果有,返回true,否则返回false. 该方法属于Object对象,由于所有的对象都"继承 ...
- [SQL] 函数整理(T-SQL 版)
函数整理(T-SQL 版) 一.数学函数 1.求绝对值 ABS() 函数用来返回一个数值的绝对值. SELECT ABS(-5.38) AS absValue; 2.求指数 POWER() 函数是用 ...
随机推荐
- mysql on duplicate key update 和 insert ignore into
on duplicate key update <insert id="insert" parameterType="Plan"> insert i ...
- Linux系统如何迁移至LVM磁盘
今天遇到一个问题,算是比较严重的把.就是要把当前系统转移到 LVM 卷里面去,下面有一些发生过程介绍. 不感兴趣可以直接跳过,看实战部分<如何迁移系统至LVM卷> 朋友今天突然找我,说是要 ...
- 如何 3D 打印一个密码锁
简评:这篇文章介绍怎么用 3D 打印机做一个密码锁,巧妙地利用机械结构的变化实现锁的功能,相当有趣! 3D 打印机非常适合打印静态物体.如果你够聪明,还可以打印出功能物件.如果你特别特别聪明,那你能做 ...
- 打扮IDEA更换主题
原文链接:https://blog.csdn.net/github_39577257/article/details/80629750 当我们安装一个新的IDEA工具时,第一次进入时会提示我们选择一个 ...
- POJ-2387-Til the Cows Come Home(最短路)
Til the Cows Come Home Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 72844 Accepted ...
- 使用私有git仓库备份服务器脚本和配置文件
1. 创建私有git仓库 服务器端配置: # 安装 git yum -y install git # 创建 git 用户 useradd git # 创建私有仓库数据存储目录 mkdir /git_b ...
- 使用 WebClient 來存取 GET,POST,PUT,DELETE,PATCH 網路資源
WebClient 基本資訊 提供通用方法使用 WebRequest 類別傳送及接收 URI (支援 http:, https:, ftp:,和 file: ) 的資源 Namespace:Syste ...
- Sum(欧拉降幂+快速幂)
Input 2 Output 2 Hint 1. For N = 2, S(1) = S(2) = 1. 2. The input file consists of multiple test cas ...
- Java 的 List 与 Scala 的 Seq 相互转换
1. List 转 Seq: List<String> tmpList = new ArrayList<>(); tmpList.add("abc"); S ...
- OAuth2 .net MVC实现获取token
OAuth2 的原理这里不多讲,可以看:https://www.cnblogs.com/icebutterfly/p/8066548.html 直奔主题:这里要实现的功能为,统计微软的Owin程序集实 ...