Vue3最佳实践 第六章 Pinia,Vuex与axios,VueUse 4(axios)

Axios

  axios 是一个基于 Promise 的 HTTP 客户端,不仅可以与 vue.js 一起使用,还可以与其他前端框架以及后端 Node.js 一起使用。当你想从包括后端服务器在内的外部服务获取数据时,可以使用axios 中的方法很方便的获得数据内容。在本文档中,我们将介绍如何在 vue.js 版本 3 的环境中使用 axios。对于 Vue 3,它不仅解释了如何将它与 Options API 一起使用,还解释了如何将它与 Composition API 一起使用。
官方文件地址https://axios-http.com/docs/intro

1 axios 设置

  我们的目标是学习如何将 axios 与 vue.js 一起使用,使用 cdn模式是最快和最简单的方法。在原生的HTML中使用axios 的方法获得数据。在浏览器访问它并显示一个远程访问获得数据列表内容。如果你不知道 axios 是什么,不用担心,我们会慢慢解释的。

DOCTYPE html>
<html lang="ja">
<head>
    <meta charset="UTF-8">
    <title>学习在vue中使用axiostitle>
head>
<body>
    <div id="app">
        <h1>{{ message }}h1>
    div>
    <script src="https://unpkg.com/vue@3">script>
    <script src="https://unpkg.com/axios/dist/axios.min.js">script>
    <script>
    Vue.createApp({
        el: '#app',
        data(){
            return {
                message: 'Hello Axios',
            }
        },
        mounted(){
            axios.get('https://jsonplaceholder.typicode.com/users')
                .then(response => console.log(response))
                .catch(error => console.log(error))
        }
}).mount('#app')
    script>
body>
html>

在 node项目中导入axios组件。

$ npm install axios

在vue3 中使用axios获得数据的例子。

<script setup>
import { onMounted } from 'vue';
import axios from 'axios'
onMounted(() => {
      axios
        .get('https://jsonplaceholder.typicode.com/users')
        .then((response) => console.log(response))
        .catch((error) => console.log(error));
});
script>
<template>
<div >
  <div>业务内容一览div>
template>

2 axios方法

  axios处理方法分为同步处理与异步处理两种,axios默认的是异步处理方法。获得的数据结果在下面几个方法中进行处理。

axios.get('/user?ID=12345')
  .then(function (response) {
 // 描述axios处理成功后要处理什么
    console.log(response);
  })
  .catch(function (error) {
 // 描述axios处理出错时要做什么
    console.log(error);
  })
  .finally(function () {
 // 无论axios的处理结果如何,都会执行
  });

在 Vue 实例中使用 axios 中get,post ,delete,put方法创建数据远程连接。

axios.get(url[, config])
axios.post(url[, data[, config]])
axios.delete(url[, config])
axios.head(url[, config])
axios.put(url[, data[, config]])
axios.patch(url[, data[, config]])

  返回json对象在 response.data 的属性中获得数据内容, response 包含的其他内容不仅是数据,还有status、headers、statusText、config。如果只关注状态,可以看到如果使用 GET 方法处理成功则返回状态码 200,使用 POST 方法返回状态码 201。

axios.get('https://jsonplaceholder.typicode.com/users')
      .then(response => {
        console.log(response.data)//数据内容
        console.log(response.status)
        console.log(response.headers)
        console.log(response.statusText)
        console.log(response.config)
      })
      .catch(error => console.log(error))
}

1 axios 异步方法

通过异步方法获得数据列表,在将列表中的数据内容显示到模板v-for指令中。

<script setup>
import {ref,onMounted  } from 'vue';
import axios from 'axios'
const userlist=ref([]);
onMounted(() => {
      axios
        .get('https://jsonplaceholder.typicode.com/users')
        .then((response) => userlist.value=response.data)
        .catch((error) => console.log(error));
    });
script>
<template>
<div class="m-4 p-4" style="height:97vh;overflow-y:auto">
  <div>业务内容一览div>
  <div v-for="list in userlist ">
    id:{{list.id}} name:{{list.name}}
  div>
 div>
template>

2 axios 同步方法

  Composition API 中使用了 async 和 await 设置的函数为同步函数。很多业务都需要axios 同步方法来处理,我们将axios处理函数设置关键字async 和 await,这个函数就是同步函数。

同步处理关键字 async , await

<script setup>
import {ref,onMounted  } from 'vue';
import axios from 'axios'
const userlist=ref([]);
    // 使用 async 和 await 函数定义同步关键字
    onMounted(async () => {
      try {
        const response = await axios.get(
          'https://jsonplaceholder.typicode.com/users'
        );
        userlist.value=response.data
      } catch (error) {
        console.log(error);
      }
    });   
script>
<template>
<div class="m-4 p-4" style="height:97vh;overflow-y:auto">
  <div>业务内容一览div>
      <div v-for="list in userlist ">
        id:{{list.id}} name:{{list.name}}
      div>
  div>
template>

  普通方法设置成同步方法。

<script setup>
import {ref,onMounted  } from 'vue';
import axios from 'axios'
const userlist=ref([]);
    onMounted( () => {
      init();
    });   
    //定义同步方法
    const init =async () => {
      try {
        const response = await axios.get(
          'https://jsonplaceholder.typicode.com/users'
        );
        userlist.value=response.data
      } catch (error) {
        console.log(error);
      }
    }
script>
<template>
<div class="m-4 p-4" style="height:97vh;overflow-y:auto">
  <div>业务内容一览div>
      <div v-for="list in userlist ">
        id:{{list.id}} name:{{list.name}}
      div>
  div>
template>

Vue3最佳实践 第六章 Pinia,Vuex与axios,VueUse 4(axios)_第1张图片

3 创建实例与配置拦截器

​  您可以使用 create 方法创建一个 axios 实例。可以在 create 方法的参数中设置 baseURL,headers表头信息等其他url请求设置。axios 实例

<script setup>
import {ref,onMounted} from 'vue';
import axios from 'axios'
const userlist=ref([]);
    onMounted( () => {
      init();
    });  
const headers = {
   Authorization: `Bearer`
}     
    const init =async () => {
      const instance = axios.create({
        baseURL:'https://jsonplaceholder.typicode.com/users',
        headers: headers
      });
        const response = await instance.get();
        userlist.value=response.data
    }
script>
<template>
<div class="m-4 p-4" style="height:97vh;overflow-y:auto">
  <div>业务内容一览div>
  <div v-for="list in userlist ">
    id:{{list.id}} name:{{list.name}}
  div>
  div>
template>

配置拦截器

  拦截器可以在 axios 发送请求之前或从服务器返回响应时对 Request 和 Response 对象进行业务处理的监听方法。

axios.defaults.baseURL = 'https://jsonplaceholder.typicode.com';
axios.interceptors.request.use((config) => {
  console.log(config)
  return config;
});
//在拦截器中设置 baseURL
axios.interceptors.request.use((config) => {
 config.baseURL = 'https://test.com';
  console.log(config)
  return config;
});

在浏览器中可以看到 baseURL 已被覆盖。显示错误消息,因为无法访问 https://test.com这个url地址。

axios.interceptors.response.use((response) => {
  console.log(response);
  return response;
});

  Response 可用于在认证失败并返回状态码401(Unauthorized)时候,作认证失败时的注销处理。通过检查每个响应的状态码,可以根据每个代码进行不同的业务处理。

axios.interceptors.response.use(
  (response) => response,
  (error) => {
    if (error.response.status === 401) {
      //logout 注销处理
    }
    return Promise.reject(error);
  }
);

4 axios 插件plugins

  创建一个 axios.js 文件,在文件中定义一个axios插件plugins功能。插件中允许我们设置一个共通的 baseURL方法路径,项目中使用axios方法可以直接引用到这个公共url路径。

axios.js

import axios from 'axios';
const axiosPlugin = {
  install(app, options) {
    const axiosInstance = axios.create({
      baseURL: options.baseURL,
    });
    app.provide('axios', axiosInstance);
  },
};
export default axiosPlugin;

main.js

项目中vue组件引入axiosPlugin插件功能,插件中引入一个共通的baseURL: 'https://jsonplaceholder.typicode.com/'访问路径。

import { createApp } from 'vue'
import router from './router'
import App from './App.vue'
import axiosPlugin from './axios';
const app = createApp(App)
app.use(router)
app.use(axiosPlugin, {
    //所有axios访问路径头
    baseURL: 'https://jsonplaceholder.typicode.com/'
 });
app.mount('#app')

axios使用

  在vue组件中获得inject 过滤方法,设置每个axios对象访问url的时候都要通过inject方法过滤访问的url地址。所有的地址baseURL+ 后台系统的业务路径

<script setup>
import {ref,onMounted  } from 'vue';
import { inject } from 'vue';
const axios = inject('axios');
const userlist=ref([]);
onMounted( () => {
  init();
}); 
const init=async ()=>{
   //访问地址是 'https://jsonplaceholder.typicode.com/'+ '/users'
  const response = await axios.get('/users');
  console.log(response.data);
  userlist.value=response.data;

}
script>
<template>
<div class="m-4 p-4" style="height:97vh;overflow-y:auto">
  <div>业务内容一览div>
  <div v-for="list in userlist ">
    id:{{list.id}} name:{{list.name}}
  div>
 div>
template>

你可能感兴趣的:(vue,javascript,vue,前端框架)