现代 JavaScript 原始数据类型转换你学会了吗?

简介: 现代 JavaScript 原始数据类型转换你学会了吗?

640.png

类型转换


大多数情况下,运算符和函数会自动将赋予他们的值转换为正确的类型。

比如,alert 会自动将任何值都转换为字符串以进行显示。算术运算符会将值转换为数字。

在某些情况下,我们需要将值显式地转换为我们期望的类型。


对象还未纳入讨论中本章不会讨论 object 类型。先学习原始类型,之后我们会学习 object 类型。我们会在 info:object-toprimitive 一节中学习对象的类型转换。


字符串转换


当我们需要一个字符串形式的值时,就会进行字符串转换。

比如,alert(value)value 转换为字符串类型,然后显示这个值。

我们也可以显式地调用 String(value) 来将 value 转换为字符串类型:

let value = true;

alert(typeof value); // boolean


value = String(value); // 现在,值是一个字符串形式的 "true"

alert(typeof value); // string

字符串转换最明显。false 变成 "false"null 变成 "null" 等。


数字型转换


在算术函数和表达式中,会自动进行 number 类型转换。

比如,当把除法 / 用于非 number 类型:

alert( "6" / "2" ); // 3, string 类型的值被自动转换成 number 类型后进行计算

我们也可以使用 Number(value) 显式地将这个 value 转换为 number 类型。

let str = "123";

alert(typeof str); // string


let num = Number(str); // 变成 number 类型 123


alert(typeof num); // number

当我们从 string 类型源(如文本表单)中读取一个值,但期望输入一个数字时,通常需要进行显式转换。

如果该字符串不是一个有效的数字,转换的结果会是 NaN。例如:

let age = Number("an arbitrary string instead of a number");


alert(age); // NaN,转换失败

number 类型转换规则:


变成……
undefined NaN
null 0
true 和 false 1 和 0
string 去掉首尾空格后的纯数字字符串中含有的数字。如果剩余字符串为空,则转换结果为 0。否则,将会从剩余字符串中“读取”数字。当类型转换出现 error 时返回 NaN
译注:字符串转换为 number 类型时,除了 undefinednullboolean 三种特殊情况,只有字符串是由空格和数字组成时,才能转换成功,否则会出现 error 返回 NaN


例子:


alert( Number("   123   ") ); // 123

alert( Number("123z") );      // NaN(从字符串“读取”数字,读到 "z" 时出现错误)

alert( Number(true) );        // 1

alert( Number(false) );       // 0


请注意 nullundefined 在这有点不同:null 变成数字 0undefined 变成 NaN


加号 '+' 连接字符串

几乎所有的算术运算符都将值转换为数字进行运算,加号 + 是个例外。如果其中一个运算元是字符串,则另一个也会被转换为字符串。然后,将两者连接在一起:


alert( 1 + '2' ); // '12' (字符串在加号右边)

alert( '1' + 2 ); // '12' (字符串在加号左边)


这仅仅发生在至少其中一方为字符串的情况下。否则值会被转换为数字。


布尔型转换


布尔(boolean)类型转换是最简单的一个。

它发生在逻辑运算中(稍后我们将进行条件判断和其他类似的东西),但是也可以通过调用 Boolean(value) 显式地进行转换。

转换规则如下:

  • 直观上为“空”的值(如 0、空字符串、nullundefinedNaN)将变为 false
  • 其他值变成 true


比如:


alert( Boolean(1) ); // true
alert( Boolean(0) ); // false
alert( Boolean("hello") ); // true
alert( Boolean("") ); // false


请注意:包含 0 的字符串 "0" 是 true

一些编程语言(比如 PHP)视 "0"false。但在 JavaScript 中,非空的字符串总是 true
alert( Boolean("0") ); // true
alert( Boolean(" ") ); // 空白, 也是 true (任何非空字符串是 true)

总结


有三种常用的类型转换:转换为 string 类型、转换为 number 类型和转换为 boolean 类型。

字符串转换 —— 转换发生在输出内容的时候,也可以通过 String(value) 进行显式转换。原始类型值的 string 类型转换通常是很明显的。

数字型转换 —— 转换发生在进行算术操作时,也可以通过 Number(value) 进行显式转换。

数字型转换遵循以下规则:


变成……
undefined NaN
null 0
true / false 1 / 0
string “按原样读取”字符串,两端的空白会被忽略。空字符串变成 0。转换出错则输出 NaN


布尔型转换 —— 转换发生在进行逻辑操作时,也可以通过 Boolean(value) 进行显式转换。

布尔型转换遵循以下规则:


变成……
0, null, undefined, NaN, "" false
其他值 true


上述的大多数规则都容易理解和记忆。人们通常会犯错误的值得注意的例子有以下几个:


  • undefined 进行数字型转换时,输出结果为 NaN,而非 0
  • "0" 和只有空格的字符串(比如:" ")进行布尔型转换时,输出结果为 true

我们在本小结没有讲 object 类型的转换。在我们学习完更多关于 JavaScript 的基本知识后,我们会在专门介绍 object 的章节 对象原始值转换 中详细讲解 object 类型转换。


作业题


先自己做题目再看答案。


类型转换


重要程度:⭐️⭐️⭐️⭐️⭐️

下面这些表达式的结果是什么?

"" + 1 + 0
"" - 1 + 0
true + false
6 / "3"
"2" * "3"
4 + 5 + "px"
"$" + 4 + 5
"4" - 2
"4px" - 2
7 / 0
"  -9  " + 5
"  -9  " - 5
null + 1
undefined + 1
" \t \n" - 2

好好思考一下,把它们写下来然后和答案比较一下。


答案


"" + 1 + 0 = "10"// (1)
"" - 1 + 0 = -1// (2)
true + false = 1
6 / "3" = 2
"2" * "3" = 6
4 + 5 + "px" = "9px"
"$" + 4 + 5 = "$45"
"4" - 2 = 2
"4px" - 2 = NaN
7 / 0 = Infinity
" -9  " + 5 = " -9  5"// (3)
" -9  " - 5 = -14// (4)
null + 1 = 1// (5)
undefined + 1 = NaN// (6)
" \t \n" - 2 = -2// (7)


  1. 有字符串的加法 "" + 1,首先会将数字 1 转换为一个字符串:"" + 1 = "1",然后我们得到 "1" + 0,再次应用同样的规则得到最终的结果。
  2. 减法 -(就像大多数数学操作那样)只能用于数字,它会使空字符串 "" 转换为 0
  3. 带字符串的加法会将数字 5 加到字符串之后。
  4. 减法始终将字符串转换为数字,因此它会使 " -9 " 转换为数字 -9(忽略了字符串首尾的空格)。
  5. null 经过数字转换之后会变为 0
  6. undefined 经过数字转换之后会变为 NaN
  7. 字符串转换为数字时,会忽略字符串的开头和结尾处的空格字符。在这里,整个字符串由空格字符组成,包括 \t\n 以及它们之间的“常规”空格。因此,类似于空字符串,所以会变为 0
目录
相关文章
|
18天前
|
JavaScript 前端开发
js变量的作用域、作用域链、数据类型和转换应用案例
【4月更文挑战第27天】JavaScript 中变量有全局和局部作用域,全局变量在所有地方可访问,局部变量只限其定义的代码块。作用域链允许变量在当前块未定义时向上搜索父级作用域。语言支持多种数据类型,如字符串、数字、布尔值,可通过 `typeof` 检查类型。转换数据类型用 `parseInt` 或 `parseFloat`,将字符串转为数值。
18 1
|
18天前
|
JavaScript
JS 获取对象数据类型的键值对的键与值
JS 获取对象数据类型的键值对的键与值
|
18天前
|
存储 JavaScript 前端开发
JavaScript数据类型详解
【4月更文挑战第4天】JavaScript有七种基本数据类型(Number, String, Boolean, Null, Undefined, Symbol, BigInt)和一种复杂数据类型(Object)。Number用于数字,String是不可变的文本,Boolean表示逻辑值,Null为空,Undefined表示未赋值,Symbol是唯一标识,BigInt处理大整数。Object用于复杂数据结构,如数组和函数。此外,`typeof`操作符检测数据类型,但有特殊行为,如`typeof null === "object"`。
24 2
|
18天前
|
JavaScript
typeof 和 instanceofJS数据类型(js的问题)
typeof 和 instanceofJS数据类型(js的问题)
|
18天前
|
JavaScript 前端开发
JavaScript 中有哪些数据类型?
JavaScript 中有哪些数据类型?
19 3
|
18天前
|
JavaScript
JS常用数据类型转换
JS常用数据类型转换
19 1
|
18天前
|
JavaScript
数据类型转换(js的问题)
数据类型转换(js的问题)
10 0
|
18天前
|
存储 JavaScript 前端开发
【JavaScript技术专栏】JavaScript基础入门:变量、数据类型与运算符
【4月更文挑战第30天】本文介绍了JavaScript的基础知识,包括变量(var、let、const)、数据类型(Number、String、Boolean、Undefined、Null及Object、Array)和运算符(算术、赋值、比较、逻辑)。通过实例展示了如何声明变量、操作数据类型以及使用运算符执行数学和逻辑运算。了解这些基础知识对初学者至关重要,是进阶学习JavaScript的关键。
|
16天前
|
存储 前端开发 JavaScript
JavaScript数据类型归纳,架构师花费近一年时间整理出来的前端核心知识
JavaScript数据类型归纳,架构师花费近一年时间整理出来的前端核心知识
JavaScript数据类型归纳,架构师花费近一年时间整理出来的前端核心知识
|
18天前
|
存储 JavaScript 前端开发
JavaScript引用数据类型
JavaScript引用数据类型