javascript基础三:谈谈 JavaScript 中的类型转换机制

这篇具有很好参考价值的文章主要介绍了javascript基础三:谈谈 JavaScript 中的类型转换机制。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

javascript基础三:谈谈 JavaScript 中的类型转换机制
一、概述
JS中有六种简单数据类型:undefined、null、boolean、string、number、symbol,以及引用类型:object

但是我们在声明的时候只有一种数据类型,只有到运行期间才会确定当前类型

let name = y?'allen':'1'

上面代码中,name的值在编译阶段是无法获取的,只有等到程序运行时才能知道

虽然变量的数据类型是不确定的,但是各种运算符对数据类型是有要求的,如果运算子的类型与预期不符合,就会触发类型转换机制

常见的类型转换有:

  • 强制转换(显示转换)
  • 自动转换(隐式转换)

二、显示转换
显示转换,即我们很清楚可以看到这里发生了类型的转变,常见的方法有:

  • Number()
  • parseInt()
  • String()
  • Boolean()

Number()
将任意类型的值转化为数值
先给出类型转换规则:
javascript基础三:谈谈 JavaScript 中的类型转换机制
举个粟子:

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

javascript基础三:谈谈 JavaScript 中的类型转换机制
从上面可以看到,Number转换的时候是很严格的,只要有一个字符无法转成数值,整个字符串就会被转为NaN

parseInt()
parseInt相比Number,就没那么严格了,parseInt函数逐个解析字符,遇到不能转换的字符就停下来

parseInt('123ab') // 123

String()
可以将任意类型的值转化成字符串
给出转换规则图:
javascript基础三:谈谈 JavaScript 中的类型转换机制
举个粟子:

// 数值转为对应的字符串
undefined
String(12345)
'12345'
// 字符串转换后还是原来的值
undefined
String('123456')
'123456'
// 布尔值true转成'true',false转为字符串'false‘’
undefined
String(true)
'true'
String(false)
'false'
// undefined转为字符串undefined
undefined
String(undefined)
'undefined'
// null 转为字符串'null'
undefined
String(null)
'null'
// 对象
undefined
String({a:1})
'[object Object]'
String([1,2,3.4,5])
'1,2,3.4,5'

javascript基础三:谈谈 JavaScript 中的类型转换机制
Boolean()
可以将任意类型的值转为布尔值,转换规则如下:
javascript基础三:谈谈 JavaScript 中的类型转换机制
举个粟子:

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

javascript基础三:谈谈 JavaScript 中的类型转换机制
三、隐式转换
在隐式转换中,我们可能最大的疑惑是 :何时发生隐式转换?
我们这里可以归纳为两种情况发生隐式转换的场景:

  • 比较运算(==、!=、>、<)、if、while需要布尔值地方
  • 算术运算(+、-、*、/、%)

除了上面的场景,还要求运算符两边的操作数不是同一类型

自动转换为布尔值
在需要布尔值的地方,就会将非布尔值的参数自动转为布尔值,系统内部会调用Boolean函数
可以得出个小结:

  • undefined
  • null
  • false
  • +0
  • -0
  • NaN
  • “”

除了上面几种会被转化成false,其他都换被转化成true

自动转换成字符串

遇到预期为字符串的地方,就会将非字符串的值自动转为字符串
具体规则是:先将复合类型的值转为原始类型的值,再将原始类型的值转为字符串

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

'66'+1
'661'
'66'+true
'66true'
'66'+false
'66false'
'66'+{}
'66[object Object]'
'66'+[]
'66'
'66'+[5]
'665'
'66'+function(){}
'66function(){}'
'66'+undefined
'66undefined'
'66'+null
'66null'

javascript基础三:谈谈 JavaScript 中的类型转换机制
自动转换成数值
除了+有可能把运算子转为字符串,其他运算符都会把运算子自动转成数值

'6' - '1'
5
'6' * '1'
6
true - 1
0
false - 1
-1
'1' - 1
0
'6' * []
0
false / '6'
0
'abc' - 1
NaN
null + 1
1
undefined + '6'
'undefined6'
undefined + 6
NaN

javascript基础三:谈谈 JavaScript 中的类型转换机制
null转为数值时,值为0 。undefined转为数值时,值为NaN文章来源地址https://www.toymoban.com/news/detail-453833.html

到了这里,关于javascript基础三:谈谈 JavaScript 中的类型转换机制的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JavaScript数据类型检测与数据类型转换详细解析与代码实例

    JavaScript是一种弱类型语言,因此在开发过程中,经常需要进行数据类型检测和数据类型转换。本文将详细介绍JavaScript中的数据类型检测和转换,并提供相关的代码实例。 一、数据类型检测 在JavaScript中,常用的数据类型有:数字、字符串、布尔值、null、undefined、对象和数组

    2024年02月05日
    浏览(51)
  • web前端框架JS学习之JavaScript类型转换

    vascript有多种数据类型,如字符串、数字、布尔等,可以通过typeof语句来查看变量的数据类型。数据类型转换就是数据类型之间相互转换,比如把数字转成字符串、把布尔值转成字符串、把字符串转成数字等,这在工作也是经常碰到的。 本期我们就给大家说说web前端框架JS学

    2024年02月10日
    浏览(64)
  • JavaScript中的垃圾回收机制

    前端入门之旅:探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发者,这里都将为你提供一

    2024年02月07日
    浏览(49)
  • 10分钟的时间,带你彻底搞懂JavaScript数据类型转换

    前言  📫 大家好,我是南木元元,热衷分享有趣实用的文章,希望大家多多支持,一起进步!  🍅  个人主页: 南木元元 目录 JS数据类型 3种转换类型 ToBoolean ToString ToNumber 对象转原始类型 隐式类型转换 结语 JS数据类型 首先我们需要知道,js中数据类型分为两大类: 基本

    2024年02月05日
    浏览(52)
  • javascript中的错误类型

    javascript 中的错误类型: SyntaxError TypeError ReferenceError RangeError URLError Error 语法错误 TypeError 表示类型错误。当您使用不打算以特定方式使用的东西时,就会发生类型错误。例如,用螺丝刀敲钉子,而不是用锤子。 ReferenceError 表示引用错误。当找不到变量的引用、在变量作用域

    2024年02月06日
    浏览(39)
  • JavaScript中的事件冒泡和事件捕获机制

    JavaScript中的事件冒泡和事件捕获机制是开发中非常重要的概念,掌握了这两种机制,可以更好地理解事件处理和DOM操作。本文将深入探讨JavaScript中的事件冒泡和事件捕获机制,包括它们的工作原理、如何使用它们、以及它们的优缺点。 一、什么是事件冒泡和事件捕获机制?

    2024年02月03日
    浏览(43)
  • 2 JavaScript的基础类型

    2 JavaScript的基础类型 JS虽然是一个脚本语言. 麻雀虽小, 五脏俱全. 在js中也是可以像其他编程语言一样. 声明变量, 条件判断, 流程控制等等. 我们先看一下JS中的数据类型 在js中主要有这么几种数据类型(基本)

    2024年02月12日
    浏览(63)
  • JavaScript中的数据类型可以分为两类:原始类型和引用类型。

    JavaScript中的数据类型可以分为两类:原始类型和引用类型。 JavaScript中的原始类型有五种,分别是: 数字(Number):表示数字,包括整数和浮点数。 字符串(String):表示文本字符串。 布尔值(Boolean):表示逻辑上的真或假。 undefined:表示未定义的值。 null:表示空值。

    2024年01月24日
    浏览(47)
  • JavaScript的基础语法和数据类型

    一、什么是JavaScript JavaScript是用于实现 用户交互 、 动态控制文档的外观和内容 ,动态控制浏览器操作、创建cookies等网页行为的跨平台、跨浏览器的由浏览器解释执行的客户端脚本语言 二、JavaScript的三种引入方式 1、引入.js后缀的文件,注意一般外部引入js的文件,放在bod

    2024年02月08日
    浏览(45)
  • JavaScript基础知识09——数据类型

    哈喽,大家好啊,这里是雷工笔记,我是雷工。 数据类型比较常见,无论是对程序员,还是电气工程师来说,都再熟悉不过了,这里跟着教程了解一下,主要看跟自己以往在其他PLC,C#,组态软件中应用的有啥不同。 在计算机的世界就像黑客帝国中的超级计算机,其中的人、

    2024年02月09日
    浏览(58)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包