js中的类型转换

news/2024/7/24 9:33:40 标签: javascript, 前端

原文地址

JavaScript 中有两种类型转换:隐式类型转换(强制类型转换)和显式类型转换。类型转换是将一个数据类型的值转换为另一个数据类型的值的过程。

隐式类型转换(强制类型转换):

隐式类型转换是 JavaScript 自动进行的类型转换,通常发生在操作符运算或比较时,以确保操作的值具有相同的数据类型。以下是一些常见的隐式类型转换的情况:

  • 字符串拼接:当使用 + 运算符将字符串与其他数据类型相加时,其他数据类型会隐式转换为字符串。
var num = 42;
var str = "The answer is: " + num; // 隐式将 num 转换为字符串
  • 数学运算:在数学运算中,JavaScript 会将其他数据类型转换为数字。
var str = "42";
var num = 10;
var result = str - num; // 隐式将 str 转换为数字
  • 比较操作符:在使用比较操作符(例如 =====)时,JavaScript 会进行类型转换以便比较两个值。
var num = 42;
var str = "42";
if (num == str) {
  // 隐式将 str 转换为数字,然后比较
  console.log("相等");
}

显式类型转换:

显式类型转换是通过编写代码来明确告诉 JavaScript 进行类型转换的过程。以下是一些常见的显式类型转换的方法:

  • parseInt() 和 parseFloat():用于将字符串转换为整数或浮点数。
var str = "42";
var num = parseInt(str); // 显式将字符串转换为整数
  • String():将其他数据类型转换为字符串。
var num = 42;
var str = String(num); // 显式将数字转换为字符串
  • Number():将其他数据类型转换为数字。
var str = "42";
var num = Number(str); // 显式将字符串转换为数字
  • Boolean():将其他数据类型转换为布尔值。
var num = 42;
var isTrue = Boolean(num); // 显式将数字转换为布尔值
  • 其他类型转换函数:JavaScript 还提供了其他类型转换函数,如 parseFloat()String.fromCharCode() 等,用于不同的数据类型转换需求。

对于undefined ,null, 0 ,''在各种类型转换中会出什么结果

  1. undefined
  • 隐式类型转换:当将 undefined 与其他数据类型进行隐式类型转换时,它会被转换为 undefinedNaN(如果是数学运算)。

  • 显式类型转换:可以使用 String(undefined) 转换为字符串,或者使用 Number(undefined) 转换为数字,结果都是 NaN图片

  1. null
  • 隐式类型转换:与 undefined 类似,当将 null 与其他数据类型进行隐式类型转换时,它会被转换为 null0(如果是数学运算)。

  • 显式类型转换:可以使用 String(null) 转换为字符串,结果是 "null";使用 Number(null) 转换为数字,结果是 0图片

  1. 0
  • 隐式类型转换:0 在隐式类型转换中通常被视为假值(false),但在数学运算中会保持为 0

  • 显式类型转换:String(0) 转换为字符串 "0"Boolean(0) 转换为 falseNumber(0) 保持为 0图片

  1. 空字符串 ''
  • 隐式类型转换:空字符串在隐式类型转换中通常被视为假值(false),但在某些情况下也可能保持为空字符串。

  • 显式类型转换:String('') 转换为空字符串 ""Boolean('') 转换为 falseNumber('') 转换为 0图片

需要注意的是,在 JavaScript 中,布尔上下文中的假值包括 undefinednull0、空字符串 ''NaNfalse。在条件语句(如 ifwhile)中,它们会被视为假值,其他所有值都被视为真值。这是 JavaScript 中的类型转换规则的一部分。

本文使用 文章同步助手 同步


http://www.niftyadmin.cn/n/5054490.html

相关文章

【lesson12】理解进程地址空间

文章目录 什么是进程地址空间?进程地址空间的作用扩展内容初步理解深入理解 什么是进程地址空间? 故事: 背景:有一个大富豪,家里的存款有10亿美元,他有三个私生子三个人之间彼此互不相识,只有富…

【C语言】指针与动态内存

文章目录 1. 使用动态内存的意义2. 动态内存分配函数2.1 malloc2.2 free2.3 calloc2.4 realloc 3. 动态内存会被自动释放吗?4. 涉及动态内存常见的错误使用4.1 对NULL指针的解引用操作4.2 未对开辟的动态内存空间初始化4.3 越界访问4.4 对非动态开辟内存使用free释放…

Python 发送企业微信通知

通过requests模块对webhook地址发送post请求就能发送通知: import requests def send_weixin(content):url "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?keyxxxxxxxx" # 这里就是群机器人的Webhook地址headers {"Content-Type": &…

WebGL实现透明物体(α混合)

目录 α混合 如何实现α混合 1. 开启混合功能: 2. 指定混合函数 混合函数 gl.blendFunc()函数规范 可以指定给src_factor和dst_factor的常量 混合后颜色的计算公式 加法混合 半透明的三角形(LookAtBlendedTriangl…

【无标题】verilog-hdl-farmat属于FPGA工程师的Verilog实用开发插件

verilog-hdl-farmat README Features 插件:verilog-hdl-farmat 功能 实现verilog代码格式化功能(变量对齐,逗号对齐,括号对齐)。功能触发:按下 ctrlshiftp :输入 verilog。 快捷键 CTRL L;一件例化功能,例化的代…

命令行程序测试自动化

【软件测试面试突击班】如何逼自己一周刷完软件测试八股文教程,刷完面试就稳了,你也可以当高薪软件测试工程师(自动化测试) 这几天有一个小工具需要做测试,是一个命令行工具,这个命令行工具有点类似mdbg等命…

【Linux】 df命令使用

df命令 df 命令,用于显示 Linux 系统中各文件系统的硬盘使用情况,包括文件系统所在硬盘分区的总容量、已使用的容量、剩余容量等 执行命令结果 各列信息的含义分别是: Filesystem:表示该文件系统位于哪个分区,因此该…

MySQL关于日期函数的使用-笔记

韩老师笔记 select current_time select CURRENT_DATE create table mes ( id int, content VARCHAR(255), send_time DATETIME ) select * from mes; insert into mes values(1,北京,CURRENT_DATE) insert into mes (id,send_time) values(2,CURRENT_TIME) insert into mes v…