JS类型检测主要有四种

  • 1、typeof Obj
  • 2、L instanceof R
  • 3、Object.prototype.toString.call/apply();
  • 4、Obj.constructor

    Remark前两种是数据类型检查方式,后两种是构造函数判断

首先了解下显式原型prototype

  • 每一个函数(fn)在创建之后都有一个prototype, 且指向函数的原型对象, 原型对象中的constructor属性又指向fn;
    fun = function () {};
    fun.prototype// 函数包含prototype指向它的原型对象 且 fun.prototype.constructor又指向fun函数

其次了解下隐式原型__proto__

  • JS中任意一个构建的对象都有__proto__, __proto__指向创建这个对象的constructor函数的prototype;

    • Array.proto => undefined;
    • Object.proto => null;
    // 1、字面量方式创建star
    let testObj = {a: 1};
    // 实际进行了以下步骤
    let textObj = new Object();
    textObj.a = 1;// 此时textObj有了__proto__,且__proto__指向Object.prototype
    // 同理 字面量创建一个数组
    let testArr = [];
    testArr = new Array();
    // 1、字面量方式创建end
    // 2、通过Object.create()构造 star
    const Obj = {a: 1};
    const copyObj = Object.create(Obj);
    // 内部是这样的
    function create(o) {
    function copy() {};
    copy.prototype = o; // **Remark此时Object.create创建的对象copyObj.__proto__直接指向Obj而不是Obj.prototype**
    return new copy(); // create也是new一个
    }
    // 2、通过Object.create()构造 end
    • 都是new一个实例对象

    显式原型prototype的作用

    • 用来实现基于原型的继承和属性共享

    隐式原形的作用

    • 构成原型链, 同样用于基于原型的继承, example: 当我们访问obj.a属性时, 如果obj找不到,那么会沿着__proto__依次寻找;(敲黑板: 重点是依次寻找);
    • 重写__proto__
    const arr = [];
    arr.__proto__.unPush = obj => console.log(obj);
    arr.push(1); // arr本身没有push(),但是它会从隐形原型上__proto__依次查找, 找到Array.prototype上有该方法所以可以使用
    arr.unPush(2); // 2

typeof

  • 缺陷有两点
  • 只能判断基本数据类型除了null,不能判断引用数据类型(判断都为Object);
  • typeof 1 => 'Number';
  • typeof {} => 'Object';
  • typeof null => 'Object';
  • typeof undefined => 'undefined'

L instanceof R 判断变量是否在某一个instanceof上("实例"上)

  • 判断左边的隐式原型是否在右边的显式原型上, 不是的话依次往上找直到为null为止; (new 操作符的反向查找)
function instance_of(L, R) {
L.__proto__ === R.prototype ? true : instance_of(L.__proto__, R);
// 一直从隐式原型链上查找
}
  • 只能判断引用数据类型
  • 右边只能是构造函数或者对象, 不然会抛出TypeError错误

Object.prototype.toString.call/apply();最完美的检测方法, 检测所有类型

  • 实现过程????!!!

constructor

  • Obj.constructor === Number/Array/Object/Function/String/Boolean
  • 字面量或者构造函数都能检测example: new Number()
  • 不能判断null和undefined

isArray(); isNaN();

//原文链接 https://blog.csdn.net/sunshine940326/article/details/77944768

JS类型判断&原型链的更多相关文章

  1. js 类型系统的核心:元类型、原型链与内省机制

    js 类型系统的核心:元类型.原型链与内省机制 二.JS数据类型 下面就来看看JS中的数据类型,在js中定义了如下几种数据类型:大方向上分为 基本数据类型(简单数据类型) 和 引用数据类型(复杂数据类 ...

  2. JS对象、原型链

    忘记在哪里看到过,有人说鉴别一个人是否 js 入门的标准就是看他有没有理解 js 原型,所以第一篇总结就从这里出发. 对象 JavaScript 是一种基于对象的编程语言,但它与一般面向对象的编程语言 ...

  3. JS面向对象之原型链

      对象的原型链 只要是对象就有原型 原型也是对象 只要是对象就有原型, 并且原型也是对象, 因此只要定义了一个对象, 那么就可以找到他的原型, 如此反复, 就可以构成一个对象的序列, 这个结构就被成 ...

  4. 类型和原生函数及类型转换(二:终结js类型判断)

    typeof instanceof isArray() Object.prototype.toString.call() DOM对象与DOM集合对象的类型判断 一.typeof typeof是一个一元 ...

  5. 深入理解JS对象和原型链

    函数在整个js中是最复杂也是最重要的知识 一个函数中存在多面性: 1.它本身就是一个普通的函数,执行的时候形成的私有作用域(闭包),形参赋值,预解释,代码执行,执行完 成后栈内存销毁/不销毁. 2.& ...

  6. JS类型判断typeof PK {}.toString.call(obj)

    参考链接:https://www.talkingcoder.com/article/6333557442705696719 先看typeof <!doctype html> <htm ...

  7. js类型判断:typeof与instanceof

    typeof用以获取一个变量或者表达式的类型,typeof一般只能返回如下几个结果: number,boolean,string,function(函数),object(NULL,数组,对象),und ...

  8. js类型判断及鸭式辨型

    目录 instanceof constructor 构造函数名字 鸭式辨型 三种检测对象的类方式: instanceof.constructor .构造函数名字 用法如下: 1)instanceof ...

  9. JS中的原型链和原型的认识

    这篇文章主要是学习一下JavaScript中的难点------原型和原型链 自定义一个对象 我们学习一门编程语言,必然要使用它完成一些特定的功能,而面向对象的语言因为符合人类的认知规律,在这方面做得很 ...

随机推荐

  1. java的本地文件操作

    一.文件的创建.删除和重命名 File file = new File("/bin/hello.txt");//文件无法被创建,系统找不到指定的路径file.createNewFi ...

  2. iOS中利用CoreTelephony获取用户当前网络状态(判断2G,3G,4G) by徐文棋

    前言: 在项目开发当中,往往需要利用网络.而用户的网络环境也需要我们开发者去注意,根据不同的网络状态作相应的优化,以提升用户体验. 但通常我们只会判断用户是在WIFI还是移动数据,而实际上,移动数据也 ...

  3. web虚拟主机、日志分割以及日志分析

    目录 一.构建虚拟web主机 1.1 概述 1.2 支持的虚拟主机类型 1.3 部署虚拟主机步骤 1.3.1 基于域名的虚拟主机 (1)为虚拟主机提供域名解析 (2)为虚拟主机准备网页文档 (3)添加 ...

  4. fiddler模拟弱网1

    第一步: 首先你得将你的fiddle配置好了,并链接上了移动端. 参考 这篇文章:http://www.cnblogs.com/lijiageng/p/6214162.html     第二步: 使用 ...

  5. selenium学习路线

      1.配置你的测试环境,针对你所学习语言,来配置你相应的selenium 测试环境.selenium 好比定义的语义---"问好",假如你使用的是中文,为了表术问好,你的写法是& ...

  6. Feign实现动态URL

    需求描述 动态URL的需求场景: 有一个异步服务S,它为其他业务(业务A,业务B...)提供异步服务接口,在这些异步接口中执行完指定逻辑之后需要回调相应业务方的接口. 这在诸如风控审核,支付回调等场景 ...

  7. 精简的言语讲述技术人,必须掌握基础性IT知识技能,第一篇

    前言 此系列将以精简的言语讲述技术人,必须掌握基础性IT知识技能,请持续关注,希望给大家都是一些精简的干货. 第一部分:必须掌握的设计模式的6大基本原则 23个设计模式,都是从这六大设计模式中演化而来 ...

  8. 经纬坐标(BLH)数据创建.kml文件小工具设计 Java版

    技术背景 KML,是标记语言(Keyhole Markup Language)的缩写,最初由Keyhole公司开发,是一种基于XML 语法与格式的.用于描述和保存地理信息(如点.线.图像.多边形和模型 ...

  9. Solution -「ARC 101D」「AT4353」Robots and Exits

    \(\mathcal{Description}\)   Link.   有 \(n\) 个小球,坐标为 \(x_{1..n}\):还有 \(m\) 个洞,坐标为 \(y_{1..m}\),保证上述坐标 ...

  10. LibOpenCM3(一) Linux下命令行开发环境配置

    目录 LibOpenCM3(一) Linux下命令行开发环境配置 本文使用 Linux 环境, 硬件为 STM32F103 系列开发板 LibOpenCM3 介绍 LibOpenCM3 是GPL协议( ...