一、JavaScript中基本的数据类型
查看数据类型用:typeof 变量名
Javascript的数据类型有六种(ES6新增了第七种Symbol)
JS中的值有两种类型:原始类型(
Primitive
)、对象类型(Object
)。原始类型包括:
Undefined
、Null
、Boolean
、Number
和String
等五种。Undefined
类型和Null
类型的都只有一个值,即undefined
和null
;Boolean
类型有两个值:true
和false
;Number
类型的值有很多很多;String类型的值理论上有无数个。所有对象都有
valueOf()
和toString()
方法,它们继承自Object,当然也可能被子类重写
- 数值(
number
):整数和小数(比如1和3.14) - 字符串(
string
):字符组成的文本(比如”Hello World”) - 布尔值(
boolean
):true(真)和false(假)两个特定值 undefined
:表示 未定义 或不存在,即此处目前没有任何值null
:表示空缺,即此处应该有一个值,但目前为空- 对象(
object
):各种值组成的集合
通常,我们将数值、字符串、布尔值称为原始类型(primitive type)的值,即它们是最基本的数据类型,不能再细分了。而将对象称为合成类型(complex type)的值,因为一个对象往往是多个原始类型的值的合成,可以看作是一个存放各种值的容器。至于undefined和null,一般将它们看成两个特殊值
二、数据类型的转换
转换函数
toString()
转换为字符串,在JavaScript中所有数据类型都可以转换为string类型
1
2
3
4
5
6
7
8
9
10var n1 = 12;
var n2 = true;
var a = [1, 2, 3];
var o = {};
function f(){}
n1.toString(); //"12"
n2.toString(); //"true"
a.toString(); //"1,2,3"
o.toString(); //"[object Object]"
f.toString(); //"function f(){}"parseInt()
解析出一个string或者number类型的整数部分,如果没有可以转换的部分,则返回NaN(not a number
)
1
2
3
4
5
6var n1 = "12";
var n2 = "23hello";
var n3 = "hello";
parseInt(n1); //12
parseInt(n2); //23
parseInt(n3); //NaNparseFloat()
解析出一个string的浮点数部分,如果没有可以转换的部分,则返回NaN
(not a number)
1
2
3
4
5
6var n1 = "1.2.3";
var n2 = "1.2hello"
var n3 = "hello"
parseFloat(n1); //1.2
parseFloat(n2); //1.2
parseFloat(n3); //NaN
强制类型转换
Boolean(value)
- 把给定的值转换成Boolean
型1
2
3
4
5
6Boolean(123); //true
Boolean(""); //false
Boolean([]); //true
Boolean({}); //true
Boolean(null); //false
Boolean(undefined); //falseNumber(value)
-把给定的值转换成数字(可以是整数或浮点数)1
2
3
4
5
6
7
8Number("123"); //123
Number("123h"); //NaN
Number(true); //1
Number(false); //0
Number(undefined); //NaN
Number(null); //0
Number([]); //0
Number({}); //NaNString(value)
- 把给定的值转换成字符串1
2
3
4
5String(123); //"123"
String([1,2]); //"1,2"
String(undefined) //"undefined"
String(null) //"null"
String({}) //"[object Object]"
隐式转换
- 数字+字符串:数字转换为字符串
console.log(12+"12")
; //1212 - 数字+布尔值:true转换为1,false转换为0
console.log(12+true)
; //13 - 字符串+布尔值:布尔值转换为true或false
console.log("hello"+true)
; //hellotrue - 布尔值+布尔值
console.log(true+true)
; //2
- 数字+字符串:数字转换为字符串
- null和undefined
undefined
表示一种未知状态,声明了但没有初始化的变量,变量的值时一个未知状态。访问不存在的属性或对象window.xxx)方法没有明确返回值时,返回值是一个undefined.当对未声明的变量应用typeof运算符时,显示为undefined。null
表示尚未存在的对象,null是一个有特殊意义的值。可以为变量赋值为null,此时变量的值为“已知状态”(不是undefined),即null。(用来初始化变量,清除变量内容,释放内存)
`undefined==null` //结果为true,但含义不同。
`undefined===null` //false,两者类型不一致,前者为“undefined”,后者为“object”
总结一下==
运算的规则:(隐式转换)
undefined == null
,结果是true
。且它俩与所有其他值比较的结果都是false
。String == Boolean
,需要两个操作数同时转为Number
。String/Boolean == Number
,需要String/Boolean
转为Number
。Object == Primitive
,需要Object
转为Primitive
(具体通过valueOf
和toString
方法)