Array.prototype.slice.apply(arguments)和[].shift.call(arguments)的使用方法
一、实例
例1、arguments在JavaScript语法中是函数特有的一个对象属性(Arguments对象),用来引用调用该函数时传递的实际参数。
function test(){
//将参数转为一个数组
var args = Array.prototype.slice.apply(arguments);
alert(args);
}
arguments是一个类数组对象,包含着传入函数中的所有参数,而且可以使用length属性来确定传递进来多少个参数。直接调用arguments.slice()将返回一个"Object doesn't support this property or method"错误,因为arguments不是一个真正的数组。而以上代码调用Array.prototype.slice.apply(arguments)的意义就在于它能将函数的参数对象转化为一个真正的数组。另一方面也可推知Arguments对象和Array对象的亲缘关系。如果你在编写JavaScript的时候,常常碰到需要将arguments对象转成Array来处理的情形,这个技巧可以帮上忙。Array其他的原型方法也可以应用在arguments上,比如:
var arg0 = Array.prototype.shift.apply(arguments);
Array.prototype.slice.apply(document.getElementsByTagName('div'));
这个IE8及以下不支持
模拟一个js new一个对象的过程
function Person(){
this.name=1234;
// return {};
}
Person.prototype.getname=function(){
console.log(this.name);
}
function CreateObj(){
var fn=[].shift.call(arguments);
var args=arguments;
var obj=new Object();
var ret=fn.apply(obj,args);
obj.__proto__=fn.prototype;
return typeof ret ==='object'?ret:obj;
}
var a=CreateObj(Person);
console.log(a);
上述代码CreateObj 模拟了js new一个对象的过程,从该函数的代码中可以清晰的看到一个对象是怎么生成的,从这里我们也可以发现,如果构造函数显示的返回一个对象,new出来的对象就是该构造函数返回的对象,如果retrun其他类型的数据都会被new忽略。