標籤:
1 typeof 和 instanceof
var array = [];
平時如果判斷一個對象是否為數組,可能你會用 typeof array,但是輸出為“object”。
typeof 一般只能返回如下幾個結果:
number,boolean,string,function,object,undefined。
對於 Array,Null 等特殊對象使用 typeof 一律返回 object。
所以你因該 :
array instanceof Array 輸出為 true;
當然 :
array instanceof Object 輸出也為 true;
因為 Array本身就是對象的子集。
這也是為什麼轉化類數組為數組的方法為:
Array.prototype.slice.call(arguments,0);
當然:
[].slice.call(arguments,0);也是可以的。
2 call 和 apply
上面既提到call的用法,那麼我就順便說一下call和apply的用法。
apply:
Function.apply(obj,args)方法能接收兩個參數,
obj:這個對象將代替Function類裡this對象
args:這個是數組,它將作為參數傳給Function(args-->arguments, 指的是函數中的參數
執行個體:
function people(age,sex){
this.age=age;
this.sex=sex;
};
function adult(age,sex){
people.apply(this,arguments)
};
var jack = new adult(18,‘man‘);console.log(jack.age+":"+jack.sex)
輸出為 18:man;
其實看到這段代碼就知道apply怎麼用了吧。
其實apply 說到底就是為了使的一個對象可以使用不屬於自己的方法,例如:jack.people(),這樣肯定不行的!
網上看到的關於apply一些延伸的方法:
求最大值:var array = [1,2,3];Math.max.apply(null,array); // 3
求最小值:var array = [1,2,3];Math.min.apply(null,array); // 1
合并數組:var array1 = [1,2,3],array2 = [4,5,6];Array.prototype.push.apply(array1,array2);
其實就是利用apply的特性將數組轉化為參數列表[param1[,param2[,…[,paramN]]]],去處理這些問題。
前兩個方法是因為不接受數組,所以這樣處理。
第三個合并數組有很多其他方法,可以不這樣用。
call:
Function.call(obj,[param1[,param2[,…[,paramN]]]])
其實這裡的參數列表 [param1[,param2[,…[,paramN]]]]= arguments;只是call 必須將參數列出來;
如果運用上面的例子,輸出的結果是一樣一樣的!
如果還有其他延伸的有意思的方法給以發評論告訴我!
apply與call簡單用法以及判斷數組的坑