JS中Number(),parseInt(),parseFloat()和自动类型转换
【参考来源】
https://www.cnblogs.com/yi0921/p/6196841.html
https://blog.csdn.net/u010200222/article/details/10282351
【正文内容】
Number()
-------------------------------------------------------------------------------------
--Number()
--
--
--Boolean值,true->1,false->0。
--
--数字值,整型就是整型,浮点型就是浮点型,科学计数就科学计数
--
--null值,转为0
--
--二进制,八进制,十六进制格式,转为十进制的数值
--
--字符串为空,转为0
--
--字符串中是纯科学计数,数值会直接转为十进制的数值
--
--undefined , 对象 , 数组 ,字符串不为纯数字和科学计数时 返回NaN
------------------------------------------------------------------------------------
- //JS区分0和-0
- var num = 123;
- var num = 123.123;
- var num = 0b10;
- var num = 010;
- var num = 0xff;
- var num = 5e2;
- var num = 5e-2;
- var num = NaN;
- console.log('值: ' , num);
- console.log('类型: ' , typeof(num))
- //NaN本身为false
- //其他类型转为数值失败时都为NaN
- console.log(NaN - 100);
- if(NaN){
- console.log('Yes');
- }else{
- console.log('No');
- }
- //NaN
- var a = '123ad';
- //
- var a = '123';
- //NaN
- var a = 'f3ad';
- //
- var a = false;
- //
- var a = true;
- //NaN
- var a = undefined;
- var a = new Object();
- var a = Array(1,23);
- //1e+124
- var a = 10e123;
- //
- var a = 0b11;
- //
- var a = 0xff;
- //1.23
- var a = 1.23;
- //
- var a = '';
- //
- var a = '12e2';
- //
- var a = null;
- //
- var a = 0132;
- var n = Number(a);
- console.log(n);
parseInt()
-----------------------------------------------------------------------------------------------------------------------------------------
--parseInt()
--
--
--数值正常转化,如果为浮点数,则转为整型,舍弃小数点后的数值
--
--数字开头的字符串,只转换数字整数部分,忽略字母部分
--
--二进制,八进制,十六进制转化时,转化为十进制的数值
--
--科学计数法,能解析时正常解析,不能时返回第一个数字
--
--Boolean,undefined , 对象 , 数组 ,空字符串,字符串开头不为纯数字和科学计数时 返回NaN
----------------------------------------------------------------------------------------------------------------------------------------
- //
- var a = '123ad';
- //
- var a = '123';
- //NaN
- var a = 'f3ad';
- //NaN
- var a = false;
- //NaN
- var a = true;
- //NaN
- var a = undefined;
- var a = new Object();
- //13 第一个值
- var a = Array(13,2);
- //3100000能够解析处时正常解析,不能时只返回第一个数字
- var a = 31e5;
- //
- var a = 0b11;
- //
- var a = 0xff;
- //
- var a = 1.23;
- //NaN
- var a = '';
- //12 字符串只返回12e舍弃
- var a = '12e2';
- //NaN
- var a = null;
- //
- var a = 1.5;
- //
- var a = 0132;
- var n = parseInt(a);
- console.log(n);
- var a = parseInt("10",2);
- var a = parseInt("FF",16);
- var a = parseInt("10",8);
- console.log(a);
parseFloat()
--------------------------------------------------------------------------------------------------------------------------------
--parseFloat()
--
--
--数值正常转化,整型为整型,浮点型为浮点型
--
--数字开头的字符串,只转换数字整数部分,忽略字母部分
--
--二进制,八进制,十六进制转化时,转化为十进制的数值
--
--科学计数法,能解析时正常解析,超出范围则返回Infinity
--
--Boolean,undefined , 对象 , 数组 ,空字符串,字符串开头不为纯数字和科学计数时 返回NaN
--
--不能有多个小数点报语法错误
--------------------------------------------------------------------------------------------------------------------------------
- //
- var a = '123ad';
- //
- var a = '123';
- //NaN
- var a = 'f3ad';
- //NaN
- var a = false;
- //NaN
- var a = true;
- //NaN
- var a = undefined;
- var a = new Object();
- //13 第一个值
- var a = Array(13,2);
- //3100000 范围过大将转为科学计数法再大将为Infinity
- var a = 31e5;
- //
- var a = 0b11;
- //
- var a = 0xff;
- //1.23
- var a = 1.23;
- //NaN
- var a = '';
- //
- var a = '12e2aa';
- //NaN
- var a = null;
- //1.5
- var a = 1.5;
- //
- var a = 0132;
- //
- var a = 1.113;
- var n = parseFloat(a);
- console.log(n);
自动类型转换
数字类型: 在字符串环境下 隐身转换为字符串
字符串类型 在数字环境下,可以隐式转换为字符串中的数字或NaN;
在布尔环境下,可以隐式转换为true.
空字符串:在数字环境下可以隐式转换为0;
在布尔环境下可以隐式转换为false;
字符串'true': 在数字环境下可以隐式转换位1;布尔为true
字符串'false': 数字环境为0,布尔位false
null: 在字符串环境下,转换为'null';
数字环境下,转换为0,布尔环境下,转为false
NaN: 在字符串环境下可以隐式转换为'NaN';
布尔环境下,转换为false
undefined: 字符串环境下,转换为“undefined”,
数字环境下,转为NaN,
布尔下,转为false
true: 字符串转为'true',数字环境下转为1
false: 字符串转为'false',数字环境下转为0
JS中Number(),parseInt(),parseFloat()和自动类型转换的更多相关文章
- Number,parseInt,parseFloat函数
Number,parseInt,parseFloat函数 console.group('Number'); console.log(Number( console.log(Number( consol ...
- 详解JS中Number()、parseInt()和parseFloat()的区别
三者的作用: Number(): 可以用于任何数据类型转换成数值: parseInt().parseFloat(): 专门用于把字符串转换成数值: 一.Number( ): (1)如果是Boolean ...
- Number(),parseInt(),parseFloat(),Math.round(),Math.floor(),Math.ceil()对比横评
首先,这些处理方法可分为三类. 1,只用来处理数字取整问题的:Math.round(),Math.floor(),Math.ceil(): 2,专门用于把字符串转化成数值:parseInt(),par ...
- java重载中的基本类型的自动类型转换
当传递到函数的参数的数据类型表示的范围小于函数形参的参数类型遵循如下原则 : char类型比较特殊, 直接转换为int: char ->int ->long->float-> ...
- js中Number()、parseInt()和parseFloat()的区别
一:Number() 如果是Boolean值,true和false值将分别被转换为1和0. 如果是数字值,只是简单的传入和返回. 如果是null值,返回0. 如果是undefined,返回NaN. 如 ...
- js中Number()、parseInt()和parseFloat()的区别进行详细介绍
http://www.jb51.net/article/100606.htm 区别: parseFloat,parseInt 解析的过程中如果前面有空格,结果不会有任何影响,Number解析的时候结 ...
- JavaScript中Number(),parseInt()和parseFloat()区别
parseInt() 函数可解析一个字符串,并返回一个整数; parseFloat() 函数可解析一个字符串,并返回一个浮点数, 以上都是截取转换,具体代码如下: alert(parseInt(&qu ...
- js中Number对象与MATH方法整理总结
W3C的文档: Number 对象属性 属性 描述 constructor 返回对创建此对象的 Number 函数的引用. MAX_VALUE 可表示的最大的数. MIN_VALUE 可表示的最小的数 ...
- Number(), parseInt(), parseFloat()
var n="100.11px";console.log(Number(n));//NaNconsole.log(parseInt(n));//100console.log(par ...
随机推荐
- Python内存优化:Profile,slots,compact dict
实际项目中,pythoner更加关注的是Python的性能问题,之前也写过一篇文章<Python性能优化>介绍Python性能优化的一些方法.而本文,关注的是Python的内存优化,一般说 ...
- 数据库sql的in操作,解决in的过多
一个sql的拼写后,服务器会把这个sql传送到数据库服务器执行,一般不在一个物理机上.那么传送需要走网络,包丢失等网络情况就可能出现. 一般情况,一个sql的长度不会很大,但是有种这样的情况.in操作 ...
- Yarn 入门
Yarn 是快速.可靠.安全的 js 包管理器. 关键词: nodejs, 包管理, yarn 简介 Yarn 是快速.可靠.安全的 js 包管理器. 快速 - Yarn 会缓存它下载的每个包,所以无 ...
- CSS-Photoshop投影与CSS中box-shadow的转换
box-shadow是给元素块添加周边阴影效果基本语法是: {box-shadow:[inset] x-offset y-offset blur-radius spread-radiuscolor} ...
- 把一个List<T>的数据复制至另一个List<T>
把一个数据集List<T>复制至到另一个数据集List<T>. 方法一,可以使用循环,然后把每一个T添加至另一个集合中去: public void ListDemo() { , ...
- flask seesion组件
一.简介 flask中session组件可分为内置的session组件还有第三方flask-session组件,内置的session组件功能单一,而第三方的flask-sessoin可支持re ...
- Scala学习(三)练习
Scala数组相关操作&练习 1. 1. 编写一段代码,将a设置为一个包含n个随机整数的数组,要求随机数介于0(包含)和n(不包含)之间 def main (args: Array[Strin ...
- NIO之缓冲区
NIO引入了三个概念: Buffer 缓冲区 Channel 通道 selector 选择器 1.java.io优化建议 操作系统与Java基于流的I/O模型有些不匹配.操作系统要移动的是大块数据(缓 ...
- 发布了一个基于jieba分词的ElasticSearch插件
github地址: https://github.com/hongfuli/elasticsearch-analysis-jieba 基于 jieba 的 elasticsearch 中文分词插件. ...
- Daily scrum 12.24
平安夜闲得想来一遍scrum,添加了之前ui组的数据库问题修复任务. 其实是之前忘记在任务中添加了.现在基本修复完成. Member Today’s task 林豪森 与学霸其他小组交流,处理整合问题 ...