在接触每一门编程语言之前,首先明白我们程序设计要处理的是“数据”,而“数据”又用“数据类型”将其区分。
一.数据类型
Javascript是一种弱类型的脚本语言,它一共有6种数据类型,又被分为基础数据类型,特殊数据类型,复合数据类型。
1.基础数据类型:数值型,字符串型,布尔型
2.特殊数据类型:null,undefined(区别在于null需要显性赋值,而undefined表示没有赋值)
3.复合(引用)数据类型:Object(数组是特殊的对象)
注:理解基础数据类型和引用数据类型的区别。如函数参数传递
二. 包装类和基础数据类型的关系
对于基础数据类型,都有相应的包装类(Object对象)与之对应。
Number,String,Boolean
注:基础数据类型会在一定条件下转化成基础类型包装对象
var str =" 这是一个基础字符串";
var length = str.length();
// 当使用length()时,Javascript解释引擎会产生//一个str的临时String对象,执行完后临时对象清除
三.如何判断数据类型
(1) typeof(鸡肋)
仅可检测出以下6种数据类型:number, string, boolean, undefined, object, function(注意!)
alert( typeof ( null )); // 结果为object
alert( typeof (a)); // a未赋值,结果为undefined
因此判断基础数据类型可以如下:
function type(o) {
return (o === null ) ? ' null ' : typeof (o);
}
另外typeof存在浏览器兼容性问题,
见:http://www.w3help.org/zh-cn/causes/SD9028
(2)instanceof
但对于复合数据类型(除了function),则全部返回object,无法通过typeof判断
可使用instanceof检测某个对象是不是另一个对象的实例,注意instanceof的右操作数必须为对象:
function Animal() {};
function Pig() {};
Pig.prototype = new Animal();
alert( new Pig() instanceof Animal); // true
instanceof不适合用来检测一个对象本身的类型
(3)constructor
alert( " qqq " .constructor == String);
alert( true .constructor == Boolean);
var o = 1 ;
alert(o.constructor == Number);
alert({}.constructor == Object);
alert( 1 .constructor == Number); // 报错
o = null ; // or undefined
alert(o.constructor); // 报错
function isArray(o) {
return Object.prototype.toString.call(o) === ' [object Array] ' ;
}
call和apply的区别:
它们都是Function.prototype的方法(针对方法的),它是Javascript引擎内在实现的。
实际上这两个的作用几乎是相同的,要注意的地方是call(thisObj[,arg1[, arg2[,)中的arg参数可以是变量,而apply([thisObj[,argArray]])中的参数为数组集合
方法是借给另一个对象的调用去完成任务,原理上是方法执行时上下文对象改变了.
(5)总结
var _toS = Object.prototype.toString,
_types = {
' undefined ' : ' undefined ' ,
' number ' : ' number ' ,
' boolean ' : ' boolean ' ,
' string ' : ' string ' ,
' [object Function] ' : ' function ' ,
' [object RegExp] ' : ' regexp ' ,
' [object Array] ' : ' array ' ,
' [object Date] ' : ' date ' ,
' [object Error] ' : ' error '
};
function type(o) {
return _types[ typeof o] || _types[_toS.call(o)] || (o ? ' object ' : ' null ' );
}
另外总结各种类型转换的方法
alert(parseInt( 0.0000001 ));
这是由于超过一定精度js就会用科学计数法记录数字,例如:
alert(0.0000001);
会得到1e-7,而parseInt会自动把参数转换成字符串的,那实际上就是:
s = (0.0000001).toString();
alert(parseInt(s));
最后得到1就不奇怪了。
使用parseInt必须记住里面参数是转换成字符串再做转换的。
2.试着运行以下代码:
alert( typeof null ); // objectalert(null instanceof Object); //false
alert( typeof undefined); // undefined
alert( typeof NaN); // number
alert(isNaN(NaN)); // true
alert(NaN == NaN); // false
alert(NaN >= NaN); // false
alert(NaN != NaN); // true
// NaN的判断用isNaN()函数,NaN是唯一不等于自己的数
alert( null == undefined); // true
alert(undefined == null ); // true
// null和undefined互相==
alert( null === undefined); // false
alert(undefined === null ); // false
// null和undefined互相!==
alert( true == true ); // true
alert( false == false ); // true
alert( null == false ); // false
alert( null === false ); // false
alert( null >= undefined); // false
alert( null <= undefined); // false
alert( typeof Infinity); // number Infinity表示最大值
alert(Infinity > 10 ); // true
alert(Infinity > " abc " ); // false
alert(Infinity == NaN); // false