JavaScript函数的属性和方法

ECMAScript中的函数是对象,因此函数也有属性和方法。每个函数都有两个属性:lengthprototype

length属性表示函数希望接收的命名参数的个数。

每个函数都包含两个非继承而来的方法:apply()call(),用途都是在特定的作用域中调用函数,实际上等于设置函数体内this对象的值。apply()方法接收两个参数:一个是在其中运行函数的作用域,另一个是参数数组。第二个可以是Array的实例,也可以是arguments对象。在使用call()方法时,传递给函数的参数必须逐个列举出来。

传递参数并不是apply()和call()的用武之地,它们真正强大的地方是能够扩充函数赖以运行的作用域。

window.color="red";
var o={color:"blue"};
function sayColor(){
  alert(this.color);
}
sayColor();//red
sayColor.call(this);//red
sayColor.call(window);//red
sayColor.call(o);//blue,此时函数体内的this对象指向o

使用call()和apply()来扩充作用域最大好处是对象不需要与方法有任何耦合关系

ECMAScript5还定义了bind()方法,会创建一个函数的实例,其this值会被绑定到传给bind()函数的值。

window.color="red";
var o={color:"blue"};

function sayColor(){
  alert(this.color);
}
var objectSaycolor=saycolor.bind(o);//返回一个函数实例
objectSayColor();//blue 



你可能感兴趣的:(前端,javaScript)