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兼容性表
出于 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 不支持此功能