深入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() 判断
相关推荐
D_jing201 小时前
Vue 3 + Element Plus 重置el-drawer样式失效
前端·javascript·vue.js
__log1 小时前
Vue 3 与 React 18+ 核心技术深度对比:从源码到实战
前端·vue.js·react.js
很晚很晚了5 小时前
纯前端转全栈 Day 1:我从第一个 NestJS 接口开始
前端
Lee川6 小时前
从零解剖一个 AI Agent Tool是如何实现的
前端·人工智能·后端
wangruofeng7 小时前
Playwright 深度调研:为什么它成了浏览器自动化的新底座
前端·测试
李白的天不白9 小时前
SSR服务端渲染
前端
卷帘依旧10 小时前
SSE(Server-Sent Events)完全指南
前端
码云之上10 小时前
万星入坞:我们如何用三层插件体系干掉巨石应用
前端·架构·前端框架
kyriewen11 小时前
一口气讲清楚 Monorepo、Turborepo、pnpm、Changesets 到底是什么?
前端·架构·前端工程化
IT_陈寒11 小时前
React性能优化踩的坑,这个错你可能也会犯
前端·人工智能·后端