如何解决将每个子函数的上下文绑定到父函数
function parentFn() {
API.greet();
}
parentFn.name = 'john';
const API = {
greet: function() {
console.log(`Hi there ${parentFunc.name}`); // prints out 'Hi there undefined'
}
};
parentFn()
有没有办法在不向内部函数添加参数的情况下获取API内部父函数的属性?
解决方法
有两种情况:
- 每个“子”函数只能有一个“父”。如果是这样,只需直接引用该特定父级:
parentFn.name
。 - 每个“子”函数都可以被多个其他函数调用。在这种情况下,您需要动态值的参数。
请注意,如果您不想声明显式参数,则可以使用每个 this
和方法都具有的隐式参数 function
。它通常指向 API
调用中的 API.greet()
对象,但您可以像 API.greet.call(parentFn)
一样更改它(尽管这有点奇怪)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。