【问题标题】:Confusion over how to use explicit binding methods关于如何使用显式绑定方法的困惑
【发布时间】:2021-01-29 20:37:22
【问题描述】:

不确定是否有人可以帮助我解决这个问题,但我知道可以使用 bind、apply 和 call 方法使函数中的 this 关键字引用您选择的特定对象。但是,我仍然有点困惑,因为在某些情况下,当我期望一个特定的结果时,我得到了另一个。这是我拥有的对象的示例:

var obj = {
    fullName: "John Doe",
    person: {
        sayHi: function() {
            console.log("This person's name is " + this.fullName)
        }
    }
}

我知道调用 obj.person.sayHi() 方法会导致人名未定义,因为隐式对象是人。

我也知道您可以通过使用 bind 调用方法来引用正确的对象,或者像这样调用:

obj.person.sayHi.call(obj)obj.person.sayHi.bind(obj)()

为了显示此人的姓名。但是,我也希望可以将绑定直接附加到对象内部的函数表达式,如下所示:

var obj = {
    fullName: "John Doe",
    person: {
        sayHi: function() {
            console.log("This person's name is " + this.fullName)
        }.bind(obj)
    }
}

然后像这样调用函数:obj.person.sayHi(),你会得到相同的结果,但是在这种情况下,this 关键字指的是全局对象。但是,如果我执行以下操作:

let sayHi = function() {
    console.log("This person's name is " + this.fullName)
}

sayHi.bind(obj)();

然后我得到了想要的结果。谁能解释为什么第二种方法不是有效的?提前致谢。

【问题讨论】:

    标签: javascript object binding this


    【解决方案1】:

    这是无效的:

    var obj = {
        fullName: "Harry Potter",
        person: {
            sayHi: function() {
                console.log("This person's name is " + this.fullName)
            }.bind(obj) // obj is not defined here yet, obj is undefined
        }
    }
    

    因为obj 在调用bind 时未定义。 obj 确实是在声明结束时定义的,但是在 obj 的声明中有一种循环引用,当调用 bind(obj) 时,它很可能具有 undefined 的值。

    另一种明确查看这一点的方法是执行以下操作:

    var obj = {
        fullName: "Harry Potter",
        person: {
            sayHi: function() {
                console.log("This person's name is " + this.fullName)
            }.bind(obj) // obj is not defined here yet, obj is undefined
        },
        ref: obj
    }
    console.log(obj.ref); // undefined

    【讨论】:

      【解决方案2】:

      嗨@Nikos 感谢您的回复。我想我现在走上了正轨。我只是想知道一件事。如果我执行以下操作:

      function dummy(fn) {return fn();}
      var obj = {
          fullName: "Harry Potter",
          person: {
              sayHi: function() {
                  dummy(function() {
                      console.log("This person's name is " + this.fullName);
                      console
                  }.bind(obj))
              }
          }
      }
      

      然后调用函数obj.person.sayHi()就会产生想要的效果。这是否以某种方式将函数表达式从对象定义中取出?抱歉,我尝试将此作为评论发布,但我不知道如何将其转换为正确的格式

      【讨论】:

      • 使用 dummy 函数会延迟到 obj 的绑定,以便在调用函数时,即在实际的 obj 声明之后。实际上,任何在 obj 被声明后绑定到 obj 的方法(而不是在声明时)都可以工作
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2013-09-09
      • 2015-08-04
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-10-05
      • 1970-01-01
      相关资源
      最近更新 更多