javascript - 如何从对象内部获取属性名称以创建新的属性名称?

标签 javascript object properties

我知道还有一些关于这个主题的其他帖子,但它们似乎没有解决我的问题:link .

我希望能够动态获取对象中特定属性的名称,以便我可以使用它在另一个对象中创建新的属性名称。例如,我将从 foo 中获取属性名称 startMin(如下面的代码所示),然后在其末尾添加文本(如 startMin + Suffix ) 创建一个新的属性名称。我怎样才能做到这一点?

相关说明:我已经弄清楚如何使用 foo[Object.keys(foo)[0]] 获取属性值。尽管这可行,但我不确定为什么 Object.keys 在这种情况下获取属性值,因为我发现的示例表明 Object.keys 应该获取属性名称而不是属性值。我很想知道为什么?

我已经包含了 pusdo 代码 foo[Object.returnObjectName(foo)[0]] + 'Cal' 我希望动态创建名称的地方。这当然行不通。

var foo = {
  startMin: 1000
};

var fooResults = {
  // the property name here is psudo code 
  foo[Object.returnObjectName(foo)[0]] + 'Cal': foo[Object.keys(foo)[0]]
}

console.log('startMinCal: ' + fooResults.startMinCal) // This should log "1000" but won't until the object name inside `fooResults` is created correctly.

// 
console.log(Object.keys(foo)); // I believe this gests the property name, but it exists inside an array, so won't work as a new property name 
console.log(foo[Object.keys(foo)[0]]); // this gets the property value as expected.

更新的工作代码:

var foo = {
  startMin: 1000,
  startMax: 3000
};

var fooResults = {
  [Object.keys(foo)[0] + 'Cal']: foo[Object.keys(foo)[0]],
  [Object.keys(foo)[1] + 'Cal']: foo[Object.keys(foo)[1]]
}

console.log('startMinCal: ' + fooResults.startMinCal)
console.log('startMaxCal: ' + fooResults.startMaxCal)

最佳答案

var foo = {
  startMin: 1000
};


//Object.keys return all the keys in an object passed as parameter

//here your wanted key is at first position
var key = Object.keys(foo)[0];

//get the value
var value = foo[key]

//append whatever suffix you want
key += 'Cal';



var fooResults = {
  //to use  content of variable as key of object put variable  in []   
  [key]: value
}


//another solution 
//create emtyy object 
var fooResults2 = {}

//use use variable name as index
fooResults2[key] = value


console.log('startMinCal: ' + fooResults.startMinCal) // This should log "1000" but won't until the object name inside `fooResults` is created correctly.

console.log('startMinCal: ' + fooResults2.startMinCal)

关于javascript - 如何从对象内部获取属性名称以创建新的属性名称?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55306676/

相关文章:

Javascript 检查对象是否具有特定属性值

java - 将文件读入对象数组

java - 用于参数注入(inject)/属性管理的良好库

javascript - 测试是否存在嵌套的 JavaScript 对象键

javascript - javascript的setInterval函数

javascript - .every 方法不将所有元素与 IF 语句匹配

javascript - Protractor 中的动态属性值元素定位器

javascript - 中间件返回错误express-Validator不是函数

c++ - 将 Win32 应用程序转换为对象

c# - 图片框不支持键盘事件吗?