亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3如何使用axios發(fā)起網(wǎng)絡(luò)請(qǐng)求

 更新時(shí)間:2022年06月24日 10:32:37   作者:3v3n1ng  
這篇文章主要介紹了Vue3如何使用axios發(fā)起網(wǎng)絡(luò)請(qǐng)求,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Vue3使用axios發(fā)起網(wǎng)絡(luò)請(qǐng)求

即使是小型項(xiàng)目也會(huì)涉及到請(qǐng)求后端API,除非你的網(wǎng)站展示的是一些不需要維護(hù)的靜態(tài)數(shù)據(jù),第三篇文章我們來(lái)給Vue項(xiàng)目搞上axios。

1.何為Axios?

請(qǐng)看官方對(duì)Axios的描述,傳送門:官方文檔

Axios 是一個(gè)基于 promise 網(wǎng)絡(luò)請(qǐng)求庫(kù),作用于node.js 和瀏覽器中。 它是 isomorphic 的(即同一套代碼可以運(yùn)行在瀏覽器和node.js中)。在服務(wù)端它使用原生 node.js http 模塊, 而在客戶端 (瀏覽端) 則使用 XMLHttpRequests。

2.如何安裝Axios

這部分我使用了幾個(gè)不同版本的node都沒(méi)有報(bào)錯(cuò),兼容性還是不錯(cuò)的。

yarn add axios?

3.如何封裝網(wǎng)絡(luò)請(qǐng)求和全局實(shí)例化axios

官網(wǎng)的實(shí)例都是在單個(gè)文件中局部實(shí)例化axios,在項(xiàng)目上使用不多。

按照之前的文章操作成功后,還需要在你的項(xiàng)目src目錄下新建api文件夾

在這里插入圖片描述

4. api.js是什么?

這里面封裝了所有的API請(qǐng)求,可以指定是否有參數(shù),指定請(qǐng)求的類型是GET、POST、DELETE還是PUT

import http from './http.js'
// 獲取驗(yàn)證碼,這個(gè)函數(shù)指的是使用GET請(qǐng)求請(qǐng)求目標(biāo)服務(wù)器的
Captcha路由
export function getCaptcha() {
    return http.get("/captcha")
}  
// 驗(yàn)證用戶名\密碼,這里指的是使用POST方法請(qǐng)求Login接口,并攜帶params對(duì)象作為參數(shù)。
export function verifyUserNameAPI(params) {
    return http.post("/login", params)
}

5.http.js是什么?

import request from '@/api/request'
const http = {
        get(url, params) {
            const config = {
                method: 'get',
                url: url
            } /*這里如果GET請(qǐng)求有參數(shù),則攜帶上傳入的參數(shù),在
            URL中以?的方式放在請(qǐng)求鏈接中*/
            if (params) config.params = params
            return request(config)
        },
        post(url, params) {
            const config = {
                method: 'post',
                url: url
            }/*同理也是傳入用戶需要發(fā)送到后臺(tái)的參數(shù),這些參數(shù)
            放在報(bào)文中,載體表達(dá)標(biāo)準(zhǔn)是JSON*/
            if (params) config.data = params
            return request(config)
        },
    }
    
//暴露接口,允許Vue文件或其他js,ts文件使用http結(jié)構(gòu)體中的方法
export default http

6.request.js是什么?

這個(gè)是核心的JS文件,表明了后端的地址,接口超時(shí)時(shí)間,以及請(qǐng)求攔截器和響應(yīng)攔截器部分。

import axios from 'axios';
// 創(chuàng)建一個(gè)自定義的Axios對(duì)象
const Axios = axios.create({
    baseURL: 'http://127.0.0.1:1234',
    timeout: 3000,
    /*也可以不設(shè)置Content-Type,影響是在你發(fā)送請(qǐng)求時(shí)
    Vue會(huì)先發(fā)送OPTIONS包探測(cè)路由是否存在,需要后端也做設(shè)置響應(yīng)OPTIONS
    方法,否則會(huì)報(bào)跨域錯(cuò)誤;我這里用的Beego2,路由里不響應(yīng)OPTIONS方法,
    所以我在這塊設(shè)置Content-Type*/
    headers: { 
        'Content-Type': 'application/x-www-form-urlencoded'
    },
    /*這個(gè)配置很重要,允許axios攜帶用戶Cookie到后端,不設(shè)置這個(gè)的話
    Set-Cookie是無(wú)效的,除此之外,Chrome默認(rèn)開(kāi)啟了SameSite檢查,如果
    后端不主動(dòng)設(shè)置SameSite = none,Set-Cookie是無(wú)效的。詳情請(qǐng)文章末尾
    參考阮老師的SameSite講解*/
    withCredentials: true
});
Axios.interceptors.request.use(req => {
    // 請(qǐng)求攔截處理
    // console.log('這里是請(qǐng)求攔截器,我攔截了請(qǐng)求', req);
    return req; 
}, err => {
    console.log('在發(fā)送請(qǐng)求時(shí)發(fā)生錯(cuò)誤,錯(cuò)誤為', err);
    //這里不能直接放回err,需要按照官方說(shuō)明返回一個(gè)Promise
    return Promise.reject(err);
})
Axios.interceptors.response.use(res => {
        // 響應(yīng)攔截處理
        // console.log('響應(yīng)攔截 ', res);
        return res.data;
    }, error => {
        const err = error.toString();
		//按照實(shí)際的響應(yīng)包進(jìn)行解析,通過(guò)關(guān)鍵字匹配的方式
        switch (true) {
            case err.indexOf('Network') !== -1:
                console.log('后端服務(wù)器無(wú)響應(yīng)或者URL錯(cuò)誤', err);
                break;
            case err.indexOf('timeout') !== -1:
                console.log('請(qǐng)求后端服務(wù)器超時(shí)!', err);
                break;
        }
        return Promise.reject(error);
    })
//暴露Axios實(shí)例化對(duì)象,允許所有文件調(diào)用Axios
export default Axios;

7.如何在Vue文件中請(qǐng)求封裝好的API呢?

//導(dǎo)入聲明的API請(qǐng)求函數(shù)
import { getCaptcha } from "@/api/api";
import { useMessage } from "naive-ui";
export default {
  setup() {
    let captchaId = ref();
    onMounted(() => {
       //onMounted是Vue聲明周期的鉤子函數(shù),由Vue提供,
       //請(qǐng)參考Vue聲明周期鉤子官方文檔
      getcaptchaAPI();
    });
    function getcaptchaAPI() {
      getCaptcha()
        .then((res) => {
          /*這里的res是響應(yīng)成功是返回的數(shù)據(jù),res.data說(shuō)明獲取報(bào)文
          中的data字段對(duì)應(yīng)的值,我在setup聲明使用的ref,所以賦值時(shí)
          需要使用captchaId.value的方式*/
          captchaId.value = res.data;
        })
        //在這里處理錯(cuò)誤
        .catch((err) => console.log(err));
    }
   }
}

就到這里了,現(xiàn)在你的項(xiàng)目既能請(qǐng)求后端接口,又能進(jìn)行路由跳轉(zhuǎn),具備了項(xiàng)目的基本條件,可以嘗試寫一個(gè)簡(jiǎn)單地頁(yè)面了。

Vue3.0請(qǐng)求接口的例子

<script>
// getInTheaters 為封裝的接口請(qǐng)求
import { getInTheaters } from "@/api/movie";
import {
  reactive,
  toRefs,
  onBeforeMount,
  onMounted,
  onBeforeUnmount,
  provide,
} from "vue";
import { useRouter } from "vue-router";
import { useStore } from 'vuex'
export default {
  components: {},
  setup() {
    const state = reactive({
      inTheaters: [],
    });
 
    // 編程式導(dǎo)航
    const router = useRouter();
    const store = useStore();
 
    onBeforeMount(() => {
      store.commit("setShowBack", false);
    });
 
    onBeforeUnmount(() => {
      store.commit("setShowBack", true);
    });
 
    const getInTheatersData = async () => {
      const res = await getInTheaters(
        "/gateway?cityId=310100&pageNum=1&pageSize=10&type=1&k=3535827"
      );
      state.inTheaters = res.data.data.films;
 
      onMounted(() => {
        //執(zhí)行請(qǐng)求
        getInTheatersData();
      });
 
       //頁(yè)面跳轉(zhuǎn)
      const goToList = (type) => {
        router.push(`/list/${type}`);
      };
 
      // 傳遞數(shù)據(jù)給子組件
      provide("title", "電影");
 
      return { ...toRefs(state), goToList };
    };
  },
};
</script>

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue中el-tree結(jié)合el-switch實(shí)現(xiàn)開(kāi)關(guān)狀態(tài)切換

    vue中el-tree結(jié)合el-switch實(shí)現(xiàn)開(kāi)關(guān)狀態(tài)切換

    本文主要介紹了vue中el-tree結(jié)合el-switch實(shí)現(xiàn)開(kāi)關(guān)狀態(tài)切換,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-12-12
  • Vue發(fā)布項(xiàng)目實(shí)例講解

    Vue發(fā)布項(xiàng)目實(shí)例講解

    在本篇文章里小編給各位分享的是關(guān)于Vue發(fā)布項(xiàng)目的實(shí)例內(nèi)容以及知識(shí)點(diǎn)講解,需要的朋友們參考下。
    2019-07-07
  • vue中監(jiān)聽(tīng)scroll事件失效的問(wèn)題及解決

    vue中監(jiān)聽(tīng)scroll事件失效的問(wèn)題及解決

    這篇文章主要介紹了vue中監(jiān)聽(tīng)scroll事件失效的問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue2之簡(jiǎn)易的pc端短信驗(yàn)證碼的問(wèn)題及處理方法

    vue2之簡(jiǎn)易的pc端短信驗(yàn)證碼的問(wèn)題及處理方法

    這篇文章主要介紹了vue2之簡(jiǎn)易的pc端短信驗(yàn)證碼的問(wèn)題,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • Vue Class Component類組件用法

    Vue Class Component類組件用法

    這篇文章主要介紹了Vue Class Component類組件用法,組件 (Component) 是 Vue.js 最強(qiáng)大的功能之一,它是html、css、js等的一個(gè)聚合體,封裝性和隔離性非常強(qiáng)
    2022-12-12
  • vue 父組件調(diào)用子組件方法及事件

    vue 父組件調(diào)用子組件方法及事件

    這篇文章主要介紹了vue 父組件調(diào)用子組件方法及事件的相關(guān)資料,父組件傳入數(shù)組子組件循環(huán)來(lái)創(chuàng)建不同的組件模塊,所有事件都在子組件內(nèi)部.怎么實(shí)現(xiàn)這樣一個(gè)功能呢?接下來(lái)跟隨腳本之家小編一起看看吧
    2018-03-03
  • antd的選擇框如何增加tab選中的方法示例

    antd的選擇框如何增加tab選中的方法示例

    這篇文章主要為大家介紹了antd的選擇框如何增加tab選中的方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • 深入淺析vue-cli@3.0 使用及配置說(shuō)明

    深入淺析vue-cli@3.0 使用及配置說(shuō)明

    這篇文章主要介紹了vue-cli@3.0 使用及配置說(shuō)明,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • Vue如何實(shí)現(xiàn)監(jiān)聽(tīng)組件原生事件

    Vue如何實(shí)現(xiàn)監(jiān)聽(tīng)組件原生事件

    這篇文章主要介紹了Vue如何實(shí)現(xiàn)監(jiān)聽(tīng)組件原生事件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • Vue全局監(jiān)測(cè)錯(cuò)誤并生成錯(cuò)誤日志實(shí)現(xiàn)方法介紹

    Vue全局監(jiān)測(cè)錯(cuò)誤并生成錯(cuò)誤日志實(shí)現(xiàn)方法介紹

    在做完一個(gè)項(xiàng)目后,之后的維護(hù)尤為重要。這時(shí),如果項(xiàng)目配置了錯(cuò)誤日志記錄,這樣能大大減少維護(hù)難度。雖然不一定能捕獲到全部的錯(cuò)誤,但是一般的錯(cuò)誤還是可以監(jiān)測(cè)到的。這樣就不用測(cè)試人員去一遍一遍復(fù)現(xiàn)bug了
    2022-10-10

最新評(píng)論