JavaScript数字与字符串转换分隐式和显式两类:显式推荐String()或toString()(前者安全处理null/undefined,后者调用时会报错),转数字可用Number()、parseInt()、parseFloat();隐式转换发生在+、==等运算中,需警惕类型自动转换陷阱。

JavaScript 中数字和字符串的转换很常见,核心在于理解隐式转换和显式转换两种方式,以及它们背后的类型转换规则。
显式转字符串:稳妥又可控
推荐用 String() 或 .toString() 方法,语义清晰、行为确定。
-
String(123) → "123",能安全处理
null和undefined(分别转为 "null"、"undefined") -
(123).toString() → "123",但
null.toString()或undefined.toString()会报错 - 123 + "" 是常用技巧,本质是隐式转换,简洁但稍不直观
显式转数字:按需选方法
不同场景适合不同函数,关键看容错性和解析逻辑:
- Number("123") → 123;Number(" 45 ") → 45;但 Number("12abc") → NaN
- parseInt("123px", 10) → 123,支持进制和“从左到右取整数部分”,parseInt("12.9") → 12
- parseFloat("3.14em") → 3.14,专用于浮点数,遇到非数字字符就停止
隐式转换:发生在运算或比较时,容易踩坑
JS 会在 +、==、if 判断等上下文中自动转换类型,规则有迹可循但需留心:
立即学习“Java免费学习笔记(深入)”;
- "1" + 2 → "12"(+ 有字符串优先级,任一操作数为字符串就全转字符串拼接)
- "1" == 1 → true(== 先转成同一类型再比,这里字符串转数字)
- Boolean("0") → true(非空字符串都是 true,包括 "0"、"false"、" ")
- 0 == false → true,但 0 === false → false(=== 不转换,类型不同直接 false)
类型转换的核心规则:抽象操作是基础
所有转换最终都依赖 JS 内部的抽象操作,比如:
- ToPrimitive(input, hint):决定先尝试转字符串(hint=string)还是数字(hint=number)
-
ToString():null→"null",undefined→"undefined",true→"true",对象默认调
obj.toString() - ToNumber():空字符串→0," 12 "→12,"abc"→NaN,null→0,undefined→NaN
基本上就这些。记住:显式转换更可靠,隐式转换要读懂上下文;用 === 替代 == 可避免多数意外转换;遇到不确定时,打印 typeof 和原始值,比猜更有效。











