我有一个 EventListener ,它可以侦听整个文档并记录击键,但我想在满足某些条件时删除此监听器。
以下是我的代码片段:
document.addEventListener('keyup', function(e) {
var letter_entered = String.fromCharCode(e.keyCode).toLowerCase();
player.makeGuess(letter_entered);
if(player.win_status === true || player.lose_status === true) {
document.removeEventListener('keyup', arguments.callee, false);
}
});
这样可行,但根据Mozilla Developer Docs,此方法已被弃用。
我知道我可以简单地命名这个功能,但是有一个替代方案可以让我继续使用未命名的功能吗?
答案 0 :(得分:9)
使用以下过程:
使用它:
var foo = function(e)
{
"use strict";
console.log(e);
document.removeEventListener('keyup', foo, false);
}
document.addEventListener('keyup', foo);
您可以使用y
组合器轻松解决此问题:
function y(f) {
return function () {
return f.bind(null, y(f)).apply(this, arguments);
};
}
现在您可以按如下方式重写代码:
document.addEventListener("keyup", y(function (callee, e) {
player.makeGuess(String.fromCharCode(e.keyCode).toLowerCase());
if (player.win_status || player.lose_status) document
.removeEventListener("keyup", callee);
}));
那是所有人。
答案 1 :(得分:3)
使用另一个匿名函数作为包装器将命名函数(callee shim)存储到原始函数中:
document.addEventListener('keyup', (function(e)
{
var aFunction = function()
{
var letter_entered = String.fromCharCode(e.keyCode).toLowerCase();
player.makeGuess(letter_entered);
};
if(player.win_status === true || player.lose_status === true)
{
document.removeEventListener('keyup', window, false);
}
else
{
aFunction();
}
}
), false);
<强>参考强>