数据类型的转化

1 谷歌浏览器快速查看数据类型

字符串的颜色是黑色的,数据类型是蓝色的,布尔类型也是蓝色的,undefined和null是灰色的

2 转换成字符串类型

2.1 toString()

常规使用

var num1=123;
var res1=num1.toString();
console.log(res1);  //123
console.log(typeof res1);   //String
            
var num2=false;
var res2=false.toString();
console.log(res2);  //false
console.log(typeof res2);   //String

使用注意:
该方法不会影响到原变量,他会将转换的结果返回

var num3=123;
var res3=num3.toString();
console.log(typeof num3);   //number
console.log(typeof res3);   //String

数据类型调用toString()方法,可以携带一个参数,输出对应进制的值

var num=123;
var res=num.toString(10);   //十进制
            
var num4=10;
console.log(num4.toString(2));
console.log(num4.toString(8));
console.log(num4.toString(10));
console.log(num4.toString(16));

null和undefined没有toString()方法,调用则报错

var num5=undefined;
console.log(num5.toString());   //错误
            
var num6=null;
console.log(num6.toString());   //错误

2.2 string()

有些值没有toString()方法,此时可以使用String() 比如null和undefined
使用注意:
null和undefined就不会调用toString()方法,而是直接转成字符串

var n1=null;
var s1=String(n1);
console.log(s1);    //null
console.log(typeof s1); //String
            
var n2=undefined;
var s2=String(n2);
console.log(s2);    //undefined
console.log(typeof s2); //String

对于Number和Boolean类型的数据,String()相当于调用toString()方法

var n3=123;
var s3=String(n3);
console.log(s3);    //123
console.log(typeof s3); //String
            
var n4=false;
var s4=String(n4);
console.log(s4);    //fales
console.log(typeof s4); //String

2.3 拼接字符串方式

常规使用:
任何数据和+""链接到一起都会转换为字符串
内部实现原理和String()函数一样

var n1=10010;
var s1=n1+"100";
console.log(s1);    //10010100
console.log(typeof s1); //string

3 转换成数字类型

3.1 字符串转数字

如果是纯数字的字符串,则直接将其转换为数字

var s1="10010";
var r1=Number(sl);
console.log(r1);    //10010
console.log(typeof r1); //Number

如果字符串为空,或者是一个全是空格的字符串,则转换为0

var s2="";
var r2=Number(s2);
console.log(r2);    //0
console.log(typeof r2); //Number
            
var s3="         ";
var r3=Number(s3);
console.log(r3);    //0
console.log(typeof r3); //Number

如果字符串中由非数字内容,则转换为NaN

var s4="17MRX"
var r4=Number(s4);
console.log(r4);    //NaN

3.2 布尔转数字

true转成1,false转换成0

var b1=true;
var s1=Number(b1);
console.log(s1);    //1
            
var b2=false;
var s2=Number(b2);
console.log(s2);    //0

3.3 null和undefined转数字

null转数字为0

var s1=null;
var r1=Number(s1);
console.log(r1);    //0

undefined转数字为NaN

var s2=undefined;
var r2=Number(s2);
console.log(r2);    //NaN

3.4 parselnt()函数/parseFloat()函数———!重点!

使用意义:
Number()函数中无论字符串中是否存在有效整数,都会直接返回NaN
利用parselnt()和parseFloat()可以提取字符串中的有效整数和浮点数
parselnt()
有两个参数,第一个参数是要转换的字符串,第二个参数是要转换的进制
从第一位有效数字开始,直到遇到无效数字
如果第一位不是有效数字,直接返回NaN

var s1="10MRX";
var r1=parseInt(s1);
console.log(r1);    //10
            
var s2="200X300";
var r2=parseInt(s2);
console.log(r2);    //200
            
var s3="itLike001";
var r3=parseInt(s3);
console.log(r3);    //NaN
            
var s4="";
var r4=parseInt(s4);
console.log(r4);    //NaN

parseFloat()
不支持第二个参数,只能解析十进制数
如果解析的内容里只有整数,则只解析成整数
从第一位有效数字开始,直到遇到无效数字
如果第一位不是有效数字,直接返回NaN

var s5="10.5deg";
var r5=parseFloat(s5);
console.log(r5);    //10.5
            
var s6="10.5.6.7.8deg";
var r6=parseFloat(s6);
console.log(r6);    //10.5

使用注意:
对于非String使用parselnt()和parseFloat(),会将其先转换成String类型然后再操作

var s7=false;
var r7=parseInt(s7);
console.log(r7);    NaN

3.5 +和-0运算符

添加+号,不会修改数据的正负性
调用的是Number()

var s1="12306"
var r1=+s1;
console.log(r1);    //12306
console.log(typeof r1); //number
            
var s2="1.01"
var r2=+s2;
console.log(r2);    //1.01
console.log(typeof r2); //number
            
var s3="20rem"
var r3=+s3;
console.log(r3);    //NaN
console.log(typeof r3); //number
            
var s4="true"
var r4=+s4;
console.log(r4);    //1
console.log(typeof r4); //number
            
var s5="false"
var r5=+s5;
console.log(r5);    //0
console.log(typeof r5); //number

(-0)使用注意:

var s6="700";
console.log(+s6);   //700
console.log(-s6);   //-700
console.log(s6-0);  //700
console.log(typeof (s6-0)); //number

4 转换成布尔类型

Boolean(),0,""(空字符串)null undefined NaN 会转换成false 其他都会转换成true

console.log(Boolean(0));    //会转换成fales
console.log(Boolean(""));   //会转换成fales
console.log(Boolean(null)); //会转换成fales
console.log(Boolean(undefined));    //会转换成fales
console.log(Boolean(NaN));  //会转换成fales
console.log(Boolean(-1));   //会转换成true
            
var str="itLike";
var num1=123;
var num2=-1;
console.log(Boolean(str));  //会转换成true
console.log(Boolean(num1)); //会转换成true
console.log(Boolean(num2)); //会转换成true

你可能感兴趣的:(数据类型的转化)