JavaScript 中的 this/new、apply/cal

2017-04-08  本文已影响15人  KrisLeeSH

this

当使用在函数中时,this指代当前的对象,也就是调用了函数的对象。如果在一个对象上使用点或者方括号来访问属性或方法,这个对象就成了this。如果并没有使用“点”运算符调用某个对象,那么this将指向全局对象(global object)。

new

它和this密切相关。它的作用是创建一个崭新的空对象,然后使用指向那个对象的this调用特定的函数。注意,含有this的特定函数不会返回任何值,只会修改this对象本身。new关键字将生成的this对象返回给调用方,而被new调用的函数成为构造函数。习惯的做法是将这些函数的首字母大写,这样用new调用他们的时候就容易识别了。

apply

第一个参数被当作函数内部中的this使用,第二个参数是一个函数参数的数组。如,

function Person(firstName, lastName) {
  this.firstName = firstName;
  this.lastName = lastName;
}

var me = { firstName: "Kris", lastName: "Lee"};

Person.apply(me, ["John"]); // me是 {firstName: "John", lastName: undefined}

call

同apply相似,不同的是参数不以数组的方式作为call的第二个参数:

var me = { firstName: "Kris", lastName: "Lee"};
Person.call(me, "John", "Snow");  // me是 {firstName: "John", lastName: "Snow"}

bind

var a = function (arg1, arg2) {
  // function content
};

var b = a.bind(this, 12);
// equals
var b = function () {
  var arguments = [12]
}
上一篇 下一篇

猜你喜欢

热点阅读