解決Vue中Axios GET請求404錯誤的方法是什麼?
P粉738046172
P粉738046172 2023-08-30 00:23:34
0
1
625
<p>我想顯示與相關答案的問題。不幸的是,如果我加載一個單獨的<code>QuestionPage</code>,它不會顯示所有的答案。這是因為我在<code>./components/Answers.vue</code>元件中發現了一個邏輯錯誤。 </p> <p>我認為問題出在我的<code>fetch()</code>函數中,其中的端點連結未定義(控制台錯誤的截圖https://prnt.sc/198ebdx)< /p> <p>這個Answers元件在QuestionPage中使用,我認為<code>Question</code>元件沒有正確引用<code>Answer</code>元件。 </p>
P粉738046172
P粉738046172

全部回覆(1)
P粉191610580

QuestionPage.vue元件中,您的<answers :question="question"></answers>應該有一個v-if= "question.id"來防止載入元件,以防data()函數中定義的question不存在。

解釋

控制台中報錯是因為在您的HTTP請求中使用了一個未定義的變數。

查看您的Answers.vue元件,在created函數中有以下程式碼:

created () {
    this.fetch(`/questions/${this.questionId}/answers`);
},

這個問題ID是指同一個Answers.vue中的Props / Data結構:

export default {
    props: ['question'],
    mixins: [highlight],
    data () {
        return {
            questionId: this.question.id,
            count: this.question.answers_count,
            answers: [],
            answerIds: [],
            nextUrl: null
        }
    }
}

在您的QuestionPage.vue元件中,您將question作為prop傳遞給Answers.vue元件。然而,這個變數可能是未定義的。您應該先檢查這個函數的結果

mounted () {
    this.fetchQuestion ();
    //  alert(this.question)
    //  console.log(this.question)
},

methods: {
    fetchQuestion () {
        axios.get(`/questions/${this.slug}`).then(({data})=> {
          this.question = data.data
        }).catch(error => console.log(error))
    }
}

如果函數沒有結果,請確保您的slug prop是正確的,並由後端處理。

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板