Vue ialah rangka kerja JavaScript moden yang telah menjadi bahagian penting dalam pembangunan bahagian hadapan. Vue menyediakan kefungsian yang kaya dan API yang mudah digunakan, membolehkan pembangun membina aplikasi dengan cepat dan cekap. Walau bagaimanapun, apabila menggunakan aplikasi Vue, anda mungkin menghadapi "Ralat Tidak Ditangkap (dalam janji): Ralat Rangkaian" dalam sumber Vue, yang mungkin menyebabkan masalah serius dalam aplikasi. Artikel ini akan meneroka kemungkinan punca dan penyelesaian kepada masalah ini apabila menggunakan sumber vue dalam aplikasi Vue.
Ralat ini biasanya bermaksud masalah: Vue-resource tidak dapat menyambung ke pelayan. Ini boleh disebabkan oleh pelbagai masalah. Berikut ialah beberapa kemungkinan sebab ralat ini:
Disebabkan sekatan keselamatan penyemak imbas, Vue-resource tidak boleh menggunakan kuki dalam permintaan merentas domain secara lalai. Jika anda ingin menggunakan kuki dalam permintaan merentas domain, anda perlu menetapkan pelayan permintaan merentas domain untuk membenarkan penggunaan kuki. Anda boleh menggunakan proksi untuk menyelesaikan isu merentas domain:
//Vue.config.js module.exports = { devServer: { proxy: { '/api/*': { target: 'http://localhost:3000', changeOrigin: true, secure: false, pathRewrite: { '^/api': '' }, cookieDomainRewrite: { "*": "" } } } } }
Dengan cara ini, permintaan anda akan diproksikan ke pelayan tempatan menggunakan port 3000.
Jika pelayan anda tidak dapat menyambung atau menghadapi sebarang ralat, Vue-resource tidak akan dapat menyambung kepadanya dan menyebabkan ralat. Anda boleh cuba mengakses API yang sepadan secara manual dalam penyemak imbas untuk menentukan masalah pelayan.
Sambungan rangkaian dan isu berkaitan boleh menyebabkan ketidakupayaan untuk menyambung ke pelayan. Sila semak tetapan rangkaian anda untuk memastikan sambungan rangkaian anda berfungsi dengan betul.
Penyelesaian:
Periksa sama ada Vue-resource dikonfigurasikan dengan betul. Pastikan anda memberikan URL yang betul dan menggunakan kaedah permintaan yang betul (GET, POST, dsb.), dan juga pastikan Vue-resource diperkenalkan di lokasi yang betul dalam projek anda.
Anda boleh menyediakan mekanisme pemeriksaan kesihatan untuk memastikan ketersediaan pelayan. Jika pelayan tidak tersedia, anda harus menerima pemberitahuan amaran.
//使用健康检查 setInterval(() => { this.$http.get('/healthcheck') .then(response => { console.log(response) }) .catch(error => { console.error(error) alert('服务器错误') // 通知用户服务器问题 }) }, 10000)
Alih Keluar Cache Menggunakan cache boleh menyebabkan ralat rangkaian. Cache boleh dialih keluar sebelum setiap permintaan untuk memastikan data lama tidak digunakan.
this.$http.get('/url', { headers: { 'Cache-Control': 'no-cache' } }) .then(response => { console.log(response) }) .catch(error => { console.error(error) })
Kesimpulan:
Tanpa mengira mana-mana masalah di atas, Vue-resource akan mengembalikan ralat "Ralat Tidak Tertahan (dalam janji): Ralat Rangkaian". Keadaan ini boleh menjejaskan kefungsian biasa aplikasi Vue dan boleh menyebabkan aplikasi itu ranap. Tangani masalah ini dengan menggunakan pemeriksaan kesihatan dan mengambil penyelesaian yang betul.
Atas ialah kandungan terperinci Apakah yang perlu saya lakukan jika 'Ralat Tidak Ditangkap (dalam janji): Ralat Rangkaian' berlaku apabila menggunakan sumber vue dalam aplikasi Vue?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!