2

我有一个对象

data = {
    'choiceA' : 'Long-Wear',
    'choiceB' : 'Anti-Age Lifting/Firming',
    'choiceC' : 'Replenishing/ Moisturizing',
    'choiceD' : 'Natural/ True-to-Skin',
    'choiceE' : 'Smoothing/ Illuminating'
}    

我需要检索给定整数的第四个值

 position = 3;

通常我会写

 key = $.inArray( position, ['choiceA', 'choiceB', 'choiceC', 'choiceD', 'choiceE']);
 answer = data[key];

但是像这样直接使用数字键访问对象是否有效?

 answer = data[position];  // where position is an integer

编辑:
我在向后使用 $.inArray 时编写的一些错误代码!
我的意思是写

 arr = ['choiceA', 'choiceB', 'choiceC', 'choiceD', 'choiceE'];
 key = arr[position];
 answer = data[key];
4

3 回答 3

4

不,在您拥有数字对象“键”之前它是无效的,即

data = {
    '1' : 'Long-Wear',
    '2' : 'Anti-Age Lifting/Firming',
    '3' : 'Replenishing/ Moisturizing',
    '4' : 'Natural/ True-to-Skin',
    '5' : 'Smoothing/ Illuminating'
};

另外,需要注意的是,JavaScript 对象中的属性没有排序。因此,正如我所见,您的解决方案是最好的方法。

于 2013-01-08T19:39:30.807 回答
2

两件事情:

  1. Javascript 键始终是字符串。如果您传递其他内容(例如,一个数字),它将被转换为一个字符串。(例如,尝试使用索引数组,array["3"]它应该可以工作

  2. Javascript 对象没有排序!您无法以可移植的方式取回第 i 个键值对。相反,您应该使用数组来存储东西(或类似的东西):

    data = [
        { name:'choiceA', value: 'Long-Wear'},
        { name:'choiceB', value: 'Anti-Age Lifting/Firming'}
    ];
    

    如果您无法更改数据表示,您可以做的一件事是使用 for-in 循环和计数变量遍历您的对象。但是,这种方法不可移植,因为并非所有浏览器都按照定义键的顺序进行迭代。

于 2013-01-08T19:45:33.533 回答
2

如果您尝试过,您会发现它无效。更糟糕的是,它不起作用!

data[position]

在您的示例中将返回 undefined ...

于 2013-01-08T19:42:08.037 回答