【基础类】—类型转换

一、数据类型

  1. 原始类型

    Boolean、Null、Undefined、Number、String、Symbol

  2. 对象

    Object

二、显示类型转换

  1. Number函数, Number(param)
    1-1. param 是 原始类型 时
    数值:转换后还是原来的值
    字符串:如果可以被解析为数值,则转换为相应的数值,否则得到NaN。空字符串转为0
    布尔值:true转成1, false 转成 0
    undefined: 转成NAN
    null: 转成 0

1-2 param 是 Object时

① 先调用对象自身的ValueOf方法,如果返回值是原始类型,则直接对该值进行Number方法

②先调用对象自身的ValueOf方法,如果返回值是复合类型,再调用对象的toString方法, 如果toString方法的返回值是原始类型的值,则对该值使用Number方法

③ 先调用对象自身的ValueOf方法,如果返回值是复合类型,再调用对象的toString方法, 如果toString方法的返回值是复合类型的值,则报错

javascript 复制代码
if (Obj.ValueOf() === 原始类型) {
    let date = new Date() 
	date.valueOf() // 1691147634782
	Number(date) === Number(date.valueOf()) === 1691147634782
	retun Number(Obj.ValueOf())
} else if (Obj.ValueOf() === 复合类型 && Obj.ValueOf().toString() === 原始类型) {
	Number(['1']) === Number(['1'].valueOf().toString()) === 1
	let obj = {name: '张三'}
	Number(obj) === Number(obj.valueOf().toString())  === NaN
	return Number(Obj.ValueOf().toString())
} else if(Obj.ValueOf() === 复合类型 && Obj.ValueOf().toString() === 复合类型 ) {
	return 报错
}
  1. String函数,String(param)
    2-1. param 是 原始类型 时
    数值:转换为相应的字符串
    字符串:返回原来的值
    布尔值:true转成"true", false 转成 "false"
    undefined: 转成 "undefined"
    null: 转成 "null"

2-2 param 是 Object时

① 先调用toString方法,如果toString方法返回的是原始类型的值,则对该值使用String方法

②先调用toString方法,如果返回值是复合类型,再调用对象的ValueOf方法, 如果ValueOf方法的返回值是原始类型的值,则对该值使用String方法

③ 先调用对象自身的toString方法,如果返回值是复合类型,再调用对象的ValueOf方法, 如果ValueOf方法的返回值是复合类型的值,则报错

javascript 复制代码
在这里插入代码片
  1. Boolean函数 Boolean(param)
    当param = undefined、null、-0、+0、NaN、'' 时, 都返回false, 其他值一律返回true

三、隐式类型转换

  1. 四则运算 (加减乘除)
  2. 判断语句 (if、else、三元运算符)
  3. Native调用 (console.log, alert 自动转换为字符串类型,隐式转换背后调用String函数)
  4. 常见题目

    \] + \[

javascript 复制代码
首先把第一个[] 转换为原始类型
=  [].ValueOf().toString()  + []
= '' + []
因为 '' 为字符串类型, [] 需要转换为字符串类型
= '' + [].ValueOf().toString()
= '' + ''
= ''

\] + {} ```javascript 首先把第一个[] 转换为原始类型 = [].ValueOf().toString() + {} 因为 '' 为字符串类型, {} 需要转换为字符串类型 = '' + {}.ValueOf().toString() = '' + '[object Object]' = '[object Object]' ``` {} + \[

{} + {}

true + true

1 + {a:1}

相关推荐
悠哉摸鱼大王2 分钟前
cesium学习(二)-地图地形
前端·cesium
SamDeepThinking20 分钟前
写代码不考虑前后兼容,迟早要还的
java·后端·程序员
青山师21 分钟前
【AI热点资讯】5月10日AI热点:Cloudflare裁员1100人、Musk庭审第二周回顾、OpenAI发布Codex Chrome插件
前端·人工智能·chrome·ai·ai热点
亿牛云爬虫专家23 分钟前
深度解析:数据采集场景下的 Java 代理技术实战
java·开发语言·数据采集·动态ip·动态代理·代理配置·连接池复用
小小仙。28 分钟前
IT自学第四十二天
java·开发语言
java1234_小锋34 分钟前
说一下Spring的事务传播行为?
java·数据库·spring
庞轩px36 分钟前
第四篇:SpringBoot自动配置——约定大于配置的底层原理
java·spring boot·后端·spring·自动配置·注解开发
不知名的忻37 分钟前
Dijkstra算法(朴素版&堆优化版)
java·数据结构·算法··dijkstra算法
苏三说技术37 分钟前
美团二面:高并发下如何保证接口幂等性?
java·数据库
TA远方43 分钟前
【JavaScript】Promise对象使用方式研究和理解
javascript·编程·脚本·web·js·promise·委托