• js instanceof 解析


    js中的instanceof运算符

    概述

    instanceof运算符用来判断一个构造函数的prototype属性所指向的对象是否存在另外一个要检测对象的原型链上

    语法

    obj instanceofObject;//true 实例obj在不在Object构造函数中

    描述

    instanceof 运算符用来检测 constructor.prototype 是否存在于参数 object 的原型链上。


    实例

    1.instanceof的普通的用法,obj instanceof Object 检测Object.prototype是否存在于参数obj的原型链上。

    Person的原型在p的原型链中

    functionPerson(){};
    var p =new Person();
    console.log(p instanceof Person);//true

    2.继承中判断实例是否属于它的父类

    Student和Person都在s的原型链中

    functionPerson(){};
    functionStudent(){};
    var p =new Person();
    Student.prototype=p;//继承原型var s=new Student();
    console.log(s instanceof Student);//trueconsole.log(s instanceof Person);//true

    3.复杂用法

    这里的案例要有熟练的原型链的认识才能理解

    function Person() {}
    console.log(Object instanceof Object);     //true
    //第一个Object的原型链:Object=>
    //Object.__proto__ => Function.prototype=>Function.prototype.__proto__=>Object.prototype
    //第二个Object的原型:Object=> Object.prototype
    
    console.log(Function instanceof Function); //true
    //第一个Function的原型链:Function=>Function.__proto__ => Function.prototype
    //第二个Function的原型:Function=>Function.prototype
    
    console.log(Function instanceof Object);   //true
    //Function=>
    //Function.__proto__=>Function.prototype=>Function.prototype.__proto__=>Object.prototype
    //Object => Object.prototype
    
    console.log(Person instanceof Function);      //true
    //Person=>Person.__proto__=>Function.prototype
    //Function=>Function.prototype
    
    console.log(String instanceof String);   //false
    //第一个String的原型链:String=>
    //String.__proto__=>Function.prototype=>Function.prototype.__proto__=>Object.prototype
    //第二个String的原型链:String=>String.prototype
    
    console.log(Boolean instanceof Boolean); //false
    //第一个Boolean的原型链:Boolean=>
    //Boolean.__proto__=>Function.prototype=>Function.prototype.__proto__=>Object.prototype
    //第二个Boolean的原型链:Boolean=>Boolean.prototype
    
    console.log(Person instanceof Person); //false
    //第一个Person的原型链:Person=>
    //Person.__proto__=>Function.prototype=>Function.prototype.__proto__=>Object.prototype
    //第二个Person的原型链:Person=>Person.prototype

    总结

    对应上述规范做个函数模拟A instanceof B:

    function_instanceof(A, B){
        var O = B.prototype;// 取B的显示原型
        A = A.__proto__;// 取A的隐式原型while (true) {
            //Object.prototype.__proto__ === nullif (A === null)
                returnfalse;
            if (O === A)// 这里重点:当 O 严格等于 A 时,返回 truereturntrue;
            A = A.__proto__;
        }
    }
  • 相关阅读:
    简单的模板解析函数
    HTML通过事件传递参数到js 二 event
    HTML通过事件传递参数到js一
    通过this获取当前点击选项相关数据
    LeetCode 20. 有效的括号(Valid Parentheses)
    LeetCode 459. 重复的子字符串(Repeated Substring Pattern)
    LeetCode 14. 最长公共前缀(Longest Common Prefix)
    LeetCode 168. Excel表列名称(Excel Sheet Column Title)
    LeetCode 171. Excel表列序号(Excel Sheet Column Number) 22
    LeetCode 665. 非递减数列(Non-decreasing Array)
  • 原文地址:https://www.cnblogs.com/mike-mei/p/14007104.html
Copyright © 2020-2023  润新知