gpt4 book ai didi

javascript - 查找回调函数的父对象

转载 作者:塔克拉玛干 更新时间:2023-11-02 22:36:50 25 4
gpt4 key购买 nike

我有一个函数:

myObject.myFunction = function(callback){
callback();
}

和回调

randomObject.callBack = function(){
console.log(this);
}

如果我直接调用 randomObject.callBack(),我会在控制台中获得父对象。但是,如果我调用 myObject.myFunction(randomObject.callBack),它会记录一个 DOM 元素。

如何访问父对象?


注意

我不知道运行前回调父对象的名称。

最佳答案

对象的上下文(即 this 值)在函数运行时确定,不是在定义时确定。将 randomObject.callBack 传递给另一个函数不会发送上下文(randomObject 位);它只是发送函数。

大概是在 myFunction 调用它时设置了上下文。由于您没有明确提供上下文(例如使用 callapply),上下文将是 window 对象。

您可以通过在函数运行之前明确说明函数的上下文来更改它。您可以使用 bind 执行此操作方法:

myObject.myFunction(randomObject.callBack.bind(randomObject))

现在,当您在 myFunction 中调用 callback 时,randomObject 将被记录。

请注意,bind 相对较新;并非所有浏览器都支持它。我上面链接到的 MDN 页面有一些代码可以让它在所有浏览器中工作。

关于javascript - 查找回调函数的父对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8819874/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com