面试系列(三)js中 this,apply ,call和bind

4 篇文章 0 订阅

一.函数调用的四种方法

(1)作为一个函数调用

    var name = "windowsName";
    function a() {
        var name = "Cherry";

        console.log(this.name);          // windowsName

        console.log("inner:" + this);    // inner: Window
    }
    a();
    console.log("outer:" + this)         // outer: Window

(2)函数作为方法调用

    var name = "windowsName";
    var a = {
        name: "Cherry",
        fn : function () {
            console.log(this.name);      // Cherry
        }
    }
    a.fn();

(3)使用构造函数调用函数

// 构造函数:
function myFunction(arg1, arg2) {
    this.firstName = arg1;
    this.lastName  = arg2;
}

// This    creates a new object
var a = new myFunction("Li","Cherry");
a.lastName; 

(4)作为函数方法调用函数

    var name = "windowsName";

    function fn() {
        var name = 'Cherry';
        innerFunction();
        function innerFunction() {
            console.log(this.name);      // windowsName
        }
    }

    fn()

二.this的指向

     this永远指向最后调用它的那个对象,   this永远指向最后调用它的那个对象

     函数的作用域是在函数定义的时候决定的,函数的作用域是在函数定义的时候决定的

    函数的作用域是在函数定义的时候决定的,函数的作用域是在函数定义的时候决定的

    这三句话请朗读并背诵

三.改变this指向的方法

     改变this指向的方法有三种

     (1)在函数内部使用let self = this

       (2)   使用箭头函数

      (3)使用new实例化函数

       (4)   使用apply,call,bind

这是简单介绍一下 apply ,call ,bind 和他们之间的区别

apply:   apply() 方法调用一个函数, 其具有一个指定的this值,以及作为一个数组(或类似数组的对象)提供的参数

call: call() 方法使用一个指定的 this 值和单独给出的一个或多个参数来调用一个函数。

bind: bind() 方法创建一个新的函数,在 bind() 被调用时,这个新函数的 this 被指定为 bind() 的第一个参数,而其余参数将作为新函数的参数,供调用时使用。

这里有一个面试常常考的点,实现一个apply 或 call 或bind函数。

这里附上一个链接:https://juejin.im/post/6844903476477034510这篇文章详细说了实现的思路。

上一篇:面试系列(二)js的基础知识

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值