纯干货!类型转换的前因后果

引言

当你在编写 JavaScript 代码时,类型转换可能是你会遇到的最令人费解的问题之一。它就像是一个变身魔法,将数据从一个形式转换为另一个形式,有时候甚至会让你感觉自己置身于一个奇幻世界。但是别担心!在这篇文章中,我将带你进入类型转换的神奇世界,准备好了吗?让我们开始这段神奇的冒险吧!

基本数据类型的转换

1.转布尔值

  • 数字类型转换为布尔类型 :非零参数转换为true,0转换为false
  • 字符类型转换为布尔类型 :非空字符串会转换为 true,空字符串转换为false
  • undefined 类型转换为布尔值 : undefined 会转换为 false
  • null 类型转换为布尔值 :null 会转换为 false

2.转数字

  • 字符串类型转换为数字 :如果字符串中仅仅包含数字,则将转换为数字,若包含非数字字符,则返回NaN
  • 布尔类型转换为数字:布尔值 true 会转换为数字 1,布尔值 false 会转换为数字 0。
  • undefined 类型转换为数字 : undefined 会转换为 NaN
  • null 类型转换为数字: null 会转换为数字 0。

3.转字符串

  • String()会将基本数据类型都转换为字符串,但会将object转换为"[object object]",会将数组转换为数组内元素加上逗号的拼接

4.转对象

要将基本数据类型转换为对象,就要调用显示的类型转换,Number(),String()等等都能分别将数字和字符串转化为对象类型

对象转换为基本数据类型

1.转字符串

  • {}.toString() 返回由"[object" 和 class 和 "]" 组成的字符串
  • \].toString() 返回由数组内部元素以逗号拼接的字符串

2.转布尔值

对象转布尔值都为true

ToPrimitive

其实在对象进行转换为字符串或者数字时,会在内部调用ToPrimitive(),这是js内部的方法,我们并不能使用

若我们要将对象转换为数字,那么ToPrimitive()会按照以下顺序执行:

ToPrimitive(obj,Number) ==>Number({})

1.如果obj是基本类型,直接返回

2.否则,调用 valueOf 方法 ,如果得到原始值,则返回

3.否则,调用toString 方法,如果得到原始值,则返回

4.否则,报错

如果要将对象转换为字符串类型,则按照以下操作:

ToPrimitive(obj,String) ==>String({})

1.如果obj是基本类型,直接返回

2.否则,调用 toString 方法 ,如果得到原始值,则返回

3.否则,调用 valueOf 方法,如果得到原始值,则返回

4.否则,报错

我们来看几个案例分析一下:

js 复制代码
console.log(Number({}))//NaN

这里我们要将对象转换为数字,则先调用valueof方法,

而valueof无法将对象转换为原始类型,

接下来,再调用toString方法,

将对象转换为"[object object]",再转换为数字,

但是字符串无法转换为基本数字,于是变成NaN。

js 复制代码
console.log(Number([]))//0

这里我们将数组转为数字,

首先调用valueof方法,但无法转换为基本数据类型,

再调用toString方法,

在上文提到,数组调用toString返回由数组内部元素以逗号拼接的字符串,在这里返回一个空字符串,

那么空字符串转为数字就是0.

结尾

本篇文章只是简单介绍了一下引用类型和基本数据类型的转换,为下一篇内容的讲解打打基础。在下一篇内容中,我们将来讲讲运算符的相关内容。

相关推荐
然我22 分钟前
不用 Redux 也能全局状态管理?看我用 useReducer+Context 搞个 Todo 应用
前端·javascript·react.js
前端小巷子27 分钟前
Web 实时通信:从短轮询到 WebSocket
前端·javascript·面试
神仙别闹31 分钟前
基于C#+SQL Server实现(Web)学生选课管理系统
前端·数据库·c#
web前端神器37 分钟前
指定阿里镜像原理
前端
枷锁—sha42 分钟前
【DVWA系列】——CSRF——Medium详细教程
android·服务器·前端·web安全·网络安全·csrf
枷锁—sha43 分钟前
跨站请求伪造漏洞(CSRF)详解
运维·服务器·前端·web安全·网络安全·csrf
群联云防护小杜1 小时前
深度隐匿源IP:高防+群联AI云防护防绕过实战
运维·服务器·前端·网络·人工智能·网络协议·tcp/ip
DanB241 小时前
html复习
javascript·microsoft·html
汉得数字平台1 小时前
【鲲苍提效】全面洞察用户体验,助力打造高性能前端应用
前端·前端监控
花海如潮淹1 小时前
前端性能追踪工具:用户体验的毫秒战争
前端·笔记·ux