js字符串转成数字的三种⽅法
⽅法主要有三种
转换函数、强制类型转换、利⽤js变量弱类型转换。
1. 转换函数:
js提供了parseInt()和parseFloat()两个转换。前者把值转换成整数,后者把值转换成浮点数。只有对String类型调⽤这些⽅法,这两个函数才能正确运⾏;对其他类型返回的都是NaN(Not a Number)。
⼀些⽰例如下:
代码如下:
parseInt("1234blue"); //returns 1234
parseInt("0xA"); //returns 10
parseInt("22.5"); //returns 22
parseInt("blue"); //returns NaN
parseInt()⽅法还有基模式,可以把⼆进制、⼋进制、⼗六进制或其他任何进制的字符串转换成整数。基是由parseInt()⽅法的第⼆个参数指定的,⽰例如下:
代码如下:
parseInt("AF", 16); //returns 175
parseInt("10", 2); //returns 2
parseInt("10", 8); //returns 8
parseInt("10", 10); //returns 10
如果⼗进制数包含前导0,那么最好采⽤基数10,这样才不会意外地得到⼋进制的值。例如:
代码如下:
parseInt("010"); //returns 8
parseInt("010", 8); //returns 8
parseInt("010", 10); //returns 10
parseFloat()⽅法与parseInt()⽅法的处理⽅式相似。
使⽤parseFloat()⽅法的另⼀不同之处在于,字符串必须以⼗进制形式表⽰浮点数,parseFloat()没有基模式。
下⾯是使⽤parseFloat()⽅法的⽰例:
代码如下:
parseFloat("1234blue"); //returns 1234.0
parseFloat("0xA"); //returns NaN
parseFloat("22.5"); //returns 22.5
parseFloat("22.34.5"); //returns 22.34
parseFloat("0908"); //returns 908
parseFloat("blue"); //returns NaN
2. 强制类型转换
还可使⽤强制类型转换(type )处理转换值的类型。使⽤强制类型转换可以访问特定的值,即使它是另⼀种类型的。
ECMAScript中可⽤的3种强制类型转换如下:
Boolean(value)——把给定的值转换成Boolean型;
Number(value)——把给定的值转换成数字(可以是整数或浮点数);
String(value)——把给定的值转换成字符串。
⽤这三个函数之⼀转换值,将创建⼀个新值,存放由原始值直接转换成的值。这会造成意想不到的后果。
当要转换的值是⾄少有⼀个字符的字符串、⾮0数字或对象(下⼀节将讨论这⼀点)时,Boolean()将返回true。如果该值是空字符串、数字0、undefined或null,它将返回false。
可以⽤下⾯的代码段测试Boolean型的强制类型转换。
代码如下:
Boolean(""); //false – empty string
Boolean("hi"); //true – non-empty string
Boolean(100); //true – non-zero number
Boolean(null); //false - null
Boolean(0); //false -
Boolean(new Object()); //true – object
Number()的强制类型转换与parseInt()和parseFloat()⽅法的处理⽅式相似,只是它转换的是整个值,⽽不是部分值。⽰例如下:
代码如下:
⽤法结果
Number(false) 0
Number(true) 1
Number(undefined) NaN
Number(null) 0
Number( "5.5 ") 5.5
Number( "56 ") 56
Number( "5.6.7 ") NaN
Number(new Object()) NaN
js方法Number(100) 100
最后⼀种强制类型转换⽅法String()是最简单的,⽰例如下:
代码如下:
var s1 = String(null); //"null"
var oNull = null;
var s2 = String(); //won't work, causes an error
3. 利⽤js变量弱类型转换
举个⼩例⼦,⼀看,就会明⽩了。
代码如下:
<script>
var str= '012.345 ';
var x = str-0;
x = x*1;
</script>
上例利⽤了js的弱类型的特点,只进⾏了算术运算,实现了字符串到数字的类型转换,不过这个⽅法还是不推荐的

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。