arguments.callee的替代方案

时间:2013-10-06 23:05:01

标签: javascript reflection arguments deprecated porting

我有一个 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,此方法已被弃用。

我知道我可以简单地命名这个功能,但是有一个替代方案可以让我继续使用未命名的功能吗?

2 个答案:

答案 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);

<强>参考