我有一个侦听整个文档并记录击键的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开发人员文档,这个方法已经被废弃了。
我知道我可以简单地命名这个函数,但是有一个替代方案可以让我继续使用未命名的函数
发布于 2013-12-06 07:33:13
使用以下过程:
以下列方式使用:
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);
}));都是这样的人。
发布于 2013-12-02 19:15:39
使用另一个匿名函数作为包装器,将命名函数(callee )存储到原始函数中:
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);参考资料
https://stackoverflow.com/questions/19214977
复制相似问题