XingYun blog
  • JS基础

    • 图解js原型链
    • JS Event Loop
    • 对象的底层数据结构
    • 让你的JavaScript代码简单又高效
    • 函数参数按值传递
    • 判断数据类型
    • 浮点数精度问题和解决办法
    • 常用方法snippet
    • 实现Promise
    • 防抖和节流
    • 巧用sort排序
  • CSS && HTML

    • CSS也需要性能优化
    • class命名规范
    • em、px、rem、vh、vw 区别
    • CSS揭秘阅读笔记
  • 浏览器

    • 浏览器是如何渲染页面的
    • 重排和重绘
    • BOM浏览器对象模型
    • DOM事件
    • 浏览器存储
  • 数据结构

    • JS实现链表
    • JS实现栈与栈应用
    • JS实现常见排序
    • 哈夫曼编码
    • MD5算法
  • vue原理浅析

    • Vue虚拟dom与Diff算法
    • 前端打包文件的缓存机制
    • vue数组为什么不是响应式
    • v-for为什么不能用index做key
  • 前端工程化

    • 浏览器是如何渲染页面的
    • 前端打包需要gzip压缩吗
    • 前端打包文件的缓存机制
    • webpack loader和plugin
  • 轮子&&组件库

    • 实现水波浪进度球
  • 文字转语音mp3文件
  • 文件上传前后端实现
  • moment.js给定时间获取自然月、周的时间轴
  • 实现文件上传功能
  • 批量下载照片
  • leaflet改变坐标原点
  • 网络

    • 有了MAC地址 为什么还需要IP地址
    • 为什么IP地址老是变
    • 我们为什么需要IPV6
    • TCP与UDP
  • 计算机组成原理

    • ASCII、Unicode、UTF-8和UTF-16
  • VSCode

    • VSCode图片预览插件 Image preview
    • rsync:linux间的高效传输工具

XingYun

冲!
  • JS基础

    • 图解js原型链
    • JS Event Loop
    • 对象的底层数据结构
    • 让你的JavaScript代码简单又高效
    • 函数参数按值传递
    • 判断数据类型
    • 浮点数精度问题和解决办法
    • 常用方法snippet
    • 实现Promise
    • 防抖和节流
    • 巧用sort排序
  • CSS && HTML

    • CSS也需要性能优化
    • class命名规范
    • em、px、rem、vh、vw 区别
    • CSS揭秘阅读笔记
  • 浏览器

    • 浏览器是如何渲染页面的
    • 重排和重绘
    • BOM浏览器对象模型
    • DOM事件
    • 浏览器存储
  • 数据结构

    • JS实现链表
    • JS实现栈与栈应用
    • JS实现常见排序
    • 哈夫曼编码
    • MD5算法
  • vue原理浅析

    • Vue虚拟dom与Diff算法
    • 前端打包文件的缓存机制
    • vue数组为什么不是响应式
    • v-for为什么不能用index做key
  • 前端工程化

    • 浏览器是如何渲染页面的
    • 前端打包需要gzip压缩吗
    • 前端打包文件的缓存机制
    • webpack loader和plugin
  • 轮子&&组件库

    • 实现水波浪进度球
  • 文字转语音mp3文件
  • 文件上传前后端实现
  • moment.js给定时间获取自然月、周的时间轴
  • 实现文件上传功能
  • 批量下载照片
  • leaflet改变坐标原点
  • 网络

    • 有了MAC地址 为什么还需要IP地址
    • 为什么IP地址老是变
    • 我们为什么需要IPV6
    • TCP与UDP
  • 计算机组成原理

    • ASCII、Unicode、UTF-8和UTF-16
  • VSCode

    • VSCode图片预览插件 Image preview
    • rsync:linux间的高效传输工具
  • leaflet改变坐标原点
  • 补间动画gsap与tween
  • 文字转语音mp3文件
  • JavaScript引入
  • JavaScript高级程序设计阅读笔记
  • Javascript函数参数按值传递传递
  • JS防抖和节流
  • 手写JS常用方法
  • 手写Promise
  • JS Event Loop
  • 重排和重绘
  • em、px、rem、vh、vw 区别
  • css也需要性能优化
  • 图解 js 原型链
  • js函数参数按值传递
  • BOM浏览器对象模型
  • DOM
  • 事件
  • js对象数组sort按需排序
  • 文件上传功能技术选型和前后端实现
  • 前端图片处理
  • 让你的JavaScript代码简单又高效
  • BEM:class命名规范
  • 前端规范-CSS属性那么多(杂),怎么排序
  • TypeScript Tips
  • jsx
  • canvas基础
  • 前端日志
  • 浏览器存储
  • CSS世界阅读笔记
  • CSS揭秘阅读笔记
  • js变量命名常用规范词
  • 你不知道的JavaScript阅读笔记
  • js对象的底层数据结构
  • js判断数据类型
    • JS浮点数精度问题和解决办法
    • js作用域
    • js堆栈溢出和内存泄漏
    • 浏览器是如何渲染页面的
    • 疑难杂症和踩坑问题合集
    • 免费在线API收集
    • 原生JS实现Ajax请求
    • cookie、session、localStorage、sessionStorage的区别
    • Sass与Less
    • arrayBuffer、blob、file对象
    • TypeScript基础
    • 前端
    XingYun
    2022-02-02
    目录

    js判断数据类型

    # 一、typeof

    
    typeof 1
    "number"
    
    typeof NaN
    "number"
    
    typeof "1"
    "string"
    
    typeof true
    "boolean"
    
    typeof undefined
    "undefined"
    
    typeof null
    "object"
    
    typeof []
    "object"
    
    typeof {}
    "object"
    
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25

    其中

    null, [], {} 都返回 "object"

    所以 typeof 无法判断数组、null、对象

    typeof null 为 'object'的 bug

    根据 C 语言的传统,null 被设计成可以自动转为 0。js 里也是一样

    JavaScript 中的数据在底层是以二进制存储,比如 null 所有存储值都是 0,但是底层的判断机制,只要前三位为 0,就会判定为 object,所以才会有 typeof null === 'object'这个 bug。

    # instanceof

    
    var a = {};
    a instanceof Object //true
    
    var b = [];
    b instanceof Array  //true
    
    
    1
    2
    3
    4
    5
    6
    7

    需要注意的是,instanceof只能用来判断对象和函数,不能用来判断字符串和数字等基础类型

    
    var b = '123';
    alert(b instanceof String);  //false
    
    var c = new String("123");
    alert(c instanceof String);  //true
    
    
    1
    2
    3
    4
    5
    6
    7

    # Object.prototype.toString.call()

    call()方法可以改变this的指向,那么可以把Object.prototype.toString()方法指向不同的数据类型上面,返回不同的结果

    
    Object.prototype.toString.call(1)
    "[object Number]"
    
    Object.prototype.toString.call(NaN);
    "[object Number]"
    
    Object.prototype.toString.call("1");
    "[object String]"
    
    Object.prototype.toString.call(true)
    "[object Boolean]"
    
    Object.prototype.toString.call(null)
    "[object Null]"
    
    Object.prototype.toString.call(undefined)
    "[object Undefined]"
    
    Object.prototype.toString.call(function a() {});
    "[object Function]"
    
    Object.prototype.toString.call([]);
    "[object Array]"
    
    Object.prototype.toString.call({});
    "[object Object]"
    
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28

    这种方法可以判断所有类型

    # 终极方法

    第一二种方法都有局限性,所以我们可以基于Object.prototype.toString.call()封装一个函数

    function mytypeof(obj){
      var s = Object.prototype.toString.call(obj)
      return s.match(/\[object (.*?)\]/)[1].toLowerCase()
    }
    
    1
    2
    3
    4
    
    mytypeof([12,3,343])
    "array"
    
    mytypeof({name: 'zxc', age: 18})
    "object"
    
    mytypeof(1)
    "number"
    
    mytypeof("1")
    "string"
    
     mytypeof(null)
    "null"
    
    mytypeof(undefined)
    "undefined"
    
    mytypeof(NaN)
    "number"
    
    mytypeof(Date)
    "function"
    
    mytypeof(new Date())
    "date"
    
    mytypeof(new RegExp())
    "regexp"
    
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    #JavaScript
    上次更新: 2023/04/05, 09:41:10
    js对象的底层数据结构
    JS浮点数精度问题和解决办法

    ← js对象的底层数据结构 JS浮点数精度问题和解决办法→

    最近更新
    01
    JavaScript-test
    07-20
    02
    二维码的原理
    07-20
    03
    利用ChatGPT优化代码
    07-20
    更多文章>
    Theme by Vdoing | Copyright © 2021-2023 XingYun | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式