call和apply动态改变this


javascript OOP中,我们经常会这样定义:

function cat(){
}
cat.prototype={
food:"fish",
say: function(){
alert("I love "+this.food);
}
}

var blackCat = new cat;
blackCat.say();

但是如果我们有一个对象whiteDog = {food:”bone”},我们不想对它重新定义say方法,那么我们可以通过call或apply用blackCat的say方法:blackCat.say.call(whiteDog);

所以,可以看出call和apply是为了动态改变this而出现的,当一个object没有某个方法,但是其他的有,我们可以借助call或apply用其它对象的方法来操作。

方法对象中的call方法和apply方法的区别:

call(object,param1,param2,param3) === apply(object,[param1,param2,param3])

2. selector不是只有jQuery等框架才有,现在的浏览器就内置selector,内置有document.querySelector、document.querySelectorAll等。

3. hasOwnProperty方法不检索prototype上的属性。

4. 赋值语句中写或判断是如果前面的取到为null、undefined、false则取下一个,如果全都取不到则取最后一个。

var a=null,b=1;
var c = a||b;//c=b=1
var a=null,b=undefined;
var c = a||b;//c=b=undefined
var a="xxx",b=undefined;
var c = a||b;//c=a="xxx"

6 responses on “call和apply动态改变this

  1. 我拍完之后也会拿手机拍,然后发朋友圈,虽说相机拍得不错,但是相机里面的照片传手机会比较麻烦,所以看到这个也没什么大惊小怪的,然后这张照片拿这么多相机唯一的可能是帮别人拿的,看图片只要那个定焦是自己的,70-200估计别人的,还有微单,说了这么多,我也不知

  2. 我拍完之后也会拿手机拍,然后发朋友圈,虽说相机拍得不错,但是相机里面的照片传手机会比较麻烦,所以看到这个也没什么大惊小怪的,然后这张照片拿这么多相机唯一的可能是帮别人拿的,看图片只要那个定焦是自己的,70-200估计别人的,还有微单,说了这么多,我也不知

发表评论

电子邮件地址不会被公开。 必填项已用*标注

您可以使用这些HTML标签和属性: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>