今天来聊聊parseInt函数和parseFloat函数。

1、parseInt

定义和用法

JavaScript内置函数,原型为parseInt(string s,int radix)。

其用途为解析一个字符并返回一个整数,其中string是需要被解析的字符,是必须的参数,而radix是被解析数字的基数,是非必需的,当radix值设置为0或未设置时,parseInt会根据string的值来判断基数。默认状态parseInt为全局函数。

parseInt解析字符先看字符开头:

  • 如果string以"0x"开头,parseInt会把string转化为十六进制整数
  • 如果string以1~9开头,parseInt会把string转化为十进制整数
  • 如果string以0后接数字开头,parseInt会把string转化为八进制整数
  • 如果string以无效字符(不包括空格)开头,parseInt会返回NaN,而不进行其他操作

注意

  • 只有字符串中第一个字符会返回,而如果中间遇到空格等无效字符则解析终止
  • 开头和结尾的空格是允许的(只要是数字字符前的空格均被允许)
  • parseInt在未指定基数时会以字符开头来判断基数,而如果想要得到预期基数的整数就需要在string后设置radix值来控制转化的进制数

实例

document.write(parseInt("10") + "<br>");
document.write(parseInt("10.33") + "<br>");        //传入字符串只能被转化为整数
document.write(parseInt("34 45 66") + "<br>");        //中间的空格被视为无效字符而中止解析
document.write(parseInt(" 60 ") + "<br>");        //开头可结尾的空格字符不会影响字符解析
document.write(parseInt("40 years") + "<br>");        //years字符是无效字符,不会被解析
document.write(parseInt("He was 40") + "<br>");        //开头字符为H,无效字符,其后的数字字符不会被解析
document.write("<br>");
document.write(parseInt("10",10)+ "<br>");        //字符后的基数表示以十进制输出该字符
document.write(parseInt("10",8)+ "<br>");        //八进制输出字符
document.write(parseInt("0x10")+ "<br>");        //因为前面有0x,默认以十六进制输出
document.write(parseInt("10",16)+ "<br>");        //十六进制输出字符

结果

10
10
34
60
40
NaN

10
8
16

16

2、parseFloat

定义和用法

同样是JavaScript内置函数,原型为parseFloat(string s)。

parseFloat函数可解析一个字符串并返回一个浮点数。解析数字时只对第一个小数点有效,之后的小数点会被当作无效字符,如果在解析过程中遇到了正负号(+ 或 -)、数字 (0-9)、小数点,或者科学记数法中的指数(e 或 E)以外的字符,则它会忽略该字符以及之后的所有字符,返回当前已经解析到的浮点数。

除了第一个小数点有效之外,parseFloat()与parseInt()的第二个区别在于它始终都会忽略前导的零。parseFloat()可以识别前面讨论过的所有的浮点数值格式,也包括十进制整数格式。但十六进制格式的字符串则始终会被转换成0。由于parseFloat()只解析十进制值,因此它没有用第二个参数指定基数的用法。

注意

  • 函数只返回字符串中第一个数字字符
  • 开头和结尾空格是允许的(只要是数字字符前的空格均被允许)
  • 如果字符串的第一个字符不能被转化为数字,则parseFloat()会返回NaN

实例

document.write(parseFloat("10") + "<br>");
document.write(parseFloat("10.33") + "<br>");
document.write(parseFloat("34 45 66") + "<br>");        //函数只返回字符串中的一个数字字符
document.write(parseFloat(" 60 ") + "<br>");        //开头和结尾的空格是允许的
document.write(parseFloat("40 years") + "<br>");        //字符串中只有数字字符会被转化为数字
document.write(parseFloat("He was 40") + "<br>");        //第一个字符不能被转化为字符

结果

10
10.33
34
60
40

NaN

JavaScript parseInt和parseFloat用法相关推荐

  1. JS转换为数字的方法Number()、parseInt()和 parseFloat()

    Number().parseInt()和 parseFloat() 第一个函数, 即转型函数 Number()可以用于任何数据类型,而另两个函数则专门用于把字符串转换成数值.这 3 个 函数对于同样的 ...

  2. html使用parseInt函数,JavaScript parseInt() 函数

    JavaScript parseInt() 函数 JavaScript 全局函数 定义和用法 parseInt() 函数可解析一个字符串,并返回一个整数. 当参数 radix 的值为 0,或没有设置该 ...

  3. Number()、parseInt() 和 parseFloat() 的区别

    一:Number() 如果是Boolean值,true和false值将分别被转换为1和0. 如果是数字值,只是简单的传入和返回. 如果是null值,返回0. 如果是undefined,返回NaN. 如 ...

  4. parseInt() 、 parseFloat() 和Number()的区别

    字符串转换数字的方式 一.parseInt 二.parseFloat 三.Number 四.parseInt() 和parseFloat()的区别 一.parseInt parseInt()函数在转换 ...

  5. Number()、parseInt()和parseFloat()的区别

    JS中Number().parseInt()和parseFloat()的区别 三者的作用:  Number(): 可以用于任何数据类型转换成数值: parseInt(): 函数可解析一个字符串,并返回 ...

  6. 从ES规范和引擎细谈 js 中 parseInt 和 parseFloat 的执行机制

    从ES规范和引擎细谈 js 中 parseInt 和 parseFloat 的执行机制 parseInt()和parseFloat()这两个常用 API 其实还是有很多"坑"的,以 ...

  7. parseInt,parseFloat,Number的区别

    Number:如果是Boolean值,true和false值将分别被转换为1和0.如果是数字值,只是简单的传入和返回.如果是null值,返回0.如果是undefined,返回NaN.如果是字符串:a. ...

  8. 你所不知道的Number()、parseInt()、parseFloat()转换细则

    为什么要写这篇文章 最近在阅读<javascript高级程序设计>(第6版)这本书,以写代记.同时刚刚入职新公司,发现自己对于number类型转换的细节掌握不足 使用场景 我们常常对于很多 ...

  9. parseInt 与 parseFloat 解析

    parseInt()  与 parseFloat  执行逻辑差不多,首先查看0位置的 字符,判断其是否是个 有效数字,依次类推,直到 遇到 非有效数字 为止, 如:123bbb  就会 变为 123 ...

最新文章

  1. stelnet 简介 华为ssh的另一种称呼
  2. 青龙面板薅羊毛–都爱玩(日收益2元左右)
  3. 在github上创建新分支
  4. SQL Server 安装好后 Always On群组配置
  5. github 档案馆(是不是那个把code放到北极的那个项目。。。)
  6. mysql存储过程套嵌_mysql存储过程套嵌
  7. 知名大学博士毕业都去哪儿?55所高校大数据揭秘
  8. Wodpress模板
  9. java number 转 long_Java Number.longValue()用法及代码示例
  10. Midi 乐器set
  11. makefile语法_Makefile的语法
  12. linux DISPLAY变量
  13. 建模学习笔记(一)层次分析法模型学习及相关论文书写 清风数学建模
  14. QQ坦白说闹得我差点分手,破解揪元凶证清白
  15. 定义复数java_java怎么定义复数?
  16. python掷骰子实验代码_Python Tkinter实例——模拟掷骰子
  17. java实现爬虫,爬取网易歌单信息
  18. 理想电压源的内阻是0,理想电流源的内阻是无穷大
  19. 支持v4l2 linux内核选项 s3c2440,linux内核移植-移植2.6.35.4内核到s3c2440
  20. 倍福PLC的ModbusRTU设置

热门文章

  1. Gallery3d 学习笔记(13)
  2. PHP使用socks5代理发送邮件
  3. includes的作用
  4. 俞敏洪一分钟励志演讲
  5. keras添加L1正则化,L2正则化和Dropout正则化及其原理
  6. 如何解释反向代理与正向代理
  7. adb 指令uninstall卸载android app 处理方法
  8. 计算机用户凭据删除,win8系统如何删除保存的共享凭据(用户名和密码)
  9. Linux如何永久以命令行界面形式登录
  10. recover database