zoukankan      html  css  js  c++  java
  • javascript基础:数据类型的转换

    1、数据类型的强制转换

    包括:

    数字+字符串:数字被强转成字符串。

    布尔+字符串:布尔被强制转为字符串。

    布尔+数字:布尔强转为数字。

    <!doctype html>
    <html>
     <head>
    	<meta charset="gb2312">
    	<title>实验</title>
    	</script>	
     </head>
    
     <body>
        <script language="javascript">
    		var str,i,b,bb,u;
    
    		str ="123";
    		i = 1;
    		b = true;
    		bb = false;
    		u = null;
    
    		document.write("<br>i+str(数字+字符串):" + (i+str));
    
    		document.write("<br>b+str(布尔+字符串):" + (b+str));
    
    		document.write("<br>b+i(布尔+数字):" + (b+i));
    
    		document.write("<br>bb+i(布尔+数字):" + (bb+i));
    
    		document.write("<br>u+str(null+字符串):" + (u+str));		
    	</script>
     </body>
    </html>



    2、数据类型的转换 函数

    (1)parseInt:把字符串变量开头的数字,按照指定的进制(就是我们认为数字的进制,不是要转化成为什么进制),转成10进制的整数。

    比如,下面代码中最后一个16fe,我们认为这个是8进制的数字,因为在8进制里根本没有fe这种只有在16进制才有的符号,所以把8进制数字16,转成10进制的数字,也就是1*8+6 = 14.

    还有第3个xx 10,因为开头的字符里没有数字,所以返回结果就是NaN, 也就是说不是一个数字,not a number。

    <!doctype html>
    <html>
     <head>
    	<meta charset="gb2312">
    	<title>实验</title>
    	</script>	
     </head>
    
     <body>
        <script language="javascript">
    
    		console.log(parseInt("10 xx"));
    		console.log(parseInt("10.6"));
    		console.log(parseInt("xx 10"));
    		console.log(parseInt("16fe的值",16));
    		console.log(parseInt("16fe的值",10));
    		console.log(parseInt("16fe的值",8));
    
    	</script>
     </body>
    </html>


    (2)parseFloat:把字符串开头的浮点数转成浮点数。

    和上面的parseInt类似。

    (3)typeof:返回变量的数据类型。

    注意,如果变量值为null,那么返回的类型是object,而不是null类型。

    <!doctype html>
    <html>
     <head>
    	<meta charset="gb2312">
    	<title>实验</title>
    	</script>	
     </head>
    
     <body>
        <script language="javascript">
            var s = null;
    		var ss;
    		var b = false;
    
    		console.log(typeof(s));
    		console.log(typeof(ss));
    		console.log(typeof(b));
    
    		console.log(typeof("xxx 10"));
    		console.log(typeof(10.5));
    
    	</script>
     </body>
    </html>


    (4)eval:把字符串中参数作为表达式,返回这个表达式的结果。

    <!doctype html>
    <html>
     <head>
    	<meta charset="gb2312">
    	<title>实验</title>
    	</script>	
     </head>
    
     <body>
        <script language="javascript">
            var s = 5;
    		var ss = 6;
    
    		console.log(eval(s+ss));
    		console.log(eval("5*6+8+s+ss"));
    		console.log(eval("5*6+'100'"));
    	</script>
     </body>
    </html>

    从输出结果可以看出,eval的功能非常强大,除了可以计算:基本的变量相加的表达式,还可以嵌入变量,引入字符串后,还可以实现数字+字符串的 计算,不过结果就是个字符串了。

    之前在sql server板块,经常有人问如何实现eval的功能,实际上sql语句更加倾向于一般的求和、计数等,不适合用来做解析字符串表达式,每一种语言都有适用范围。



  • 相关阅读:
    还不懂MySQL索引?这1次彻底搞懂B+树和B-树
    11条MySQL规范,你知道的有几个?
    4个点说清楚Java中synchronized和volatile的区别
    还不知道如何实践微服务的Java程序员,这遍文章千万不要错过!
    14个Java并发容器,你用过几个?
    分布式事务解决方案,中间件 Seata 的设计原理详解
    一篇文章搞明白Integer、new Integer() 和 int 的概念与区别
    一线大厂面试官最喜欢问的15道Java多线程面试题
    70道阿里百度高频Java面试题(框架+JVM+多线程+算法+数据库)
    关于spark当中生成的RDD分区的设置情况。
  • 原文地址:https://www.cnblogs.com/momogua/p/8304363.html
Copyright © 2011-2022 走看看