1、Javascript中的语言特性:
1.1、动态性:
动态性是指,在一个Javascript对象中,要为一个属性赋值,我们不必事先创建一个字段,只需要在使用的时候做赋值操作即可
// 定义一个对象
var obj = new Object();
//动态创建属性
obj.name = "Object1";
// 动态创建函数getName, 函数也是一个
obj.getName = function(){
return "name: Object1";
}
alert(obj.getName());
1.2、弱类型:
// 数据类型无需在声明时指定,解释器会根据上下文对变量进行实例化
var a = "Hello";
a = 1 + 2;
a = 3.14;
a = new Object();
2、Javascript中的数据类型:
2.1、基本数据类型:
基本的数据类型包括字符串,整型,浮点型,布尔值,可以通过typeof运算符查看某个变量的真正类型:
var data = "arthinking"; // 字符串
var data2 = 1; // 整型
var data3 = 1.2; // 浮点型
var data4 = true; //布尔值
// typeof 运算符
alert(typeof data);
2.2、对象类型:
包括对象(Object),数组(Array)和函数(function)
//对象
var obj = new Object();
obj.name = "arthinking";
//数组
var arr = new Array("1","2","3");
//函数
var printName = function(){
alert("arthinking");
}
其中的Array和Object使用typeof操作符获取到的类型都为object类型。
2.3、Object和基本数据类型之间的转换
类似于Java中的装箱与拆箱,Javascript中的的基本数据类型和对象之间在某些运算条件下也会自动进行转换,如下面:
if(new Boolean(false)){
alert("boolean");
}
这里的Boolean对象也会先转换为boolean的基本类型。(注意:在对象转换为基本数据类型时,如果该对象非空,都会被转换为true,如上面的也会自动转换为true)。
为此,我们可以这样判断对象时候为空,并为空的情况下进行创建:
var user = new Object();
if(user.username){
alert(user.username);
} else {
user.username = "arthinking";
}
2.4、Javascript中的数据类型判断
在某些时候,我们在使用某个变量时,需要确定其类型是不是符合我们需要的,可以这样判断:
2.4.1使用typeof:
使用typeof操作符进行判断:
//数据类型的判断
if(typeof handle == "function"){}
2.4.2使用instanceof
有些情况下,如数组和对象,如果使用typeof操作符,都会被判断成object类型,这样就符合我们的编程需求了,为此,我们可以使用instanceof操作符:
var obj = {};
var arr = new Array("1","2","3");
if(obj instanceof Array){}
if(arr instanceof Array){}