js中强制类型转换Number、parseInt、parseFloat、Boolean、String、toString的使用
文章目录
- 一、Number() 转换为整数
- 二、Number.parseInt() 将字符串转换为整数
- 三、Number.parseFloat() 将字符串转换为浮点数
- 四、Boolean() 转换为布尔值
- 五、String() 转换为字符串
- 六、.toString() 转换为字符串
最近在巩固 js 的基础知识,今天复习到了 js 中的数据类型转换知识点,然后整理一下。
之前整理了一篇隐式类型转换文章:js中的隐式类型转换有哪些
一、Number() 转换为整数
转换规则:
- 数字:返回自身;
- 布尔值:true返回1,false返回0;
- undefined:返回NaN;
- null:返回0;
- 字符串:
- 只包含数字,则将其转化为十进制;
- 包含有效的浮点格式,将其转换为浮点数值;
- 忽略前导和尾随空格/行终止符;
+
和-
允许在字符串的开头指示其符号;- 空字符串
''
或仅空格字符串转换为 0; - 如果不是以上格式的字符串,返回NaN。
- Symbol:抛出TypeError;
- BigInt:返回它的 Number 值,并且可能损失精度;
- 对象:首先按顺序调用 Symbol.toPrimitive方法(将 “number” 作为 hint)、valueOf() 和 toString() 方法将其转换为原始值。然后将生成的原始值转换为数值。
一元运算符:+
完全按照上面的数值强制转换规则来转换。
例如:
+true; // 1
+false; // 0
+''; // 0
+'0123'; // 123
example:
Number(true); // 1
Number(false); // 0
Number('011'); // 11
Number('011abc'); // NaN
Number('3.141500'); // 3.1415
Number('3.141500abc'); // NaN
Number(undefined); // NaN
Number(null); // 0
Number(''); // 0
Number(' '); // 0
Number(-0x11); // -17
Number('0x11'); // 17
Number(Symbol()); // Uncaught TypeError: Cannot convert a Symbol value to a number
Number({}); // NaN
Number([]); // 0
二、Number.parseInt() 将字符串转换为整数
Number.parseInt() 方法依据指定基数,解析字符串并返回一个整数。
语法:
Number.parseInt(string)
Number.parseInt(string, radix)
radix:进制,基数
转换规则:
- 被解析的值必须是 string 类型,若不是,将其强制转换为 string 类型,然后再转换为整数;
- 字符串开头的空白字符会被忽略;
- 第一个非空白字符不能转换为数字,则返回NaN;
- 如果存在 radix 参数,则取值为
[2, 36]
之间的整数,否则返回NaN; - 如果 radix 参数未指定或者为0,按10进制进行转换;
- 如果 radix 参数未指定或者为0,且数字以 0x 或 0X 开头,按16进制转换。
这个方法和全局的 parseInt() 函数具有一样的函数功能:
Number.parseInt === parseInt; // true
Number 添加此方法,其目的是对全局变量进行模块化。
example:
Number.parseInt(true); // NaN
Number.parseInt(false); // NaN
Number.parseInt(undefined); // NaN
Number.parseInt(null); // NaN
Number.parseInt(''); // NaN
Number.parseInt(' 3 '); // 3
Number.parseInt('3.141590ab '); // 3
Number.parseInt(' d3.14159'); // NaN
Number.parseInt(-0x11); // -17
Number.parseInt('0x11'); // 17
Number.parseInt('0x11', 0); // 17
Number.parseInt('0x11', 1); // NaN
Number.parseInt('0x11', 2); // 0
Number.parseInt('0x11', 16); // 17
Number.parseInt('0x11', 37); // NaN
Number.parseInt('123', 0); // 123
Number.parseInt('123', 8); // 83
Number.parseInt('123', 37); // NaN
Number.parseInt({}); // NaN
Number.parseInt([]); // NaN
Number.parseInt(Symbol()); // Uncaught TypeError: Cannot convert a Symbol value to a string
Number.parseInt(900719925474099267n); // 900719925474099300 丢失精度
Number.parseInt('900719925474099267n'); // 900719925474099300 丢失精度
三、Number.parseFloat() 将字符串转换为浮点数
Number.parseFloat() 方法可以把一个字符串解析成浮点数。
语法:
Number.parseFloat(string)
转换规则:
- 如果 parseFloat 在解析过程中遇到了正号(+)、负号(- U+002D HYPHEN-MINUS)、数字(0-9)、小数点(.)、或者科学记数法中的指数(e 或 E)以外的字符,则它会忽略该字符以及之后的所有字符,返回当前已经解析到的浮点数;
- 第二个小数点的出现也会使解析停止(在这之前的字符都会被解析);
- 参数首位和末位的空白符会被忽略;
- 如果参数字符串的第一个字符不能被解析成为数字,则返回NaN;
- parseFloat 也可以解析并返回 Infinity。
- parseFloat 解析 BigInt 为 Numbers, 丢失精度。因为末位 n 字符被丢弃。
- parseFloat 也可以转换一个已经定义了 toString 或者 valueOf 方法的对象,它返回的值和在调用该方法的结果上调用 parseFloat 值相同。
这个方法和全局的 parseFloat() 函数具有一样的函数功能:
Number.parseFloat === parseFloat; // true
Number 添加此方法,其目的是对全局变量进行模块化。
example:
Number.parseFloat(3.14); // 3.14
Number.parseFloat('3.14'); // 3.14
Number.parseFloat(' 3.14 '); // 3.14
Number.parseFloat('314e-2'); // 3.14
Number.parseFloat('0.0314E+2'); // 3.14
Number.parseFloat('3.14some non-digit characters'); // 3.14
Number.parseFloat({ toString: function() { return "3.14" } }); // 3.14
Number.parseFloat({ valueOf : function() { return "3.14" } }); // NaN
Number.parseFloat("asc3.14"); // NaN
Number.parseFloat(900719925474099267n); // 900719925474099300 丢失精度
Number.parseFloat('900719925474099267n'); // 900719925474099300 丢失精度
四、Boolean() 转换为布尔值
Boolean 对象是一个布尔值的对象包装器。
转换规则:
- Boolean() 初始值为 false ;
- 参数值为 0、-0、null、false、NaN、undefined,或空字符串(
""
),转换为 false。 - 所有其它值,包括任何对象,空数组([])或字符串
"false"
,都会创建一个初始值为 true 的对象。
另一种使用方式是 双重非(!!)运算符,与 Boolean() 规则一致。
example:
Boolean(); // false
Boolean(0); // false
Boolean('0'); // true
Boolean(-0); // false
Boolean(null); // false
Boolean(false); // false
Boolean('false'); // true
Boolean(NaN); // false
Boolean(undefined); // false
Boolean(''); // false
Boolean(123); // true
Boolean('123'); // true
Boolean(' '); // true
Boolean({}); // true
Boolean([]); // true
注意:
Boolean 对象的值与基本数据类型中的 true 和 false 不同。
const bool = new Boolean(false);
if (bool) {// 代码被执行了
}
console.log(bool); // Boolean {false}
console.log(!!bool); // true
上面使用 Boolean 构造函数生成了一个 bool 实例对象,虽然 Boolean 的初始值为 false ,但实例对象 bool 的值为 true;所以if 语句会被执行。使用基本数据类型就不会有上面的情况:
const bool = false;
if (bool) {// 代码不被执行
}
五、String() 转换为字符串
String 对象用于表示和操作字符序列。
转换规则:
- 字符串按原样返回;
- true、false、null、undefined 都可以转换成字符串;
- 使用与 toString(10) 相同的算法转换数字,默认转换为十进制;
- 使用与 toString(10) 相同的算法转换 BigInt;
- Symbol 隐式转换会抛出 TypeError,显示转换则为字符串;
- 对象:通过次序调用 Symbol.toPrimitive方法(将 “number” 作为 hint)、toString() 和 valueOf() 方法将其转换为原始值。然后将生成的原始值转换为数值。
example:
String('like'); // 'like'
String(true); // 'true'
String(false); // 'false'
String(null); // 'null'
String(undefined); // 'undefined'
String(10); // '10'
String(900719925474099267n); // '900719925474099267'
String(Symbol()); // 'Symbol()'
Symbol('foo') + 'bar'; // Uncaught TypeError: Cannot convert a Symbol value to a string 隐式类型转换报错
String({}); // '[object Object]'
String([]); // ''
六、.toString() 转换为字符串
大多数 JavaScript 对象和原始值都有一个 toString() 方法将值转换为字符串,例如:字符串、数字、布尔、BigInts 和符号;除了 null 和 undefined。
对象的 toString() 方法返回的是当前数据类型的字符串,如,将一个对象转换为字符串,格式为 '[object Object]'
,将数组转换为字符串,格式为'[object Array]'
;首字母小写object为固定格式,首字母大写Object为数据类型。
有时候,为了准确判断数据类型,会使用Object.prototype.toString.call()
来进行转换判断。
Object.prototype.toString.call([]); // '[object Array]'
Object.prototype.toString.call('123'); // '[object String]'
Object.prototype.toString.call(true); // '[object Boolean]'
Object.prototype.toString.call(function(){}); // '[object Function]'
Object.prototype.toString.call(null); // '[object Null]'
Object.prototype.toString.call(undefined); // '[object Undefined]'
Object.prototype.toString.call(Symbol()); // '[object Symbol]'
...
转换规则:
- 除null、undefined外,其他基本数据类型按照正常规则转换;
- 不能转换null、undefined,报错 TypeError,因为没有 toString 方法;
- 对象:转换为
'[object Type]'
格式; - 数组:与使用
join()
方法相同,转换为元素拼接成的字符串;空数组转换为空字符串''
。
当调用Number.prototype.toString()时,语法:
numObj.toString([radix])
radix 指定要用于数字到字符串的转换的基数 [2, 36]。如果未指定 radix 参数,则默认值为 10(十进制)。
let num = 100;
num.toString(); // '100' 默认按照10进制转换
num.toString(2); // '1100100'
num.toString(8); // '144'
num.toString(10); // '100'
num.toString(16); // '64'
Number.prototype.toString() 与 Number.parseInt() 可以在字符串与数字值之间按照不同进制相互转换。
如,将上面的字符串按照不同进制转换为数字:
Number.parseInt('100'); // 100
Number.parseInt('1100100',2); // 100
Number.parseInt('144',8); // 100
Number.parseInt('100',10); // 100
Number.parseInt('64',16); // 100
example:
[].toString(); // ''
({}).toString(); // '[object Object]'
(123).toString(); // '123'
(true).toString(); // 'true'
(false).toString(); // 'false'
(null).toString(); // Uncaught TypeError: Cannot read properties of null (reading 'toString')
(undefined).toString(); // Uncaught TypeError: Cannot read properties of undefined (reading 'toString')
Symbol().toString(); // 'Symbol()'
(900719925474099267n).toString(); // '900719925474099267'
相关文章:

js中强制类型转换Number、parseInt、parseFloat、Boolean、String、toString的使用
文章目录一、Number() 转换为整数二、Number.parseInt() 将字符串转换为整数三、Number.parseFloat() 将字符串转换为浮点数四、Boolean() 转换为布尔值五、String() 转换为字符串六、.toString() 转换为字符串最近在巩固 js 的基础知识,今天复习到了 js 中的数据类…...

漏斗分析法
一什么是漏斗分析? 漏斗分析是数据领域最常见的一种“程式化”数据分析方法,它能够科学地评估一种业务过程,从起点到终点,各个阶段的转化情况。通过可以量化的数据分析,帮助业务找到有问题的业务环节,并进…...

pycharm入门快捷操作(部分)
altenter:提示意图动作shift两次或者crtlshifta:查找框(查找动作、类、项目等)crtlw:一次一个字符、两次整个字符串(if条件下选择整个判断体)、三次整个句子、四次整个引用ctrlshiftw࿱…...

宣布 Databricks 支持 Amazon Graviton2,性价比提高3倍
今天,我们很高兴地宣布 Databricks 对基于 Amazon Graviton2 的亚马逊弹性计算云(Amazon EC2)实例的支持的公开预览。Graviton 处理器由亚马逊云科技进行定制设计和优化,为运行在 Amazon EC2 上的云工作负载提供最佳性价比。当与高…...

18_FreeRTOS任务通知
目录 任务通知的简介 任务通知值的更新方式 任务通知的优势 任务通知的劣势 任务通知值和通知状态 发送通知相关API函数 接收通知相关API函数 任务通知模拟信号量实验 任务通知模拟消息邮箱实验 任务通知模拟事件标志组实验 任务通知的简介 任务通知:用来通知任务的…...

【华为OD机试模拟题】用 C++ 实现 - 整理扑克牌(2023.Q1)
最近更新的博客 华为OD机试 - 入栈出栈(C++) | 附带编码思路 【2023】 华为OD机试 - 箱子之形摆放(C++) | 附带编码思路 【2023】 华为OD机试 - 简易内存池 2(C++) | 附带编码思路 【2023】 华为OD机试 - 第 N 个排列(C++) | 附带编码思路 【2023】 华为OD机试 - 考古…...

mysql lesson1
常用命令 1:exit 退出mysql 2:uroot pENTER键,再输入密码,不被别人看见 3:完美卸载:双击安装包,手动删除program file中的mysql,手动删除Programedate里的mysql 4:use mysql 使用数据库 5:…...

联想笔记本无法下载 Lenovo Vantage
状况 在 Microsoft Store 下载时发生错误,可能是如下代码:0x80070005, 0x80073D05, or 0x80070017. 解决方法 1.在“开始”菜单搜索栏中输入PowerShell 2.当Windows PowerShell出现在“开始”菜单中,右键点击此图标,然后选择以…...

功能性材料深入超级赛道,赋能多行业迭代升级
中国国际胶粘剂及密封剂展览会深耕胶粘剂、密封剂和胶粘带行业26年,是行业认可的、优质的贸易与技术交流平台。展会连接了十几个行业的买家和卖家,包括汽车、电子、新能源、轨道交通、工业等重要领域,为客户提供封装、粘合、散热、装配制造等…...

【项目精选】jsp企业快信系统(论文+视频+源码)
点击下载源码 计算机网络的出现到现在已经经历了翻天覆地的重大改变。因特网也从最早的供科学家交流心得的简单的文本浏览器发展成为了商务和信息的中心。到了今天,互联网已经成为了大量应用的首选平台,人们已经渐渐习惯了网络交易,渐渐对网络…...

通信算法之112:载波同步及comm.CarrierSynchronizer
1. 2. 载波同步是基于锁相环技术使本地获取和载波同频同相的参考信号,用来解调信号。载波同步就是对本地参考信号进行频率和相位偏差的补偿,进而实现本地参考信号和载波信号同频同相。 载波同步只适用于单载波调制系统,载波同步算法对于BPSK、…...

【C. Build Permutation】(整数理论、构造、思维)
链接 理论基础 结论:在区间[n,2n]上,至少存在一个完全平方数。结论:在区间[n,2n]上,至少存在一个完全平方数。结论:在区间[n,2n]上,至少存在一个完全平方数。 构造⌈n⌉2构造\lceil \sqrt{n}\rceil^2构造⌈…...

前端面试题:事件循环(Eventloop)
什么是事件循环?如何理解事件循环?事件循环原理如何描述?事件循环涉及了很多知识点,想要彻底掌握JS事件循环原理必须要掌握以下知识点:同步任务、异步任务、宏任务、微任务、任务队列、执行栈、js运行机制、EventLoop。 1.事件循…...

jmeter接口自动化测试框架
接口测试可以分为两部分: 一是线上接口(生产环境)自动化测试,需要自动定时执行,每5分钟自动执行一次,相当于每5分钟就检查一遍线上的接口是否正常,有异常能够及时发现,不至于影响用…...

树莓派CM4基础设置
安装系统1.1 软件和硬件准备硬件:CM4(4GB DDR32GB EMMC 板载WIFI和蓝牙)CM4-to-Pi4-Adapter软件:Raspberry Pi或者 Win32DiskImagerRaspberry Pi下载链接:点击直接下载Win32DiskImager下载链接:链接&#x…...

JS 合并数组的三大方式
1. 数组的不可变合并 1.1使用扩展运算符进行合并 如果您想知道一种在JavaScript中合并数组的好方法,那么请记住使用扩展操作符进行合并。 在数组字面量中写入两个或更多带有扩展操作符…前缀的数组,JavaScript将创建一个合并所有这些数组的新数组: co…...

30岁测试开发年薪不足50万,被面试官嘲讽混得太差?
近日,有网友发帖称:“30岁去应聘测试开发,拿不到七八十万的年薪确实有点丢人了,还被面试官diss混得太差了”,网友们看完都炸了。 来看看网友们都是怎么说的。 有网友说: 扯淡 有网友气到: 那拿…...

【C语言】多线程
多线程线程线程的优点C语言多线程创建线程终止线程连接和分离线程开启一个线程最基本的多线程实现开启两个线程多线程进行协同运算无参数传递的线程并发编程实例简单参数传递的线程并发编程实例结构体参数传递的线程并发编程实例线程的连接编程实例信号量同步进行写入互斥信号量…...

CDGA|浅谈“以治促用,以用促治”的数据治理战略
数据治理夯实企业数字化转型基础。采取“以治促用,以用促治”的数据治理战略,可以充分释放了企业核心运行要素的活力。 “以治促用”是指通过建立在数据治理链路及用户多维评估系统的基础上,对数据资产重新进行价值识别,推进高价值…...

Apifox-比postman更优秀的接口自动化测试平台
一、Apifox介绍 Apifox 是 API 文档、API 调试、API Mock、API 自动化测试一体化协作平台,定位 Postman Swagger Mock JMeter。通过一套系统、一份数据,解决多个系统之间的数据同步问题。只要定义好 API 文档,API 调试、API 数据 Mock、A…...

周期矩形波的傅里叶级数展开(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

前端预防XSS攻击全攻略
如何防止XSS攻击 一、是撒子 XSS攻击(跨站点脚本攻击),就是黑客恶意篡改你网页的前端代码,在里面注入一些恶意的 htmljavascript的脚本,并在你的浏览器内运行,获取你的信息,或者进行一些恶意操…...

JUC(一)
1.AQS原理 1.1.概述 1>.AQS全称是 AbstractQueuedSynchronizer,是阻塞式锁和相关的同步器工具的框架; 2>.特点: ①.用state属性来表示资源的状态(分独占模式和共享模式),子类需要定义如何维护这个状态,控制如何获取锁和释放锁; getState: 获取state状态;setStata: 设置…...

API接口——睡眠带开放能力
本文介绍睡眠带相关接口。 API 列表 请求方法API描述GET/v1.0/devices/{device_id}/sleep/daily-reports获取日睡眠报告。GET/v1.0/devices/{device_id}/sleep/monthly-reports获取月睡眠报告。GET/v1.0/devices/{device_id}/sleep/24h-reports获取 24 小时睡眠报告。GET/v1.…...

面向对象的一点小想法
接口里的方法可以写也可以不写 如果写的话,那么得是默认方法,需要在前面加个default 对于默认方法,能够重写,或者直接继承(也就是直接用) 比如下面: 就直接调用了接口的默认函数nibuhao&#…...

数据仓库工作问题总结
1. ODS 层采用什么压缩方式和存储格式? 压缩采用 Snappy ,存储采用 orc ,压缩比是 100g 数据压缩完 10g 左右。 2. DWD 层做了哪些事? 1.、数据清洗 空值去除过滤核心字段无意义的数据,比如订单表中订单 id 为 nul…...

Java常用算法
关于时间复杂度: 平方阶 (O(n2)) 排序 各类简单排序:直接插入、直接选择和冒泡排序。线性对数阶 (O(nlog2n)) 排序 快速排序、堆排序和归并排序。O(n1)) 排序, 是介于 0 和 1 之间的常数。希尔排序。线性阶 (O(n)) 排序 基数排序,…...

插画网课平台排名
插画网课平台哪个好,插画网课排名靠前的有哪些,今天给大家梳理了国内5家专业的插画网课平台,各有优势和特色,给学插画的小伙伴提供选择,报插画网课一定要选择靠谱的,否则人钱两空泪两行! 一&am…...

雷达、定位、跟踪等信号处理邻域SCI期刊整理及推荐
雷达邻域SCI期刊整理及推荐:题名、刊物信息、撰写特点、审稿周期及投稿难度总结 定位/跟踪邻域SCI期刊整理及推荐:题名、刊物信息、撰写特点、审稿周期及投稿难度总结 估计/滤波/融合等信号处理邻域SCI期刊整理及推荐:题名、刊物信息、撰写…...

NDK C++ 指针常量 常量指针 常量指针常量
指针常量 常量指针 常量指针常量// 指针常量 常量指针 常量指针常量#include <iostream> #include <string.h> #include <string.h>using namespace std;int main() {// *strcpy (char *__restrict, const char *__restrict);// strcpy()int number 9;int n…...