当前位置: 首页 > news >正文

js中的类型转换

原文地址

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.lryc.cn/news/177174.html

相关文章:

  • Oracle物化视图(Materialized View)
  • Spring 学习(九)整合 Mybatis
  • Android AMS——概述(一)
  • DDoS攻击和CC攻击
  • Lnmp架构之mysql数据库实战2
  • 【软件工程_设计模式Designer Method】三类?23种常用设计模式?-简介-作业一
  • 信号相关的函数
  • matlab实现杨氏双缝干涉实验可视化界面
  • 【SQL】统一训练平台数据库实践--20230927
  • 全国职业技能大赛云计算赛项---Linux系统调优案例
  • Docker部署ZooKeeper分布式协调服务
  • 算法 出现次数超过一半的数字-(哈希+摩尔投票)
  • 如何搭建游戏平台?
  • 【华为OD机试python】数字反转打印【2023 B卷|100分】
  • MATLAB配置编译器(包括vs和mingw)
  • 基本网络协议
  • Tungsten Fabric Rabbitmq故障处理
  • sqlServer 检测慢 sql
  • Mac电脑音视频播放器: Infuse for Mac中文
  • 优化积分商城页面的8个实用技巧
  • Python机器学习实战-特征重要性分析方法(2):内置特征重要性(附源码和实现效果)
  • vue中v-for和v-if同时使用的解决办法
  • 【解决方法】树莓派4B安装wiringpi失败、gpio -v与gpio readall命令not found(arm64架构)
  • oracle 递归
  • SSM - Springboot - MyBatis-Plus 全栈体系(十三)
  • Python|OpenCV-访问并修改图片像素值,鉴别彩色和灰色图像(6)
  • 【Python基础】if __name__ == ‘__main__‘:和assert函数
  • 设计模式——1. 单例模式
  • 操作文档的用户故事怎么写,敏捷开发
  • 14.抽象工厂模式