Как добавить объект в массиве в JavaScript - PullRequest
0 голосов
/ 27 ноября 2018

Я использую веб-компонент и OpenAPI.и мой веб-компонент работает с ценными данными [параметров].

это круговая диаграмма, разделенная на значение DATA_VALUE, а ITEM_NAME - метка для отображения!

Я извлекаю данные из OpenAPI и хочу добавить в массив [data] в параметрах var.

Мне нужно использовать строки с [1] по [11], но сейчас я использую только строки [1], и все работает хорошо.

, поэтому сейчас я пытаюсь сделать это для строк операторов [1] до [11]!

Мне интересно, как я могу добавить строки [1] к данным [11] в [data] в параметрах var?

Я пытался так, ноэто происходит ошибка.думаю, это не в правильном месте или неправильно.

  options.data.push({DATA_VALUE: dataV, ITEM_NAME2: itemNm2});

это весь код.

<body>
<div class='pie'></div>
<script>
    var styles = {
        legend: {
            use: true,
            stackedGap: 5,
            type: 'insideLegend',
            text: {
                family: 'Nanum Gothic',
                size: 17,
                color: '#333333',
                style: 'normal', /* normal | italic */
                weight: 'bold', /* normal | bold */
                opacity: 1
            }
        }
    };

    $.ajax({
        url: 'http://openapi.crimestats.or.kr/WiseOpen/PoliceDataList/ZTEADTY42D1XJ9XPOZDG/json/1/15/2016/22/01010000006/?/',
        type: 'GET',
        dataType: 'json',
        success: function (resp) {
            console.log(resp);
            var rows = resp.PoliceDataList.row;
            if (rows) {
                var representativeRow = rows[1],

                   /* statNm = representativeRow.STAT_NAME,
                    baseYear = representativeRow.BASE_YEAR,
                    itemNm1 = representativeRow.ITEM_NAME1;*/

                    itemNm2 = representativeRow.ITEM_NAME2;
                    dataV = representativeRow.DATA_VALUE;

                    console.log(itemNm2);
                    console.log(dataV);


/*
                var dataArray = [];
                $.each(rows, function (idx, row) {
                    var tmp = [];
                    tmp.push(row.ITEM_NAME2);
                    tmp.push(Number(row.DATA_VALUE));
                    dataArray.push(tmp);

                });
                console.log(dataArray);
                var jsonEncode = JSON.stringify(dataArray);
                console.log(jsonEncode);*/

                var options = {
                    data: {
                        data: [
                            {DATA_VALUE: dataV, ITEM_NAME2: itemNm2}
                        ]
                        ,
                        use: 'DATA_VALUE'
                    },
                    legend: {
                        use: 'ITEM_NAME2'
                    }
                };
                options.data.push({DATA_VALUE: dataV, ITEM_NAME2: itemNm2});

                pie = webponent.visual.pie.init($(".pie"), styles, options);
            }
        }
    });
</script>
</body>

это пример значения OpenAPI

{
"PoliceDataList":{
"list_total_count":12,
"row":[
{
"ITEM_NAME1":"강간",
"ITEM_NAME2":"계",
"ITEM_CODE2":"X0001",
"ITEM_CODE1":"01010000006",
"STAT_NAME":"검거자",
"DATA_VALUE":"5916",
"STAT_CODE":"22",
"BASE_YEAR":"2016"
},
{
"ITEM_NAME1":"강간",
"ITEM_NAME2":"수사·형사",
"ITEM_CODE2":"X0003",
"ITEM_CODE1":"01010000006",
"STAT_NAME":"검거자",
"DATA_VALUE":"979",
"STAT_CODE":"22",
"BASE_YEAR":"2016"
},
{
"ITEM_NAME1":"강간",
"ITEM_NAME2":"외근·112차",
"ITEM_CODE2":"X0004",
"ITEM_CODE1":"01010000006",
"STAT_NAME":"검거자",
"DATA_VALUE":"1032",
"STAT_CODE":"22",
"BASE_YEAR":"2016"
},

1 Ответ

0 голосов
/ 11 декабря 2018

options.data.data.push ({DTA_VAL: dataV, ITM_NM: itemNm2});

это хорошо работает!

...