• 使用Object.prototype.toString.call()方法精确判断对象的类型


    在JavaScript里使用typeof判断数据类型,只能区分基本类型,即:number、string、undefined、boolean、object。
    对于null、array、function、object来说,使用typeof都会统一返回object字符串。
    要想区分对象、数组、函数、单纯使用typeof是不行的。在JS中,可以通过Object.prototype.toString方法,判断某个对象之属于哪种内置类型。
    分为null、string、boolean、number、undefined、array、function、object、date、math。

    1. 判断基本类型

    Object.prototype.toString.call(null); // "[object Null]"
    Object.prototype.toString.call(undefined); // "[object Undefined]"
    Object.prototype.toString.call(“abc”);// "[object String]"
    Object.prototype.toString.call(123);// "[object Number]"
    Object.prototype.toString.call(true);// "[object Boolean]"
    

    2. 判断原生引用类型

    //函数类型
    function fn(){
      console.log("test");
    }
    Object.prototype.toString.call(fn); // "[object Function]"
    
    //日期类型
    var date = new Date();
    Object.prototype.toString.call(date); // "[object Date]"
    
    //数组类型
    var arr = [1,2,3];
    Object.prototype.toString.call(arr); // "[object Array]"
    
    //正则表达式
    var reg = /[hbc]at/gi;
    Object.prototype.toString.call(reg); // "[object RegExp]"
    
    //自定义类型
    function Person(name, age) {
        this.name = name;
        this.age = age;
    }
    var person = new Person("Rose", 18);
    Object.prototype.toString.call(arr); // "[object Object]"
    

    很明显这种方法不能准确判断person是Person类的实例,而只能用instanceof操作符来进行判断,如下所示:

    console.log(person instanceof Person); // true
    

    3. 判断原生JSON对象

    var isNativeJSON = window.JSON && Object.prototype.toString.call(JSON);
    console.log(isNativeJSON);// 输出结果为”[object JSON]”说明JSON是原生的,否则不是;
    

    注意:Object.prototype.toString()本身是允许被修改的,而我们目前所讨论的关于Object.prototype.toString()这个方法的应用都是假设toString()方法未被修改为前提的。

    4. 实例:为Array对象添加一个去除重复项的方法

    [false, true, undefined, null, NaN, 0, 1, {}, {}, 'a', 'a', NaN].uniq()
    输出
    [false, true, undefined, null, NaN, 0, 1, {}, {}, 'a']

    这里要注意,NaN === NaN 为false,{} === {}为false。

    Array.prototype.uniq = function () {
        if (!this.length || this.length == 0) return this;
        var res = [], key, hasNaN = false, temp = {};
        for (var i = 0 ; i < this.length; i++) {
            if (typeof this[i] === 'object') {
                res.push(this[i]);
            } else if (this[i] != this[i]) { // 如果当前遍历元素是NaN
                if (!hasNaN) {
                    res.push(this[i]);
                    hasNaN = true;
                }
            } else {
                key = typeof(this[i]) + this[i];
                if (!temp[key]) {
                    res.push(this[i]);
                    temp[key] = true;
                }
            }
        }
        return res;
    }
    

    另一种解法:

    Array.prototype.uniq = function () {
        var res = [];
        var flag = true;
        this.forEach(function(x) {
            if (res.indexOf(x) == -1) {
                if (x != x) {
                    if (flag) {
                        res.push(x);
                        flag = false;
                    }
                } else {
                    res.push(x);
                }
            }
        })
        return res;
    }
    

    本文转自:https://www.jianshu.com/p/585926ae62cc

  • 相关阅读:
    蓝桥杯算法训练 区间k大数查询
    【模板】快读
    [ACM] hdu 2544 最短路(dijkstra算法)
    [ACM] hdu 3791 二叉搜索树
    [ACM] hdu 2141 Can you find it? (二分查找)
    [ACM] hdu 2025查找最大元素(水题)
    [ACM] hdu 1232 畅通工程(并查集)
    [ACM] hdu 1022 Train Problem I(栈的使用)
    [ACM] hdu 2857 Mirror and Light (对称点+两条直线的交点)
    [ACM] hdu 爆头(点到直线距离)
  • 原文地址:https://www.cnblogs.com/tnnyang/p/9197916.html
Copyright © 2020-2023  润新知