JavaScript中的数值转换函数

1.Number()函数
(1)用于任何数据类型,属于一种转型函数
(2)转型规则

  • Boolean值,true->1,false->0
  • 数字值,简单的传入和返回
  • null值,返回0
  • undefined,返回NaN
  • 字符串,如果只包含数字,则转为十进制数,如果前面带0,则会自动忽略;如果里面包含有效的浮点格式,就会转换为对应的浮点数值,前导0也会被自动忽略;如果字符串中包含有效的十六进制格式,则会转换为相应的十进制整数值;如果是空字符串,不包含任何字符,则会转化为0;除了上面的这些格式,其余的格式的字符串都会转换为NaN。
    下面的对上述规则的一个验证例子程序:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" lang="en">
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
		<title>数值转换</title>
		<script type="text/javascript">
			/*Number()函数处理数值问题*/
			var number1 = Number("javascript");
			var number2 = Number("11");
			var number3 = Number("0002");
			var number4 = Number(false);
			var number5 = Number(true);
			alert(number1);//NaN
			alert(number2);//11
			alert(number3);//2
			alert(number4);//0
			alert(number5);//1
		</script>
	</head>
	<body>
	</body>
</html>

2.parseInt()函数和parseFloat()函数
(1)parseInt在转换字符串时,首先会判断其是否符合数值模式,它会自动忽略字符串前面的空格,直到找到第一个非空格字符。
(2)如果第一个字符不是数字字符或者负号,parseInt就会返回NaN;对于空字符串,parseInt会返回NaN,但是Number函数会返回0;如果解析的第一个字符是数字字符,那么就会一直解析,直到解析到最后一个不是数字字符的字符时停止解析,如果没有遇到非数字字符,就会解析完所有的字符。
(3)对于进制数也是可以进行正确的解析的,解析为十进制,在ECMAScript3中parseInt是具有解析进制数的能力,但是在ECMAScript5中parseInt已经不具有这种能力了,所以要想在ECMAScript5中解析进制数,就需要给parseInt再添加一个参数,该参数用来指定进制数。
下面是对于parseInt函数的一个简单的验证

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en">
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
		<title>数值转换</title>
		<script type="text/javascript">
			/*parseInt函数处理数值问题*/
			var num1 = parseInt("  123xas");
			var num2 = parseInt("");
			var num3 = parseInt("0xA");
			var num4 = parseInt("123.456");
			var num5 = parseInt("66");
			var num6 = parseInt("070");//ECMAScript5中的parseInt已经不具有解析八进制的能力,前导零会被忽略掉,按照十进制进行解析
			var num7 = parseInt("070",8);
			alert(num1);//123
			alert(num2);//NaN
			alert(num3);//10
			alert(num4);//123
			alert(num5);//66
			alert(num6);//70  
			alert(num7);//56
		</script>
	</head>
	<body>
	</body>
</html>

(4)parseFloat是从第一个字符(位置0)开始解析每个字符,直到解析到字符串末尾,或者解析到遇见一个无效的浮点数字字符为止。其中第一个小数点是有效的,以后的小数点都是无效的,会被自动忽略掉。
(5)parseFloat函数始终都会忽略掉前导0,所以十六进制的字符串总是被转换为0,而且parseFloat只解析十进制,因此它不用指定第二个参数。如果字符串中包含一个可解析为整数的数(没有小数点或者小数点后全是0),parseFloat就会返回整数。
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值