JavaScript有8种数据类型,分7种基本类型(String、Number、Boolean、undefined、null、Symbol、BigInt)和1种引用类型(Object及其派生类如Array、Function等),核心区别在于存储方式、赋值行为、比较逻辑和可变性。

JavaScript 有 8 种数据类型,分为 基本类型(原始类型) 和 引用类型(对象类型) 两大类。区分它们的关键不在“叫什么”,而在于 存储方式、赋值行为、比较逻辑和可变性。
基本数据类型(7 种)
它们是不可再分的最小单元,值直接存于栈内存,操作的是值本身:
-
String:文本,如
"hello"、`world` -
Number:数字,含整数、小数、
NaN、Infinity -
Boolean:仅
true和false - undefined:变量声明未赋值,或属性不存在时的默认值
-
null:有意表示“空值”的原始值(注意:
typeof null返回"object",是历史遗留 bug) -
Symbol:ES6 新增,每次调用
Symbol()都生成唯一值,常用于对象属性名防冲突 -
BigInt:ES2020 新增,用后缀
n表示,如123n,支持任意精度整数运算
引用数据类型(1 大类,多种表现形式)
本质都是 Object 的实例,实际数据存在堆内存,变量中只保存指向它的地址(引用):
-
Object:普通键值对,如
{ name: "Alice", age: 30 } -
Array:有序集合,如
[1, "a", true](数组也是对象) -
Function:函数是一等公民,如
function fn() {}或() => {} -
Date:时间对象,如
new Date() -
RegExp:正则表达式,如
/\d+/g - Map / Set / WeakMap / WeakSet:ES6 新增的集合类型
- Promise / ArrayBuffer / TypedArray / DataView 等内置构造器实例
如何准确判断具体类型
单靠 typeof 不够可靠(比如 typeof null === "object",typeof [] === "object"),推荐组合使用:
技术上面应用了三层结构,AJAX框架,URL重写等基础的开发。并用了动软的代码生成器及数据访问类,加进了一些自己用到的小功能,算是整理了一些自己的操作类。系统设计上面说不出用什么模式,大体设计是后台分两级分类,设置好一级之后,再设置二级并选择栏目类型,如内容,列表,上传文件,新窗口等。这样就可以生成无限多个二级分类,也就是网站栏目。对于扩展性来说,如果有新的需求可以直接加一个栏目类型并新加功能操作
立即学习“Java免费学习笔记(深入)”;
-
typeof:适合快速区分基本类型("string"、"number"、"function"等),但对null、数组、普通对象都返回"object" -
instanceof:检查是否为某构造函数的实例,如[] instanceof Array→true;但跨 iframe 会失效 -
Object.prototype.toString.call(x):最稳妥的标准方法,返回形如"[object Array]"、"[object Date]"的字符串,可精准识别所有内置类型 -
Array.isArray()、Number.isNaN()、BigInt.asIntN()等专用 API:语义明确,优先用于对应场景
核心区别一句话总结
基本类型按值操作、复制即拷贝一份新值、比较看内容是否相等;引用类型按地址操作、复制只是多一个指针、比较看是不是同一个内存位置——改一个,另一个可能跟着变。










