Javascript 无法访问对象的属性
Javascript can't access property of an object
我有一个对象(从jQuery ajax返回),看起来像这样:
data:{
materials:{
1:{
id:1,
name:"jacob"
}//1 (some integer)
}//materials
}//data
我正在尝试访问name
,但我无法传递对象1
。我尝试使用这样的makeArray()
var m = $.makeArray(data.materials);
var m0 = m.shift();
console.log(m);
console.log(m0);
$isArray(m)
& $.isArray(m0)
返回 true,但 m
和 m0
都返回:
1:{
id:1,
name:"jacob"
}//1 (some integer)
我希望shift()
返回1
内部的对象。
当我尝试访问m0.name
时,它返回未定义,当我尝试访问m[1]
时,它返回未定义。
问题是1
是可变的(我不知道它会是什么,所以我想使用不适用于对象的shift()
)。data.materials["1"].name
编辑:所以似乎在makeArray()
中存在限制:由于对象属性不应该用数字命名,因此该函数不会转换对象的其余部分,并且输出是某种对象数组混合(您不能使用像shift()
这样的数组函数),所以我想到的快速肮脏解决方案是像这样循环通过它:
var m = data.materials,
id;
for ( key in m ) { id = key; }
console.log( m[id].name );
它不是那么干净,所以如果有更好的方法,请告诉我。
附言1:{}
首先存在,因为控制器在某些条件下返回多个"材料"(当使用此js时永远不会成立)。
你应该使用data.materials["1"].name
http://jsfiddle.net/nq4RE/
雅各布,我看到你更新了你的问题。
要使用变量,只需调用data.materials[your_variable_here].name
http://jsfiddle.net/nq4RE/1/
你试过吗:data.materials[1].name
?
但在我看来,使用数字作为属性名称是误导性的。
相关文章:
- 为什么我可以在Array属性对象中找到Javascript Array for Each方法
- 使用onclick调用属性对象函数
- 嵌套为..in 循环,列出多维对象的属性(对象)
- 动态属性对象 - JSON
- 在不使用隔离范围angularjs自定义指令的情况下获取属性对象
- 通过属性传递属性/对象.Javascript
- Javascript:属性/对象的类型
- 访问JSON中的属性(对象)
- 属性对象Javascript不是用Jquery Deferred设置的
- 无法读取属性'#<对象>'未定义的获取错误
- Twitter中多属性对象的子字符串匹配
- 无法设置'data'属性'对象'标记.(只IE8)
- 更新数据属性对象属性值
- 将属性对象的选定对象从原型推入数组
- 将单个属性对象字面量的数组转换为仅包含其值的数组的最佳方法
- 寻找一种更简单的方法来检查是否多个属性&对象中的方法是未定义的
- 主干模型:带有get方法的空属性,但在属性对象中
- 如何赋值给"text"someText"属性对象在动能js
- Angularjs的数据绑定与数据属性对象
- 如何将一个嵌套的javascript对象转换为只有一级属性对象