关于this的一些学习笔记

Posted ReedSun

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于this的一些学习笔记相关的知识,希望对你有一定的参考价值。

关于可以指定this的apply()、call()函数

  • apply()call()函数都可以 指定this值和参数值的情况下调用某个函数。
  • call()apply()的作用一样,区别在于提供给原函数的参数的方式不一样
    • apply()函数只接受两个参数,提供给原函数的参数以数组或类数组对象的形式存在
    • call()接收无限个参数, 第二个参数及其后面的参数就是提供给原函数的参数。

例子

通过例子,我觉得可以更好的理解this

第一个例子:此时this是john对象

var john =  
  firstName: "John" 

function func()  
  alert(this.firstName + ": hi!")

john.sayHi = func
john.sayHi()     //  弹出John:hi!

第二个例子:this是window

func()   //  弹出window对象

function func()  
  alert(this)
  • 因为在函数func()被直接调用时,this绑定到全局对象。在浏览器中,window 就是该全局对象

第三个例子:监听函数的this是被监听的元素

function fn0()
    function fn()
        console.log(this);
    
    fn();


fn0();  //  输出window对象


document.addEventListener('click', function(e)
    console.log(this);   //  输出document对象
    setTimeout(function()
        console.log(this);   //  输出window对象
    , 200);
, false);

第四个例子: 使用call修改this

var john =  
  firstName: "John" 


function func()  
  alert( this.firstName ) 

func.call(john)    //  弹出John
  • func()函数通过call()函数调用,此时this为John对象,john.firstName存在,输出”John”

第五个例子:使用call修改this

var john =  
  firstName: "John",
  surname: "Smith"


function func(a, b)  
  alert( this[a] + ' ' + this[b] )

func.call(john, 'firstName', 'surname')   //  输出 John Smith

以上是关于关于this的一些学习笔记的主要内容,如果未能解决你的问题,请参考以下文章

jQuery学习笔记:this相关问题及选择器

jQuery学习笔记:this相关问题及选择器

关于框架的一些学习笔记

关于guava 集合的一些学习笔记

关于cookie的一些学习笔记

《学习opencv》笔记——关于一些画图的函数