码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • javascript--类型检测 type of 和 instanceof


    类型判断

    • 1、typeof
    • 2、instanceof
      • **instanceof 的原理**
    • 3、constructor

    1、typeof

    typeof在检测null、object、array、data的结果中都是object,所以无法用来区分这几个类型的区别。

     <script>
          let a = [
            "123",
            123,
            false,
            true,
            Symbol(1),
            new Date(),
            null,
            undefined,
            function () {},
            {},
            []
          ];
          a.forEach((item) => {
            console.log(item, "检测出的值:", typeof item);
          });
        </script>
    
    

    在这里插入图片描述

    2、instanceof

    缺点是只能检测该对象是否存在目标对象的原型上

    [对象] instanceof [构造函数]

      <script>
          function Foo() {}
          var f1 = new Foo();
          var d = new Number(1);
    
          console.log(f1 instanceof Foo); // true
          console.log(d instanceof Number); //true
          console.log(123 instanceof Number); //false   
          -->不能判断字面量的基本数据类型
        </script>
    
    console.log(Number instanceof Number)  // false
    console.log(String instanceof String)  // false
    console.log(Fun instanceof Fun)        // false,这里Fun指的是函数
    console.log(null instanceof Object)   // false,null不具有任何对象的特性,也没有__proto__属性
    

    instanceof 用于判断对象类型,但以上情况的结果都为false,请注意。

    instanceof 的原理

    因为会一直往原型链上查找

    L代表instanceof左边,R代表右边

    function hand(L, R) {
            let L = L._propto_;
            while (true) {
              if (L === null) {
                return false;
              }
              if (L === R.propotype) {
                return true;
              }
              L = L._propto_;
            }
          }
    
    

    3、constructor

    constructor 不能判断null、undefind,因为他们不是构造对象

      <script>
          let a = [
            "123",
            123,
            false,
            true,
            Symbol(1),
            new Date(),
            function () {},
            {},
            [],
            null,
            undefined,
          ];
          try {
            a.forEach((item) => {
              console.log(item, "检测出的值:", item.constructor.name);
            });
          } catch (e) {
            console.log(e);
          }
        </script>
    

    在这里插入图片描述
    4、Object.prototype.toString.call
    可以检测出所有的数据类型

    <script>
          let a = [
            "123",
            123,
            false,
            true,
            Symbol(1),
            new Date(),
            function () {},
            {},
            [],
            null,
            undefined,
          ];
          try {
            a.forEach((item) => {
              console.log(
                item,
                "检测出的值:",
                Object.prototype.toString.call(item)
              );
            });
          } catch (e) {
            console.log(e);
          }
        </script>
    

    在这里插入图片描述

  • 相关阅读:
    apple pencil一定要买吗?Ipad电容笔推荐品牌
    PySide6实现word转化pdf
    DVWA靶场环境搭建
    代码随想录算法训练营DAY29(记录)|C++回溯算法Part.5|491.递增子序列、46.全排列、47.全排列II
    2020年大厂Java面试前复习的正确姿势(800+面试题答案解析)
    简述如何使用Androidstudio对文件进行保存和获取文件中的数据
    【StableDiffusion秋叶包反斜杠问题】Failed to find xxx\sd-webui-aki-v4.8\...\xxx.pth
    第八章 时序检查(中)
    【大数据 - Doris 实践】数据表的基本使用(三):数据模型
    acwing第 126 场周赛 (扩展字符串)
  • 原文地址:https://blog.csdn.net/weixin_45705239/article/details/139842084
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号