深入JS(一): 数据类型与检测方法原理

JS数据类型

undefined

  • undefined 的含义是 未被赋值 未被初始化

null

  • 值未知的特殊值。

bigint

  • JS 中,"number" 类型不能安全地表示大于 (253-1) 的整数值(即 9007199254740991),或小于 -(253-1) 的负数。
  • BigInt 可以表示任意长度的整数。
js 复制代码
const bigInt = 1234567890123456789012345678901234567890n;

symbol

  • 创建唯一标识符

常用symbol

js 复制代码
Object.prototype[Symbol.iterator]=function(){
  let arr=Object.values(this)
  return arr[Symbol.iterator]()
}
let [a,b]={a:1,b:2}
console.log(a,b);
//1 2

类型检测

typeof

  • typeof 适合判断基本类型(除 null 外)

typeof原理: 数据在底层都表示为二进制,在Javascript中二进制前(低)三位存储其类型信息

typeof 对于原始类型来说,除了 null 都可以显示正确的类型

js 复制代码
typeof 1 // 'number'
typeof '1' // 'string'
typeof undefined // 'undefined'
typeof true // 'boolean'
typeof Symbol() // 'symbol'
typeof null // 'object'
typeof [] // 'object'
typeof {} // 'object'
typeof console // 'object'
typeof console.log // 'function'

instanceof

  • instanceof 用于检测对象的具体实例类型 ,无法判断原始类型

如果有静态方法 Symbol.hasInstance,那就直接调用这个方法:

js 复制代码
let a={}
a[Symbol.hasInstance]=function(arg){
  if(arg=='111'){
    return true
  }
}
console.log('111' instanceof a);//true

如果没有,则检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。

js 复制代码
console.log("11" instanceof String); //false
console.log(11 instanceof Number); //false
console.log({} instanceof Object); //true
console.log([] instanceof Array); //true

toString方法

对象的toString()
  • 取得该对象的 [Symbol.toStringTag] 属性值作为 tag,然后返回 "[object " + tag + "]" 形式的字符串。
js 复制代码
let user = {
    [Symbol.toStringTag]: "User"
  };
console.log(Object.prototype.toString.call(user));  
//[object User]
js 复制代码
console.log(Object.prototype.toString({}));//[object Object]
console.log(Object.prototype.toString.call([])); //[object Array]
console.log(Object.prototype.toString.call('11'));//[object String]

为啥需要调用call

直接调用数组和字符串实例的toString方法可能会受到原型上toString方法被覆盖的影响。而使用Object.prototype.toString.call()确保了调用的是最原始、未被修改的toString方法,提高了代码的稳定性和可靠性。

数组的toString()
js 复制代码
console.log([1, 2, 3].toString()); // 正常输出:"1,2,3"
其他的toString()
js 复制代码
//Number
let num = 123;
console.log(num.toString()); // 输出 "123"

//String
let str = "Hello";
console.log(str.toString()); // 输出 "Hello"

//Boolean
console.log(true.toString()); // 输出 "true"
console.log(false.toString()); // 输出 "false"

//函数function
let func = function() { return "Hello"; };
console.log(func.toString()); // 输出 "function (){ return "Hello"; }"

Array.isArray()

Array.isArray()的判断逻辑:

  • 在JS中,每个对象都有一个内部属性 [[Class]],它是一个字符串,描述了对象的具体类型(如 "Array""Date""RegExp" 等)。
  • 使用 Object.prototype.toString.call() 判断
相关推荐
freewlt6 小时前
前端性能优化实战:从 Lighthouse 分数到用户体验的全面升级
前端·性能优化·ux
小小亮016 小时前
Next.js基础
开发语言·前端·javascript
华洛6 小时前
我用AI做了一个48秒的真人精品漫剧,不难也不贵
前端·javascript·后端
Novlan17 小时前
我把 Claude Code 里的隐藏彩蛋提取出来了——零依赖的 ASCII 虚拟宠物系统
前端
IAUTOMOBILE7 小时前
Python 流程控制与函数定义:从调试现场到工程实践
java·前端·python
好大哥呀7 小时前
C++ Web 编程
开发语言·前端·c++
爱学习的小仙女!8 小时前
面试题 前端(一)DOCTYPE作用 标准模式与混杂模式区分
前端·前端面试题
小小小小宇9 小时前
前端转后端基础- 变量和类型
前端
Cobyte9 小时前
1.基于依赖追踪和触发的响应式系统的本质
前端·javascript·vue.js
主宰者10 小时前
C# CommunityToolkit.Mvvm全局事件
java·前端·c#