如何访问每个JSON对象的属性?

时间:2019-11-22 21:56:36

标签: javascript ajax api vue.js

因此,我正在使用Axios进行API调用,并将JSON响应推送到一个空数组。我在访问每个对象的各个属性时遇到问题。 `

            
        <div class="wrapper">
            <div class="row">
                <div v-for="group in groups" :key="group.id">
                    <div class="col-md-4 cards">
                        <h3>{{ group[1].name }}</h3>
                        <h3>{{ group.name }}</h3>
                    </div>
                </div>
            </div>
        </div>
    </div>

然后我的js是

import axios from 'axios'
export default {
    name: 'app',
        data () {
            return {
                groups: [],
                loading: false
            }
        },
        methods: {
            getHomes: function() {
                this.loading = true;
                axios.get("*******")
                    .then((response) =>{
                        this.loading = false;
                        this.groups.push(response.data);
                        // console.log(this.groups)
                    }, (error) => {
                        this.loading = false;
                    })

            },

我可以通过对数组索引进行硬编码来访问每个单独的group.name,但是我在动态访问它们时遇到了问题。

这是回应的图片 enter image description here

2 个答案:

答案 0 :(得分:1)

代替这样做:

.then((response) =>{
  this.loading = false;
  this.groups.push(response.data);
}, (error) => {
  this.loading = false;
})

只需将response.data分配到groups变量。

.then((response) =>{
  this.loading = false;
  this.groups = response.data;
}, (error) => {
  this.loading = false;
})

在您的模板中:

<div v-for="(group, index) in groups" :key="index">
  <div class="col-md-4 cards">
    <h3>{{ group.name }}</h3>
    <h4>{{ group.url }}</h4>
  </div>
</div>

之所以无法访问该项目,是因为您将对象数组推入一个数组内,因此需要遍历另一个数组内的数组。

答案 1 :(得分:0)

在示例数据集中,您在Axios调用中获得的response.data似乎已经是一个数组。您应该采用这种方式。

"use strict";

import Vue from "vue";
import Axios from "axios";

export default Vue.component({
    data() {
        return {
            groups: [],
            loading: false
        };
    },

    created() {
        this.loading = true;

        axios.get("https://somwhere.com/api/something").then(response => {
            this.groups = response.data;
        }).finally(() => this.loading = false);
    }
});

此外,您应该在finally块中执行加载取消。我主动添加它,以便即使它不在问题范围内,您也可以看到它是如何完成的。