JavaScript常见数据类型及区别

1.概述

Js中数据类型分为基本数据类型和引用数据类型,其中基本数据类型有undefinded,null,boolean,string,number,symbol;引用数据类型有:Object(函数也属于Object)

需要注意的是,简单数据类型是在栈内存中,值引用;引用数据类型则是在堆内存中,地址引用。

在 JavaScript 中,Symbol 是一种基本数据类型,它是在 ES6中引入的新特性。Symbol 提供了一种唯一且不可变的数据类型,用于标识对象的唯一性。

数据在声明时类型不会确定,只有到运行时才会确定当前类型

此时就涉及到类型转换,类型转换有:1.显示转换,2.隐式转换

2.显示转换

顾名思义,即我们知道发生了明确的转换,常见的转换方法有:

Number(),

parseInt(),

String(),

Boolean()

Number()

将任意类型的值转换成数值

eg:

Number(324) // 324
​
// 字符串:如果可以被解析为数值,则转换为相应的数值
Number('324') // 324
​
// 字符串:如果不可以被解析为数值,返回 NaN
Number('324abc') // NaN
​
// 空字符串转为0
Number('') // 0
​
// 布尔值:true 转成 1,false 转成 0
Number(true) // 1
Number(false) // 0
​
// undefined:转成 NaN
Number(undefined) // NaN
​
// null:转成0
Number(null) // 0
​
// 对象:通常转换成NaN(除了只包含单个数值的数组)
Number({a: 1}) // NaN
Number([1, 2, 3]) // NaN
Number([5]) // 5

从上看出,Number的转换比较严格,若是一个字符无法转换成数值,整个字符串就会变成NaN

parseInt()

该函数会逐步解析字符,遇到不能转换的字符就会停下来

parseInt('32a3') //32

String()

将任意类型转换成字符串

// 数值:转为相应的字符串
String(1) // "1"
​
//字符串:转换后还是原来的值
String("a") // "a"
​
//布尔值:true转为字符串"true",false转为字符串"false"
String(true) // "true"
​
//undefined:转为字符串"undefined"
String(undefined) // "undefined"
​
//null:转为字符串"null"
String(null) // "null"
​
//对象
String({a: 1}) // "[object Object]"
String([1, 2, 3]) // "1,2,3"
​
//undefined
String(undefined) //"undefined"

Boolean()

将任意值转换成布尔值

Boolean(undefined) // false
Boolean(null) // false
Boolean(0) // false
Boolean(NaN) // false
Boolean('') // false
Boolean({}) // true
Boolean([]) // true
Boolean(new Boolean(false)) // true

3.隐式转换

发生隐式转换的场景有(发生运算的操作数不是同一类型)

  • 比较运算( ===,!=,<,>),if,while

  • 算术运算:加减乘除,取余运算等

自动转换成布尔值

在需要布尔值的地方会自动将非布尔值转换成布尔值,系统内部会调用Boolean函数

undefined,null,false,0,NaN,""等都会自动转换成false,其余转换成true

自动转换成字符串

一般发生+运算中,一旦存在字符串,就会进行字符串拼接操作

'5' + 1 // '51'
'5' + true // "5true"
'5' + false // "5false"
'5' + {} // "5[object Object]"
'5' + [] // "5"
'5' + function (){} // "5function (){}"
'5' + undefined // "5undefined"
'5' + null // "5null"

自动转换为数值

'5' - '2' // 3
'5' * '2' // 10
true - 1  // 0
false - 1 // -1
'1' - 1   // 0
'5' * []    // 0
false / '5' // 0
'abc' - 1   // NaN
null + 1 // 1
undefined + 1 // NaN

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值