关于this

作者: 嘿菠萝 | 来源:发表于2017-01-17 21:48 被阅读23次
  • apply、call 有什么作用,什么区别
    • apply()方法可以在设置指定的this值和参数的情况下调用某个函数,参数以数组或类数组对象的形式存在
  • call()方法可以在设置指定的this值和一个或若干指定的参数即参数列表的前提下调用某个函数
  • call和apply的作用一样,不同之处是参数的形式不同,call接收参数列表,apply则接收参数数组

代码

1.以下代码输出什么

var john = { 
  firstName: "John" 
}
function func() { 
  alert(this.firstName + ": hi!")
}
john.sayHi = func
john.sayHi() 

输出:John:hi!
2.下面代码输出什么,为什么

func() 
function func() { 
  alert(this)
}

输出:window 因为该函数的执行环境是全局环境window
3.下面代码输出什么

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

输出:window document window
4.下面代码输出什么,why

var john = { 
  firstName: "John" 
}
function func() { 
  alert( this.firstName )
}
func.call(john) 

输出:John 因为函数实例func调用call方法,指定函数func内部的this指向john对象。
5.代码输出?

var john = { 
  firstName: "John",
  surname: "Smith"
}
function func(a, b) { 
  alert( this[a] + ' ' + this[b] )
}
func.call(john, 'firstName', 'surname') 

输出:John Smith
6.以下代码有什么问题,如何修改

var module= {
  bind: function(){
  //改成var that=this即可
    $btn.on('click', function(){
      console.log(this) //this指什么,此处this指的是$btn,$btn没有showMsg属性,会报错,不符合题意想要表示的是module
      this.showMsg();
    })
  },
  showMsg: function(){
    console.log('饥人谷');
  }
}

修改后:

var module= {
  bind: function(){
  var that=this;
    $btn.on('click', function(){
      console.log(this);
      that.showMsg();
    })
  },
  showMsg: function(){
    console.log('饥人谷');
  }
}

版权声明:本教程版权归本人与饥人谷所有,转载需说明来源

相关文章

  • 关于关于关于

    他们爱他们自己,不爱你 他们爱你是他们的母亲妻子女儿姐妹 他们不爱你 直到你死的时候,爱才产生,与遗忘同时 那也不...

  • 光明人生

    关于出生 关于成长 关于求学 关于青春期 关于恋爱 关于择业 关于婚姻 关于养生 关于家庭 关于人际 关于教子 关...

  • 「梦雅的简动力」打卡计时65天

    * 关于人生 * 关于梦想 * 关于方向 * 关于创业 * 关于投资 * 关于成败 * 关于个性 * 关于高度 *...

  • 关于

    关于两个人? 关于100步? 关于回头? 关于深情? 关于家庭? 关于孩子? 关于成长? 关于伤痛? 关于怀抱? ...

  • 2017新手妈妈年终总结

    关于购物 关于体重 关于减肥 关于纪念日 关于生活态度 关于上班 关于职场晋升加薪 关于睡眠 关于抱孩子 关于发型...

  • 2018-11-28

    关于流浪、关于随心、关于自由、关于世俗、关于规则、关于坦诚、关于真我、关于好奇心、关于对这整个世界的态度、关于整个...

  • 一首歌的时间

    认真的 想理出点思绪 关于今天关于明天 关于工作关于梦想 关于冬天关于夜晚 关于阳光关于浪花 关于木马关于窗花 关...

  • 最近的各种关于

    关于运动,关于中文阅读,关于英文听力,关于口算。 关于专注,关于目标,关于举家迁移。 关于对正确的过于执着,关于对...

  • 『关于』

    关于雨落,关于天晴; 关于入夜,关于天明; 关于齐眉,关于耳鬓; 关于缘定,关于今生。 (早安~诸君!)

  • 关于关于的关于

    关于这篇文章究竟该起个什么名字,想了很长时间也没答案,于是只能暂且搁置,等到写完之后再说。其实不仅是文章的名字,就...

网友评论

    本文标题:关于this

    本文链接:https://www.haomeiwen.com/subject/kkbmbttx.html