this

1.apply、call 有什么作用,什么区别

函数调用有三种形式:
func(p1,p2)
obj.childrend.method(p1,p2)
func.call(context,p1,p2)
第三种形式才是正常调用形式,call就是调用函数的一种形式,call的第一个参数(context)很重要,context就是函数执行的上下文环境,也就是this。call一个函数时传入的context是什么,函数的this就指向什么。如果传入的context是null或者undefined,那么context默认就是window(严格模式下默认 context 是 undefined)
apply也是调用函数的一种形式,和call不同之处在于apply调用是只能传入两个参数.apply(context,参数数组),.call(context,p1,p2)可传入多个参数。


2.下面代码输出什么,为什么
func() 

function func() { 
  alert(this)
}

func()等价于func.call()
输出的内容是window全局对象


3.以下代码输出什么?
var john = { 
  firstName: "John" 
}
function func() { 
  alert(this.firstName + ": hi!")
}
john.sayHi = func
john.sayHi() 

john.sayHi()可写成john.sayHi.call(john),这里call传入的context是john这个对象,所以this.firstNme的值是'John',打印结果是John :hi


4.下面代码输出什么
function fn0(){
    function fn(){
        console.log(this);
    }
    fn();
}

fn0();

document.addEventListener('click', function(e){
    console.log(this);
    setTimeout(function(){
        console.log(this);
    }, 200);
}, false);

fn0()执行后打印的this是全局对象window,因为fn0()执行的时候是window在调用。
事件绑定后第一次打印的this是触发该事件的dom对象,第二次打印的this是window全局对象,因为setTimeout和setInterval执行时也是window全局对象在调用。


5.下面代码输出什么,为什么
var john = { 
  firstName: "John" 
}

function func() { 
  alert( this.firstName )
}
func.call(john) 

.call(context)这里context代表传入的函数执行的上下文环境,这里传入的是john对象,所以func.call(john)打印的内容是John


6.代码输出?
var john = { 
  firstName: "John",
  surname: "Smith"
}

function func(a, b) { 
  alert( this[a] + ' ' + this[b] )
}
func.call(john, 'firstName', 'surname') 

func.call(context,参数1,参数2) 这里函数执行时传入的this是john对象,所以打印的内容是John Smith


7.以下代码有什么问题,如何修改
var module= {
  bind: function(){
    $btn.on('click', function(){
      console.log(this) //this指什么
      this.showMsg();
    })
  },
  
  showMsg: function(){
    console.log('饥人谷');
  }
}

console.log(this)打印的内容是触发绑定事件的DOM对象,这里是$btn触发所以this指向$btn。代码中执行this.showMsg()会报错,因为this指向$btn后,$btn上没有.showMsg()这个方法,.showMsg()方法在module对象上。修改代码如下

var module= {
  bind: function(){
  var cur=this//申明cur,将this赋值给cur,这里this指向module对象
    $btn.on('click', function(){
      console.log(this) //绑定事件后this在这里指向$btn
      cur.showMsg();//cur指向module对象
    })
  },

  showMsg: function(){
    console.log('饥人谷');
  }
}

8.下面代码输出什么
var length = 3;
function fa() {
  console.log(this.length);
}
var obj = {
  length: 2,
  doSome: function (fn) {
    fn();
    arguments[0]();
  }
}
obj.doSome(fa)

obj.doSome(fa)等价于
obj.doSome.call(obj,fa),注意虽然这里this指向obj,但参数2位置上是fa函数,doSome定义传入参数并执行'fn()',所以参数2位置上的fa()要执行,fa()等价于fa.call(null),因为null所以this指向全局对象window,因为length=3实在全局对象下声明的,所以第一次打印结果为3.
执行arguments[0]()时,等价于arguments[0].call(arguments)由于arguments是类数组对象,相当于传入的第0个参数执行,这里传入的第0个参数是fa,所以等价于fa.call(arguments),这时候this指向arguments类数组对象,arguments.length=1,因为只有1个参数fa(),所以第二次打印1


9.下面代码输出什么? why
obj = {
  go: function() { alert(this) }
}
obj.go(); 
(obj.go)(); 
(a = obj.go)(); 
(0 || obj.go)(); 

1.obj.go()等价于obj.go.call(obj) this指向obj,所以打印obj对象
2.(obj.go)()相当于obj对象上的go属性立即执行,go是个函数所以等价于obj.go.call(obj)打印obj对象
3.obj.go赋值给全局对象a,等价于a=function(){alert(this)},a()---->a.call(),这里打印的是window全局对象
4.注意这里执行或运算函数时,是全局对象window在调用,因为第一个0不成立所以等价于obj.go.call()。所以打印window全局对象

****本文版权归本人和饥人谷所有,转载请注明来源。****

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容

  • 简答题 1.apply、call 有什么作用,什么区别 call apply,调用一个函数,传入函数执行上下文及参...
    GarenWang阅读 544评论 1 4
  • 问答 apply、call 有什么作用,什么区别? 在介绍apply和call之前,我们先来看看this,this...
    小木子2016阅读 270评论 0 0
  • javascript里的this指针逻辑上的概念也是实例化对象,这一点和java语言里的this指针是一致的,但是...
    天外来人阅读 459评论 0 0
  • 与其他语言相比,函数的this关键字在JavaScript中的表现略有不同,此外,在严格模式和非严格模式之间也会有...
    codingC阅读 565评论 0 0
  • 昨天一直在赶非文学翻译的presentation ppt,差不多十二点才睡觉,躺在床上时又过了一下要点评的内容,辗...
    敏哥儿阅读 719评论 0 1