jQuery将键值对添加到空对象

时间:2014-09-15 19:03:05

标签: javascript jquery arrays object

在jQuery中,我可以为元素添加多个属性,如此...

var input = $('<input/>').attr({ type : 'text', value : 'New Value'});

我的问题是,如何使用像这样的变量实现这一目标......

var input = $('<input/>').attr(inputAttr);

我假设inputAttr应该是一个对象,我可以添加到该对象。我一定是弄错了。这是我实现这一目标的众多尝试之一。

var inputAttr = {};
inputAttr.add({ type: 'text' });
inputAttr.add({ value : 'New Value' });

我也试过这样......

var inputAttr = {};
inputAttr.add('type: text');
inputAttr.add('value : New Value');

我想也许inputAttr应该是一个数组,它似乎输出一个正确的字符串,但不知道如何使它成为一个对象(我认为它应该是这样)。

var inputAttr = [];
inputAttr.push('type: text');
inputAttr.push('value : New Value');

// Then added object brackets like so
var input = $('<input/>').attr({inputAttr});

任何帮助将不胜感激! 提前谢谢!

2 个答案:

答案 0 :(得分:8)

只需按名称访问对象属性。它不是一个数组。

var inputAttr = {};
inputAttr.type = 'text';
inputAttr.value = 'New Value';

var input = $('<input/>').attr(inputAttr);

如果你想通过键间接访问它们,它就像一本字典:

var inputAttr = {};
inputAttr["type"] = 'text';
inputAttr["value"] = 'New Value';

答案 1 :(得分:7)

object的键值可以这样设置:

var inputAttr = {};
inputAttr.type = 'text';
inputAttr.value = 'New Value';

Fiddle