提问人:Todd R 提问时间:3/30/2009 最后编辑:KARTHIKEYAN.ATodd R 更新时间:5/29/2023 访问量:386349
使用变量作为名称向 JavaScript 对象添加属性?
Add a property to a JavaScript object using a variable as the name?
问:
我正在使用 jQuery 将项目从 DOM 中拉出,并希望使用 DOM 元素在对象上设置属性。id
例
const obj = {}
jQuery(itemsFromDom).each(function() {
const element = jQuery(this)
const name = element.attr('id')
const value = element.attr('value')
// Here is the problem
obj.name = value
})
如果包含一个带有“myId”的元素,我希望有一个名为“myId”的属性。以上给了我.itemsFromDom
id
obj
name
如何使用 JavaScript 的变量命名对象的属性?
答:
您可以使用以下等效语法:
obj[name] = value
示例:
let obj = {};
obj["the_key"] = "the_value";
或具有 ES6 功能:
let key = "the_key";
let obj = {
[key]: "the_value",
};
在这两个示例中,将返回:console.log(obj)
{ the_key: 'the_value' }
评论
您甚至可以创建这样的对象列表
var feeTypeList = [];
$('#feeTypeTable > tbody > tr').each(function (i, el) {
var feeType = {};
var $ID = $(this).find("input[id^=txtFeeType]").attr('id');
feeType["feeTypeID"] = $('#ddlTerm').val();
feeType["feeTypeName"] = $('#ddlProgram').val();
feeType["feeTypeDescription"] = $('#ddlBatch').val();
feeTypeList.push(feeType);
});
使用 ECMAScript 2015,您可以直接在对象声明中使用括号表示法执行此操作:
var obj = {
[key]: value
}
其中可以是返回值的任何类型的表达式(例如变量):key
var obj = {
['hello']: 'World',
[x + 2]: 42,
[someObject.getId()]: someVar
}
评论
obj[name]=value
使用 lodash,您可以创建如下新对象 _.set:
obj = _.set({}, key, val);
或者,您可以像这样设置为现有对象:
var existingObj = { a: 1 };
_.set(existingObj, 'a', 5); // existingObj will be: { a: 5 }
如果你想在路径中使用 dot (“.”),你应该小心,因为 lodash 可以设置层次结构,例如:
_.set({}, "a.b.c", "d"); // { "a": { "b": { "c": "d" } } }
随着 ES2015 Object.assign 和计算属性名称的出现,OP 的代码可以归结为:
var obj = Object.assign.apply({}, $(itemsFromDom).map((i, el) => ({[el.id]: el.value})));
objectname.newProperty = value;
如果要动态地向对象添加字段,最简单的方法如下:
let params = [
{ key: "k1", value: 1 },
{ key: "k2", value: 2 },
{ key: "k3", value: 3 },
];
let data = {};
for (let i = 0; i < params.length; i++) {
data[params[i].key] = params[i].value;
}
console.log(data); // -> { k1: 1, k2: 2, k3: 3 }
首先,我们需要将 key 定义为变量,然后我们需要将 key 赋值为 object.,例如
var data = {key:'dynamic_key',value:'dynamic_value'}
var key = data.key;
var obj = { [key]: data.value}
console.log(obj)
有两种不同的表示法可用于访问对象属性
- 点表示法:myObj.prop1
- 括号表示法:myObj[“prop1”]
点表示法既快速又简单,但必须显式使用实际属性名称。没有替换、变量等。
括号表示法是开放式的。它使用字符串,但您可以使用任何合法的 js 代码生成字符串。您可以将字符串指定为文字(尽管在这种情况下,点表示法更容易阅读)或使用变量或以某种方式计算。
因此,这些都将名为 prop1 的 myObj 属性设置为值 Hello:
// quick easy-on-the-eye dot notation
myObj.prop1 = "Hello";
// brackets+literal
myObj["prop1"] = "Hello";
// using a variable
var x = "prop1";
myObj[x] = "Hello";
// calculate the accessor string in some weird way
var numList = [0,1,2];
myObj[ "prop" + numList[1] ] = "Hello";
陷阱:
myObj.[xxxx] = "Hello"; // wrong: mixed notations, syntax fail
myObj[prop1] = "Hello"; // wrong: this expects a variable called prop1
TL的;dnr:如果要计算或引用密钥,则必须使用括号表示法。如果显式使用该键,则对简单的明文代码使用点表示法。
注意:还有其他一些好的和正确的答案,但我个人发现它们有点简短,因为对 JS 即时古怪的熟悉程度很低。这可能对某些人有用。
const data = [{
name: 'BMW',
value: '25641'
}, {
name: 'Apple',
value: '45876'
},
{
name: 'Benz',
value: '65784'
},
{
name: 'Toyota',
value: '254'
}
]
const obj = {
carsList: [{
name: 'Ford',
value: '47563'
}, {
name: 'Toyota',
value: '254'
}],
pastriesList: [],
fruitsList: [{
name: 'Apple',
value: '45876'
}, {
name: 'Pineapple',
value: '84523'
}]
}
let keys = Object.keys(obj);
result = {};
for(key of keys){
let a = [...data,...obj[key]];
result[key] = a;
}
如果你有对象,你可以创建键数组,而不是映射,并从以前的对象键和值创建新对象。
Object.keys(myObject)
.map(el =>{
const obj = {};
obj[el]=myObject[el].code;
console.log(obj);
});
ajavascript 有两种类型的注释用于获取 javascript 对象属性:
Obj = {};
1) (.) 注释,例如。Obj.id 仅当对象已具有名称为“id”的属性时,这才有效
2) ([]) 注释,例如 .Obj[id] 这里如果对象没有任何名称为 'id' 的属性,它将创建一个名称为 'id' 的新属性。
所以对于下面的例子:
当您写入 Obj[name] 时,将始终创建一个新属性。 如果属性已存在同名属性,它将覆盖它。
const obj = {}
jQuery(itemsFromDom).each(function() {
const element = jQuery(this)
const name = element.attr('id')
const value = element.attr('value')
// This will work
obj[name]= value;
})
与主题相关,但不是专门针对jquery的。我在 ec6 react 项目中使用了它,也许可以帮助某人:
this.setState({ [`${name}`]: value}, () => {
console.log("State updated: ", JSON.stringify(this.state[name]));
});
PS:请注意引号字符。
评论
{ [
]: value}
{ [name]: value}
上一个:按值对对象属性进行排序
评论