JavaScript 方括号作为变量值

JavaScript Square Bracket as Variable Value

出于 CSRF 目的,我需要使用 [tokenName] 在以下函数中将变量值作为名称传递。它在 Firefox 和 Chrome 中运行良好,但在 IE11 中运行不正常。

我得到的错误是:预期标识符、字符串或数字 在 [tokenName] 行上。

想法?

    $('#container').on('click','#delete',function(e) {
        e.preventDefault();
        var button = $(this),
            form = button.closest('form'),
            id = button.attr('data-id'),
            verify = button.attr('data-verify'),
            tokenName = form.find('input[name=token_name]').val(),
            tokenHash = form.find('input[name=' + tokenName + ']').val();

        // delete user via ajax
        $.post(form.attr('action'), {
                "id" : id,
                "object" : verify,
                [tokenName] : tokenHash
            }, function(data) {

            // do stuff


        }, "json");

    });

您可以随时回退到旧语法:

  var options = {
      "id" : id,
      "object" : verify,
  };

  options[tokenName] = tokenHash;

  $.post(form.attr('action'), options, function(data) {
      //...
  });

在 Javascript 对象文字中使用变量作为键是 ES6 特性

[tokenName] : tokenHash IE 11 不支持此功能

点击here查看各种js引擎的ES兼容性表