JavaScript parseInt和parseFloat用法
今天来聊聊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用法相关推荐
- JS转换为数字的方法Number()、parseInt()和 parseFloat()
Number().parseInt()和 parseFloat() 第一个函数, 即转型函数 Number()可以用于任何数据类型,而另两个函数则专门用于把字符串转换成数值.这 3 个 函数对于同样的 ...
- html使用parseInt函数,JavaScript parseInt() 函数
JavaScript parseInt() 函数 JavaScript 全局函数 定义和用法 parseInt() 函数可解析一个字符串,并返回一个整数. 当参数 radix 的值为 0,或没有设置该 ...
- Number()、parseInt() 和 parseFloat() 的区别
一:Number() 如果是Boolean值,true和false值将分别被转换为1和0. 如果是数字值,只是简单的传入和返回. 如果是null值,返回0. 如果是undefined,返回NaN. 如 ...
- parseInt() 、 parseFloat() 和Number()的区别
字符串转换数字的方式 一.parseInt 二.parseFloat 三.Number 四.parseInt() 和parseFloat()的区别 一.parseInt parseInt()函数在转换 ...
- Number()、parseInt()和parseFloat()的区别
JS中Number().parseInt()和parseFloat()的区别 三者的作用: Number(): 可以用于任何数据类型转换成数值: parseInt(): 函数可解析一个字符串,并返回 ...
- 从ES规范和引擎细谈 js 中 parseInt 和 parseFloat 的执行机制
从ES规范和引擎细谈 js 中 parseInt 和 parseFloat 的执行机制 parseInt()和parseFloat()这两个常用 API 其实还是有很多"坑"的,以 ...
- parseInt,parseFloat,Number的区别
Number:如果是Boolean值,true和false值将分别被转换为1和0.如果是数字值,只是简单的传入和返回.如果是null值,返回0.如果是undefined,返回NaN.如果是字符串:a. ...
- 你所不知道的Number()、parseInt()、parseFloat()转换细则
为什么要写这篇文章 最近在阅读<javascript高级程序设计>(第6版)这本书,以写代记.同时刚刚入职新公司,发现自己对于number类型转换的细节掌握不足 使用场景 我们常常对于很多 ...
- parseInt 与 parseFloat 解析
parseInt() 与 parseFloat 执行逻辑差不多,首先查看0位置的 字符,判断其是否是个 有效数字,依次类推,直到 遇到 非有效数字 为止, 如:123bbb 就会 变为 123 ...
最新文章
- stelnet 简介 华为ssh的另一种称呼
- 青龙面板薅羊毛–都爱玩(日收益2元左右)
- 在github上创建新分支
- SQL Server 安装好后 Always On群组配置
- github 档案馆(是不是那个把code放到北极的那个项目。。。)
- mysql存储过程套嵌_mysql存储过程套嵌
- 知名大学博士毕业都去哪儿?55所高校大数据揭秘
- Wodpress模板
- java number 转 long_Java Number.longValue()用法及代码示例
- Midi 乐器set
- makefile语法_Makefile的语法
- linux DISPLAY变量
- 建模学习笔记(一)层次分析法模型学习及相关论文书写 清风数学建模
- QQ坦白说闹得我差点分手,破解揪元凶证清白
- 定义复数java_java怎么定义复数?
- python掷骰子实验代码_Python Tkinter实例——模拟掷骰子
- java实现爬虫,爬取网易歌单信息
- 理想电压源的内阻是0,理想电流源的内阻是无穷大
- 支持v4l2 linux内核选项 s3c2440,linux内核移植-移植2.6.35.4内核到s3c2440
- 倍福PLC的ModbusRTU设置