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

本文主要从数值转换这一维度来剖析在JS中,数值转换会遵循什么样的规则,有哪些用途?

哪些情况下我们会用到js中的数值转换?

  1. 在传统的js中,对元素进行变换、位移、改变大小时,我们经常需要对长度单位进行计算操作;
  2. 当我们提供了一个通用add函数,此时需要对传入参数的类型进行限制,不能是非数字格式;
  3. 更多场景请关注知乎问答:JavaScript中 Number()函数在哪些场景中用到?

Javascript中存在哪些数值转换方式?

我们都知道js中存在显式类型转换和隐式类型转换,其中显式类型转换包含:

  • Number()
  • parseInt()
  • parseFloat()
  • 一元加和减操作符

隐式类型在js中的体现比较复杂,这里简单罗列以下几种情况:

  • 位运算符在操作非数值时,会使用Number()来对变量进行转换,然后进行计算;
  • 乘/除/减法操作符;
  • 关系操作符(<,>,<=,>=);
  • 相等操作符其中一个变量为数值时,会把另一个变量转换为数值进行比较。

由于js的弱类型特性,隐式类型转换其实是相对而言的,如果你了解了一段代码的类型转换方式,那么它对于你而言,就可以被视为显式转换。

由于Javascript中的隐式类型转换基本都是通过调用Number函数的方式进行的,所以这篇文章主要讨论不同显式类型转换的区别。在讨论之前,我们先看一段代码示例:

 var a = '+3.14159test';

 var num1 = Number(a);         // NaN
var num2 = parseInt(a, 10);     // 3
var num3 = parseFloat(a);      // 3.14159
var num4 = +a             // NaN
var num5 = -a             // NaN

Number函数

特点

Number()可以用于转换任何类型。

ECMA规范关于Number转换的规则描述:

https://tc39.github.io/ecma262/#sec-number-objects

转换规则

  • 如果参数是Boolean,则如果为true,返回1;false返回0;
  • 如果数字类型,直接返回;
  • null返回0,undefined返回NaN;
  • 如果是对象,则首先调用valueOf方法,如果返回值能转换为数值,则返回;否则调用toString方法,然后将返回值按照其他类型规则转换后的内容返回;
  • 如果是字符串
    • 如果只包含数字类型,则返回该数字类型的十进制格式;如果前边有-号,则返回负数;
    • 空字符串返回0;
    • 十六进制字符串返回十进制数字;如果前边有-号,返回NaN;
    • 如果非数字,返回NaN;
 var num1 = Number(true);          //
var num2 = Number(false);      //
var num3 = Number(12);       //
var num4 = Number();         //
var num5 = Number(null);       //
var num6 = Number(undefined);    // NaN
var num7 = Number('012');      //
var num8 = Number('-012');      // -12
var num9 = Number(' 0x12');      //
var num10 = Number('-0x12');    // NaN
var num11 = Number('12test'); // NaN
var num12 = Number(          //
  {
    valueOf: function (){
      return '012'
    },
toString: function () {
      return '012test'
    }
  }
)

parseInt函数

特点

仅用于转换字符串类型,首先会忽略字符串前面的空格。如果字符串一开始是数字或者加减号后边跟数字,则返回该字符串一直到非数字截止。

ECMA规范关于parseInt转换的规则描述

https://tc39.github.io/ecma262/#sec-parseint-string-radix

转换规则

  • 如果第一个参数非字符串或数字类型,则返回NaN;
  • 第一个参数格式正常,第二个参数不传值
    • 如参数一开始的非空格字符不是非数字且非加减号,则返回NaN
    • 如参数一以0x开头,则以十六进制来解析字符串,并返回该字符串的十进制格式;
    • 如参数一以0开头,则在es3标准中按照八进制来解析,es5标准中按照十进制来解析,最终返回十进制格式;(很重要,不了解会导致一些低版本浏览器莫名其妙的问题)
  • 第二个参数传值,首先会将参数二进行Number()转换
    • 如参数二能转换成一个非0数字,则将参数一按照对应进制进行转换
    • 如参数二不能转换成一个非0数字,则按照参数二为空进行处理
 var num1 = parseInt('  0xf');                // 15   同parseInt('  +0xf')
var num2 = parseInt(' -0xf'); // -15
var num3 = parseInt(' 12test'); // 12
var num4 = parseInt('f'); // NaN
var num5 = parseInt('f', 16); //
var num6 = parseInt('015', 8); //
var num7 = parseInt('15.34'); //
var num8 = parseInt('f', '0x10');      //

parseFloat函数

特点

与parseInt类似,但只能接收一个参数,传入字符串只会按照10进制进行解析,会将传入的字符串解析成Double类型数字。

ECMA规范关于parseInt转换的规则描述

https://tc39.github.io/ecma262/#sec-parsefloat-string

转换规则

  • 如果第一个参数非字符串或数字类型或点字符,则返回NaN;
 var num1 = parseFloat('  15.34.43');        // 15.34
var num2 = parseFloat('0x123.45'); // 0 因为不支持十六进制
var num3 = parseFloat(' 012.0test'); // 12

一元加和减操作符

一元加操作符的功能完全和Number()函数一致;一元减操作符是在加操作符的基础上取负值

小结

当我们可以确定被转换的变量类型是string类型时,推荐优先使用parseFloat,可以当被转换变量为小数的正常使用;当使用parseInt时,推荐使用第二个参数来确定参数一的进制类型,避免因为不同浏览器的兼容问题;

在写作过程中,越写越发现牵涉到的知识点很多,或许很多地方存在纰漏、误差。如有问题,还请指正!!!

【前端】深入浅出Javascript中的数值转换的更多相关文章

  1. JavaScript中的数值转换

    在JavaScript中,有3个函数可以把非数值转换为数值 1.Number()函数 Number()可以用于任意数据类型. 转换规则如下. 如果是Boolean值,true和false将分别被转换为 ...

  2. 前端随笔 - JavaScript中的闭包

    前阵子重新复习了一下js基础知识,第一篇博客就以分享闭包心得为开始吧. 首先,要理解闭包,就必须要了解一个概念:作用域链. 作用域链 作用域代表着可访问变量的集合,变量分为全局变量和局部变量两种,在函 ...

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

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

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

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

  5. 深入浅出 JavaScript 中的 this

    在 Java 等面向对象的语言中,this 关键字的含义是明确且具体的,即指代当前对象.一般在编译期确定下来,或称为编译期绑定.而在 JavaScript 中,this 是动态绑定,或称为运行期绑定的 ...

  6. 【转】深入浅出 JavaScript 中的 this

    Java 等面向对象的语言中,this 关键字的含义是明确且具体的,即指代当前对象.一般在编译期确定下来,或称为编译期绑定.而在 JavaScript 中,this 是动态绑定,或称为运行期绑定的,这 ...

  7. 【前端】javascript中10常用的个小技巧总结

    javascript中10常用的个小技巧总结 本文转自:http://www.cnblogs.com/libin-1/p/6756393.html 1. new Set() 可能有人知道ES6中提供了 ...

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

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

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

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

随机推荐

  1. python用ElemenTree快速高效的解析xml

    python解析xml有很多种方法,比较流行的由SAX,DOM和ElementTree,简要介绍一下这几种方法的异同: 方法 特点 SAX SAX解析通过流模式在解析XML的过程中触发对应的事件(st ...

  2. px,em,rem,vw单位在网页和移动端的应用

    px: 是网页设计中最常用的单位,然而1px到底是多大长,恐怕没有人能回答上来 它用来表示屏幕设备物理上能显示的最小的一个点,这个点不是固定宽度的,不同设备上点的长度.比例有可能会不同. 假设:你现在 ...

  3. Serializable序列化的作用

    这里转载一篇讲解java序列化(Serializable)和反序列化方面的感觉很好的文章.1.序列化是干什么的?简单说就是为了保存在内存中的各种对象的状态(也就是实例变量,不是方法),并且可以把保存的 ...

  4. DES、3DES、AES加密方式

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt165 DES 支持8位加密解密,3Des支持24位,Aes支持32位.3De ...

  5. java伪代码《大道至简》

    阅读<大道至简>第一章,深感作者对编程问题的精炼定义,通过对古老寓言故事<愚公移山>的引用,说明了编程的本质,即顺序,分支,循环.其中又将他们扮演的项目组织者,团队经理,编程人 ...

  6. 【Alpha】阶段 第六次 Scrum Meeting

    每日任务 1.本次会议为第 六次 Meeting会议: 2.本次会议在上午09:35,大课间休息时间在陆大召开,召开本次会议为20分钟,讨论统一下时间安排的问题以及一些程序上的该进: 一.今日站立式会 ...

  7. java中覆盖必须满足的约束

    子类方法的名称,参数何返回类型必须与父类一致. 子类方法不能缩小父类方法的访问权限 子类方法不能抛出比父类方法更多的异常 方法覆盖只存在于子类和父类,同一个类中方法只能被重载 父类的静态方法不能被子类 ...

  8. 201521123080《Java程序设计》第5周学习总结

    1. 本周学习总结 1.1 尝试使用思维导图总结有关多态与接口的知识点. 2. 书面作业 1.代码阅读:Child压缩包内源代码 1.1 com.parent包中Child.java文件能否编译通过? ...

  9. 201521123053《Java程序设计》第3周学习总结

    ---恢复内容开始--- 1. 本周学习总结 2. 书面作业 1. 代码阅读 以上代码可否编译通过?哪里会出错?为什么?尝试改正?        如果创建3个Test1对象,有内存中有几个i,几个j? ...

  10. 201521123048 《Java程序设计》第1周学习总结

    一 本周学习总结 第一周我们了解了java及其它的由来.刚开始学java显的特别吃力,对于一些概念和程序执行步骤什么的都不好理解,也有很多在编程时容易出错的地方需要花时间理解和记忆.初步一周下来,在我 ...