如何在Jquery中将键和值都推送到Array中

问题描述 投票:71回答:5

我正在阅读RSS提要并将标题和链接推送到Jquery中的数组。

我做的是

var arr = [];

            $.getJSON("displayjson.php",function(data){
                $.each(data.news, function(i,news){
                    var title = news.title;
                    var link = news.link;
                    arr.push({title : link});
                });                      
            });

我正在使用再次阅读该阵列

$('#show').click(function(){
                $.each(arr, function(index, value){
                    alert( index +' : '+value);
                });
            });

但它给我输出为

1:[Object Object]
2:[Object Object]
3:[Object Object]

像这样 ...

我怎么能把瓷砖和链接作为一对(标题作为键和链接作为值)

jquery arrays key-value
5个回答
150
投票

JavaScript数组中没有键。为此目的使用对象。

var obj = {};

$.getJSON("displayjson.php",function (data) {
    $.each(data.news, function (i, news) {
        obj[news.title] = news.link;
    });                      
});

// later:
$.each(obj, function (index, value) {
    alert( index + ' : ' + value );
});

在JavaScript中,对象充当关联数组的角色。请注意,对象在迭代时没有定义的“排序顺序”(参见下文)。

但是,在你的情况下,我并不清楚你为什么要从原始对象(data.news)传输数据。为什么不简单地传递对该对象的引用?


您可以组合对象和数组以实现可预测的迭代和键/值行为:

var arr = [];

$.getJSON("displayjson.php",function (data) {
    $.each(data.news, function (i, news) {
        arr.push({
            title: news.title, 
            link:  news.link
        });
    });                      
});

// later:
$.each(arr, function (index, value) {
    alert( value.title + ' : ' + value.link );
});

25
投票

这段代码

var title = news.title;
var link = news.link;
arr.push({title : link});

没有做你认为它做的事情。推送的是一个新对象,其中一个成员名为“title”,link为值......不使用实际的title值。要保存具有两个字段的对象,您必须执行类似的操作

arr.push({title:title, link:link});

或者使用最近的Javascript进展,您可以使用快捷方式

arr.push({title, link}); // Note: comma "," and not colon ":"

最接近python元组的是

arr.push([title, link]);

一旦你在arr数组中得到了你的对象或数组,你就可以得到value.titlevalue.link的值,或者在推送数组版本的情况下,得到value[0]value[1]


15
投票

我认为你需要定义一个对象,然后推入数组

var obj = {};
obj[name] = val;
ary.push(obj);

12
投票
arr[title] = link;

你没有进入数组,你正在使用密钥title将元素设置为值link。因此,您的数组应该是一个对象。


2
投票

你可能是这个意思:

var unEnumeratedArray = [];
var wtfObject = {
                 key    : 'val', 
                 0      : (undefined = 'Look, I\'m defined'),
                 'new'  : 'keyword', 
                 '{!}'  : 'use bracket syntax',
                 '        ': '8 spaces'
                };

for(var key in wtfObject){
    unEnumeratedArray[key] = wtfObject[key];
}
console.log('HAS KEYS PER VALUE NOW:', unEnumeratedArray, unEnumeratedArray[0], 
             unEnumeratedArray.key, unEnumeratedArray['new'], 
             unEnumeratedArray['{!}'], unEnumeratedArray['        ']);

你可以为像这样的对象设置一个可枚举:({})[0] = 'txt';你可以设置一个数组的键,如:([])['myKey'] = 'myVal';

希望这可以帮助 :)

© www.soinside.com 2019 - 2024. All rights reserved.