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