programing

Jquery에서 키와 값을 모두 배열로 밀어넣는 방법

bestprogram 2023. 8. 10. 19:01

Jquery에서 키와 값을 모두 배열로 밀어넣는 방법

는 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]

이와 같이

타일링크를 쌍으로 가져오는 방법(키로서의 제목과 값으로서의 링크)

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 );
});

이 코드

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

당신이 생각하는 것처럼 하지 않는 것입니다.푸시되는 것은 "제목"이라는 이름의 단일 멤버와 다음을 가진 새 개체입니다.link그 가치로서...실제의title값이 사용되지 않습니다.두 개의 필드가 있는 개체를 저장하려면 다음과 같은 작업을 수행해야 합니다.

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

또는 최근의 자바스크립트 발전으로 당신은 바로 가기를 사용할 수 있습니다.

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

대신 개체의 키를 변수의 내용으로 사용하려면title사용할 수 있습니다.

arr.push({[title]: link}); // Note that title has been wrapped in brackets

개체를 정의한 다음 배열을 밀어넣어야 합니다.

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

배열을 밀어넣는 것이 아니라 키로 요소를 설정하는 것입니다.title가치 있는link따라서 어레이는 개체여야 합니다.

다음과 같은 의미일 수 있습니다.

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';

이것이 도움이 되길 바랍니다 :)

언급URL : https://stackoverflow.com/questions/4825899/how-to-push-both-key-and-value-into-an-array-in-jquery