强制类型转换

目录

强制类型转换    

一、强制类型转换 - String

二、强制类型转换 - Number

 三、其他进制的数字

 四、转化为Boolean


强制类型转换    

         - 指将一个数据类型强制转换为其他的数据类型
         - 类型转换主要指,将其他的数据类型,转换为
                     String Number Boolean

一、强制类型转换 - String

将其他的数据类型转换为String

方式一:
                    - 调用被转换数据类型的toString()方法
                    - 该方法不会影响到原变量,它会将转换的结果返回
                    - 但是注意:null 和 undefin

ed这两个值没有toString()方法

			var a = 123;
			
			//调用a的toString()方法
			//调用xxx的yyy()方法,就是xxx.yyy();
			a = a.toString();
			
			a = true;
			a = a.toString();
			
			a = null;
			// a = a.toString(); //报错
			
			a = undefined;
			// a = a.toString(); //报错

            ​console.log(typeof a);
			console.log(a);

 方法二:
                    - 调用String()函数,并将被转换的数据作为参数传递给函数
                    - 使用String()函数做强制类型转换时,
                        对于Number和Boolean实际上就是调用toString()方法
                        但是对于null和undefined,就不会调用toString()方法
                            它会将 null 直接转换为 "null"
                            将 undefined 直接转换为 "undefined"

​            var a = 123;
            //调用String()函数,来将a转换为字符串
			a = String(a);
			
			a = null;
			a = String(a);
			
			a = undefined;
			a = String(a);
			
			console.log(typeof a);
			console.log(a);

二、强制类型转换 - Number

转换方式一:
                        使用Number()函数
                            - 字符串 --> 数字
                                1.如果是纯数字字符串,则直接将其转换为数字
                                2.如果字符串中有非数字的内容,则转换为NaN
                                3.如果字符串是一个空串或是一个全是空格的字符串,则转换为0
                            - 布尔 --> 数字
                                true 转成1
                                false 转成0
                                
                            - Null --> 数字    0
                            
                            - undefined --> 数字     NaN

            var a = "123";
			
			a = "abc";
			
			a = "789abc"
			
			a = "";
			
			//调用Number()函数来将a转换为Number类型
			a = Number(a);

 转换方式二:
                    - 这种方式专门用来对付字符串
                    - parseInt() 把字符串转换为一个整数
                    - parseFloat() 把一个字符串转换为一个浮点数

            a = "123.789px456";
			//调用parseInt()函数将a转换为Number
			/* 
				parseInt()可以将一个字符串中的有效内容取出来,
				 然后转换为Number
			 */
			a = parseInt(a); //123
			
			/* 
				parseFloat()作用和parseInt()类似,不同的是它可以获得有效的小数
			 */
			a = "123.456.789";
			a = parseFloat(a); //123.456

 注意:

            /* 
                如果对非String使用parseInt()或parseFloat()
                 它会先将其转换为String,然后再操作
             */
            a = true;
            a = parseFloat(a); //undefined
            
            a = 198.23;
            a = parseInt(a); //198
            
            console.log(typeof a);
            console.log(a);

 三、其他进制的数字

在jS中,如果需要表示16进制的数字,则需要以0x开头
                            如果需要表示8进制的数字,则需要以0开头
                            如果需要表示2进制的数字,则需要以0b开头
                                但是不说所有的浏览器都支持

            //十六进制
			a = 0x10; //16
			a = 0xff; //255
			
			//八进制
			a = 070;
			
			//二进制
			//a = 0b10;
			
			//向"070"这种字符串,有些浏览器会当成8进制解析,有些会当成10进制解析
			a = "070";
			
			//可以在parseInt()中传递一个第二个参数,来指定数字的进制
			a = parseInt(a,10);
			
			console.log(typeof a);
			console.log(a);

//可以在parseInt()中传递一个第二个参数,来指定数字的进制

a = parseInt(a,10);

 四、转化为Boolean

                将其他的数据类型转化为Boolean
                 - 使用Boolean()函数
                     - 数字 ---> 布尔
                         - 除了0和NaN,其余的都是true
                         
                     - 字符串 ---> 布尔
                         - 除了空串,其余的都是true
                         
                     - null和 undefined都会转换为false
                     
                     - 对象也会转换为true

            var a = 123; //true
			a = -123; //true
			a = 0; //false
			a = Infinity; //true
			a = NaN; //false
			
			//调用Boolean()函数来将a转换为布尔值
			a = Boolean(a);
			
			a = "hello";
			
			a  = null; //false
			a = Boolean(a);
			
			a  = undefined; //false
			a = Boolean(a);
			
			console.log(typeof a);
			console.log(a);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值