在JavaScript中,有3个函数可以把非数值转换为数值

1、Number()函数

Number()可以用于任意数据类型。

转换规则如下。

  • 如果是Boolean值,true和false将分别被转换为1和0。
  • 如果是数字值,只是简单的传入和返回。
  • 如果是null值,返回0。
  • 如果是undefined,返回Nan。
  • 如果是字符串,遵循下列规则:如果是对象,则调用对象的valueOf()方法,然后依照前面的规则转换返回的值。如果转换的结果是NaN,则调用对象的toString()方法,然后再依照前面的规则转换返回的字符串值。
    • 如果字符串中只包含数字,则将其转换为十进制数值,即“1”会变成1,而“011”会变成11。
    • 如果字符串中包含有效的浮点格式,如“1.1”,则将其转换为对应的浮点数值。
    • 如果字符串中包含有效的十六进制格式,如“0xf”,则将其转换为相同大小的十进制整数值。
    • 如果字符串是空的,则将其转换为0。
    • 如果字符串中包含除上述格式之外的字符,将其转换为NaN。

看几个例子:

    var num1 = Number("Hello");  //NaN
var num2 = Number(""); //
var num3 = Number("0011"); //
var num4 = Number(true); //
var num5 = Number(1.1); //1.1

注:一元加操作符的操作与Number()函数相同。

由于Number()函数在转换字符串时比较复杂而且不够合理,因此在处理整数时更常用的是parseInt()函数。

2、parseInt()函数

parseInt()函数在转换字符串时,会忽略字符串前面的空格,直到找到第一个非空格字符。

如果第一个字符不是数字或者负号,parseInt() 就会返回NaN,同样的,用parseInt() 转换空字符串也会返回NaN(而Number()对空字符返回0)。

如果第一个字符是数字字符,parseInt() 会继续解析第二个字符,直到解析完所有后续字符串或者遇到了一个非数字字符。

例如,“1234blue”会被转换成1234,因为“blue”会被完全忽略。如果字符串中第一个字符是数字字符,parseInt()也能够识别各种整数格式(八进制、十进制、十六进制)。也就是说,如果字符串以“0x”开头且后面跟数字字符,就会将其当做一个十六进制整数;

如果字符串以“0”开头且后面跟数字字符,就会将其当做一个八进制数来解析;

看几个例子:

    var num1 = parseInt("1234blue");    //
var num2 = parseInt(""); //NaN
var num3 = parseInt("0xA"); //
var num4 = parseInt("22.5"); //
var num5 = parseInt("070"); //未定,70或者56
var num6 = parseInt("70"); //
var num7 = parseInt("0xf"); //

在ECMAScript3 JavaScript引擎中,“070”被当成八进制字面量,因此转换后是十进制56。而在ECMAScript5 JavaScript引擎中,parseInt()已经不具有解析八进制的能力,因此前导的零会被认为无效,从而将这个值当成“0”,结果就得到十进制的0。为了消除在使用parseInt()函数时可能导致上述的困惑,可以为这个函数提供第二个参数:转换时使用的基数(即多少进制)。

看几个例子:

  var num1 = parseInt("AF", 16);          //
var num2 = parseInt("AF");            //NaN
var num3 = parseInt("10", 2);           //2  (按照二进制解析)
var num4 = parseInt("10", 8);           //8  (按照八进制解析)
var num5 = parseInt("10", 10);          //10  (按照十进制解析)
var num6 = parseInt("10", 16);          //16  (按照十六进制解析)

注:多数情况下,我们要解析的都是十进制数值,因此将10作为第二个参数是非常有必要的。

3、parseFloat()函数

与parseInt() 函数类似,parseFloat() 也是从第一个字符(位置0)开始解析每个字符。而且也是一直解析到字符串末尾,或者解析到遇见一个无效的浮点数字字符为止。也就是说,字符串中第一个小数点是有效的,而第二个小数点就是无效的了,它后面的字符串将被忽略。例如,“22.3.34”将会被转换为22.3。

除了第一个小数点有效之外,parseFloat()parseInt()的第二个区别在于它始终忽略前导0。parseFloat()可以识别所有浮点数值格式,也包括十进制整数格式。但十六进制的字符串则始终被转换为0。

由于parseFloat()只解析十进制,因此它没有第二个参数指定基数的用法

如果字符串中包含的是一个可解析为整数的数(没有小数点,或者小数点后都是零),parseFloat() 会返回整数。

看几个例子:

        var num1 = parseFloat("1234blue");    //
var num2 = parseFloat(""); //NaN
var num3 = parseFloat("0xA"); //
var num4 = parseFloat("22.5"); //
var num5 = parseFloat("22.34.5"); //22.34
var num6 = parseFloat("09.5"); //9.5
var num7 = parseFloat("3.125e7"); //

JavaScript中的数值转换的更多相关文章

  1. 【前端】深入浅出Javascript中的数值转换

    由于Javascript是一门弱类型的语言,在我们的代码中无时无刻不在发生着类型转换,所以了解Javascript中的类型转换对于了解我们认识Javascript的运行原理至关重要. 本文主要从数值转 ...

  2. JavaScript之parseInt()数值转换常被忽略的问题

    使用parseInt()你可以从字符串中获取数值,该方法接受另一个基数参数,这经常省略,但不应该.当字符串以”0″开头的时候就有可能会出问题,例如,部分时间进入表单域,在ECMAScript 3中,开 ...

  3. javascript 数据类型之数值转换

    数值转换 一.有3个函数可以把非数值转换为数值: Number() parse Int() parse Float() 说明: 1.Number()可以用于任何数据类型,强转类型,如果不能把指转成数值 ...

  4. javaScript中eval()方法转换json对象

    <script language="javascript"> var user = '{name:"张三",age:23,'+ 'address:{ ...

  5. python与JavaScript中正则表达式如何转换

    使用python爬取网站数据的时候,总会遇到各种各样的反爬虫策略,有很大一部分都和JavaScript(以下简称为JS) 有关.在破解这些JS代码的过程中,经常会遇到模拟JS正则表达式的情况,因此,今 ...

  6. javascript 中关于对象转换数字值的一些特点

    下面是摘至<Javascript 高级程序设计第三版>里的一段话 是关于对象转换数字值的一些规则 "在应用于对象时,先调用对象的valueOf()方法以取得一个可供操作的值.然后 ...

  7. js中的数值转换

    js中有3个函数可以把非数值转换为数值:Number().parseInt().parseFloat().其中Number()可以用于任何数据类型.parseInt()及parseFloat()用于将 ...

  8. Javascript数值转换(string,int,json)

    数值: 在JavaScript中,数值转换一般有三种方式: 一.Number(param)函数:param可以用于任何数据类型 1.1 param是Boolean值,true和false分别转换为1和 ...

  9. JavaScript数值转换总结

    在JavaScript中,数值转换一般有三种方式: 一.Number(param)函数:param可以用于任何数据类型 1.1  param是Boolean值,true和false分别转换为1和0: ...

随机推荐

  1. 201521123086《java程序设计》第四周

    本章学习总结 尝试使用思维导图总结有关继承的知识点 1.2 使用常规方法总结其他上课内容. 为了不必要写重复的代码,可以运用继承,用关键字extends来定义一个类,被继承的类叫做父类,继承的类叫做子 ...

  2. 201521123017 《Java程序设计》第13周学习总结

    1. 本周学习总结 2. 书面作业 Q1.网络基础 1.1 比较ping www.baidu.com与ping cec.jmu.edu.cn,分析返回结果有何不同?为什么会有这样的不同? 1.2 te ...

  3. JAVA课程设计 计算器模拟程序 王华俊(201521123015)

    1.团队课程设计博客链接 http://www.cnblogs.com/yuanj/p/7072137.html 2.个人负责模块或任务说明 GUI界面设计 各类之间拼接 3.自己的代码提交记录截图 ...

  4. latch session allocation

    应用反馈上午10点左右出现大量应用连接数据库报错 采集9点-10点和10点-11点的AWR报告进行分析 DB时间明显差异,再继续分析等待事件 可以看出有session相关的Latch等待事件,查看相关 ...

  5. postman: 用于网页调试和发送Http请求的chrome插件

    一 简介 Postman 是一款功能超级强大的用于发送 HTTP 请求的 Chrome插件 .做web页面开发和测试的人员应该是无人不晓无人不用!其主要特点 特点: 创建 + 测试:创建和发送任何的H ...

  6. Python可视化----------matplotlib.pylot

    1 >>> import matplotlib.pyplot as plt 2 >>> plt.axis([0,5,0,20]) 3 [0, 5, 0, 20] 4 ...

  7. 使用Spring的隐式注解和装配以及使用SpringTest框架

    SpringTestConfiguration 1.加入jar 包spring-test-4.3.9.RELEASE.jar 2.写基本的Component 注意级联状态下  需要给需要调用的属性加入 ...

  8. (转)Unity3D中移动物体位置的几种方法

    1. 简介 在unity3d中,有多种方式可以改变物体的坐标,实现移动的目的,其本质是每帧修改物体的position. 2. 通过Transform组件移动物体 Transform 组件用于描述物体在 ...

  9. 使用JavaScript实现ATM取款机

    ATM机需求描述如下: 假设一个简单的ATM机的取款过程为:  首先提示用户输入密码(password),假设默认密码为111111,最多只能输入3次,  超过3次则提示用户"密码错误,请取 ...

  10. [解读REST] 4.基于网络应用的架构风格

    上篇文章介绍了一组自洽的术语来描述和解释软件架构:如何利用架构属性评估一个架构风格:以及对于基于网络的应用架构来说,那些架构属性是值得我们重点关注评估的.本篇在以上的基础上,列举一下一些常见的(RES ...