JS数据类型转换

[align=center][color=brown][size=large]JS数据类型转换[/size][/color][/align]

JS数据类型转换方法主要有三种:转换函数、强制类型转换、利用js变量弱类型转换。

1、转换函数:

js提供了parseInt()和parseFloat()两个转换函数。前者把值转换成整数,后者把值转换成浮点数。只有对String类型调用这些方法,这两个函数才能正确运行;对其他类型返回的都是NaN(Not a Number)。

在判断字符串是事是数字值前,parseInt()和parseFloat()都会仔细分析该字符串。parseInt()方法首先查看位置0处的字符,判断它是否是个有效数字;如果不是,该方法返回NaN,不再继续执行其他操作。如果该字符是有效数字,该方法将查看位置1处的字符,进行同样的测试。这一过程将持续到发现非有效数字的字符为止,此时parseInt()将把该字符之前的字符串转换成数字。

例如:

parseInt("1234blue");//return 1234

parseInt("22.5");// return 22 对于整数来说,小数点是无效字符

parseInt("blue");//return NaN


parseInt()方法还有基模式,可以把二进制、八进制、十六进制或其他任何进制的字符串转换成整数。基是由parseInt()方法的第二个参数指定的。

例如:

parseInt("AF",16); //return 175 十六进制

parseInt("10",2);//return 2 二进制

parseInt("10",8);//return 8 八进制

parseInt("10",10);//return 10 十进制


如果十进制数包含前导0,那么最好采用基数10,这样才不会意外地得到八进制的值。

例如:

parseInt("010");//return 8

parseInt("010",8);//return 8

parseInt("010",10);//return 10

parseFloat()方法与parseInt()方法的处理方式相似,但有不同之处 。当字符串中有两个小数点,第二个小数点将被看作无效的,即字符串“22.34.5”将被解析为22.34。另外一个不同之处在于,字符串必须以十进制形式表示浮点数,不能用八进制或十六进制。parseFloat()没有基模式。

例如:

parseFloat("1234blue");//return 1234.0

parseFloat("22.34.5");//return 22.34

parseFloat("0908");//return 908

parseFloat("blue");//return NaN


2、强制类型转换

Boolean(value)--把给定的值转换成Boolean型,如果转换的值是至少有一个字符的字符串、非0数字或对象时,返回true;如果该值是空字符串、数字0、undefined或null,将返回false。

Boolean("");//return false

Boolean("hi");//return true

Boolean(100);//return true

Boolean(null);//return false

Boolean(0);//return false

Boolean(new Object());//return true


Number(value)--把给定的值转换成数字(整数或浮点数),如果转换的值不是数值,则会返回NaN

Number(false);//return 0

Number(true);//return 1

Number(undefined);//return NaN

Number(null);//return 0

Number("5.5");//return 5.5

Number("56");//return 56

Number("5.6.7");//return NaN

Number(new Object());//return NaN

String(value)--把给定的值转换成字符串


3、js变量弱类型转换


原文链接 [url]http://www.cnblogs.com/446557021/archive/2011/10/13/2211043.html[/url]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值