javascript怎么将值转换为数字类型

转换为数字类型的方法:1、使用parseInt()函数,可以把值转换为整数,语法“parseInt(值)”;2、使用parseFloat()函数,可以把值转换为浮点数,语法“parseFloat(值)”;3、利用乘号运算符,语法“值*1”。

本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

javascript将值转换为数字类型的方法

方法1:使用 parseInt()函数

parseInt() 是一个全局方法,它可以把值转换为整数。转换的过程如下:

  • 先解析位置 0 处的字符,如果不是有效数字,则直接返回 NaN。

  • 如果位置 0 处的字符是数字,或者可以转换为有效数字,则继续解析位置 1 处的字符,如果不是有效数字,则直接返回位置 0 处的有效数字。

  • 以此类推,按照从左到右的顺序,逐个分析每个字符,直到发现非数字字符为止。

  • parseInt() 将把前面分析合法的数字字符全部转换为数值并返回。

console.log(parseInt(123abc));  //返回数字123
console.log(parseInt(1.73));   //返回数字1
console.log(parseInt(.123));   //返回值NaN

浮点数中的点对于 parseInt() 来说属于非法字符,因此不会转换小数部分的值。

如果是以 0 开头的数字字符串,则 parseInt() 会把它作为八进制数字处理:先把它转换为八进制数值,然后再转换为十进制的数字返回。

如果是以 0x 开头的数字字符串,则 parseInt() 会把它作为十六进制数字处理:先把它转换为十六进制数值,然后再转换为十进制的数字返回。

var d = 010;  //八进制数字字符串
var e = 0x10;  //十六进制数字字符串
console.log(parseInt(d));  //返回十进制数字8
console.log(parseInt(e));  //返回十进制数字16

parseInt() 也支持基模式,可以把二进制、八进制、十六进制等不同进制的数字字符串转换为整数。基模式由 parseInt() 函数的第二个参数指定。

示例

下面代码把二进制、八进制和十进制数字字符串转换为十进制的整数。

console.log(parseInt(10,2));  //把二进制数字 10 转换为十进制整数,为 2
console.log(parseInt(10,8));  //把八进制数字 10 转换为十进制整数,为 8
console.log(parseInt(10,10));  //把十进制数字 10 转换为十进制整数,为 10

方法2:使用 parseFloat() 函数

parseFloat() 也是一个全局方法,它可以把值转换为浮点数,即它能够识别第一个出现的小数点,而第二个小数点被视为非法。解析过程与 parseInt() 方法相同。

console.log(parseFloat(1.234.5));  //返回数值 1.234

parseFloat() 的参数必须是十进制形式的字符串,而不能使用八进制或十六进制的数字字符串。同时,对于数字前面的 0(八进制数字标识)会忽略,对于十六进制的数字将返回 0。

console.log(parseFloat(123));  //返回数值 123
console.log(parseFloat(123abc));  //返回数值 123
console.log(parseFloat(010));  //返回数值 10
console.log(parseFloat(0x10));  //返回数值 0
console.log(parseFloat(x10));  //返回数值 NaN

方法3:使用乘号运算符

如果变量乘以 1,则变量会被 JavaScript 自动转换为数值。乘以 1 之后,结果没有发生变化,但是值的类型被转换为数值。如果值无法被缓缓为合法的数值,则返回 NaN。

var a = 1;  //数值
var b = 1;  //数字字符串
console.log(a + (b * 1));  //返回数值 2

【相关推荐:javascript学习教程

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...