Js深入浅出——第一讲

本文深入解析JavaScript中的六种数据类型,包括原始类型和对象类型,并探讨了隐式转换的机制,例如文本与数值间的转换。此外,还对比了==与===操作符的区别,并介绍了类型检测的方法,包括使用typeof和Object.prototype.toString进行更精确的数据类型判断。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

六种数据类型

原始类型对象
objectFunction
stringArray
nullDate
number
boolean
undefined

隐式转换

文本与数值转换
- “文本数值”-数值 eg:

       "31"-0````  结果为31,减号在这里被理解为减法运算,位置可以对调
  • “文本数值”+数值 eg:
       "31"+0````  结果为310,加号在这里被理解为文本拼接,位置可以对调

==与===的区别

  • 在==中
    • 数字1和0会变转为true和false, 1 == true 和 0 == false 成立
    • 文本数字会转为数字进行比较, “10” == 10 是成立的
    • null == undefined 是成立的
  • 在===中
    • 所有比较都需要多一重比较,不会进行隐式转换
      • “10” === 10 是不成立

类型检测

Typeof函数检测

typeof函数返回值类型
typeof 100“number”
typeof false“boolean”
typeof function“function”
typeof(undefined)“undefined”
typeof new Object()“object”
typeof [1,2]“obeject”
typeof NaN“number”
typeof null“obeject”

Object.prototype.toString:原生原型扩展函数,用来更精确的区分数据类型

var   gettype=Object.prototype.toString  **先声明一个对象**
输出返回值类型
gettype.call(‘AaBbCc’)[object String]
gettype.call(123456)[object Number]
gettype.call(false)[object Boolean]
gettype.call(undef[object Undefined]
gettype.call(null)[object Null]
gettype.call({})[object Object]
gettype.call([])[object Array]
gettype.call(function(){[object Function]

判断还有用constructor,instanceof
可以看看这里,这里有更为精准的描述
typeof 和 instanceOf的区别_segmentfault
Javascript typeof 和instanceof by hongweigg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

crper

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值