How vue3 solves the axios request encapsulation problem
vue3 actual axios request encapsulation problem
1. Create an http folder in the src directory, and create index.js, request.js, and api.js under the http folder
2. The role of index.js: used to export all interfaces defined by api.js, the code is as follows
export * from './api';
3. The request.js code is as follows:
import axios from 'axios'; import buildURL from 'axios/lib/helpers/buildURL'; import { merge } from 'axios/lib/utils'; //判断指定参数是否是一个纯粹的对象,所谓"纯粹的对象",就是该对象是通过"{}"或"new Object"创建的 function isPlainObject (val) { return val && val.constructor.name === 'Object' } //请求之前进行拦截,可做的操作:1、添加loading的加载;2、添加请求头;3、判断表单提交还是json提交 let requestInterceptors = [ config => { //添加loading的加载 //添加请求头 config.headers.authorization = sessionStorage.getItem('Token'); //判断表单提交还是json提交 if (config.emulateJSON && isPlainObject(config.data)) { config.data = buildURL('', config.data).substr(1); } return config; } ] //请求响应之后进行拦截,可做操作:1、取消loading的加载;2、对返回状态进行判断:如请求错误、请求超时、获取数据失败、暂无数据等等 let responseInterceptors = [ res => { //取消loading加载 //对返回状态进行判断:如请求错误、请求超时、获取数据失败等等 //返回结果 return Promise.resolve(res); }, err => { //取消loading加载 //对返回状态进行判断:如请求错误、请求超时、获取数据失败等等 //返回结果 return Promise.reject(err); } ] //组装请求 let serviceCreate = config => { let service = axios.create(merge({}, config)); service.interceptors.request.use(...requestInterceptors); service.interceptors.response.use(...responseInterceptors); return service } serviceCreate(); export { serviceCreate, merge };
4. the api.js code is as follows :
import { serviceCreate, merge } from '@/http/request'; //这种方式可以采用单个项目的接口,也可以使用多个项目的接口,看自己的项目情况而定 let http0 = serviceCreate({ baseURL: '/project1/api1', timeout: 15000,//请求超时 emulateJSON: true,//默认表单提交 }) let http1 = serviceCreate({ baseURL: '/project2/api2', timeout: 15000,//请求超时 emulateJSON: true,//默认表单提交 }) //get请求示例 export function getData(params, config) { return http0.get('/project/list', merge(config, { params })); } //delete请求示例 export function deleteData(params, config) { return http0.delete('/project/list', merge(config,{ params })); } //post请求示例(表单提交) export function postDataFrom(params, config) { return http0.post('/project/list', params, config); } //post请求示例(json提交) export function postDataJson(params, config) { return http0.post('/project/list', params, merge(config, { emulateJSON: false })); } //put请求示例(表单提交) export function putDataFrom(params, config) { return http0.put('/project/list', params, config); } //put请求示例(json提交) export function putDataJson(params, config) { return http0.put('/project/list', params, merge(config, { emulateJSON: false })); }
5. Call in the page
import { getData, deleteData, postDataFrom, postDataJson, putDataFrom, putDataJson } from "@/http"; getData({ name: "我是参数" }).then(res => { console.log("返回数据", res) }) deleteData({ name: "我是参数" }).then(res => { console.log("返回数据", res) }) postDataFrom({ name: "我是参数" }).then(res => { console.log("返回数据", res) }) postDataJson({ name: "我是参数" }).then(res => { console.log("返回数据", res) }) putDataFrom({ name: "我是参数" }).then(res => { console.log("返回数据", res) }) putDataJson ({ name: "我是参数" }).then(res => { console.log("返回数据", res) })
vue3 axios simple encapsulation tutorial
First create a new utils folder in the root directory, and create two new files below, requests .js and html.js
requests.js is used to introduce axios and set the root domain name and some default settings, interceptors, etc.
import axios from "axios"; const service = axios.create({ baseURL: 'http://localhost:3000', timeout: 10000, }) // 请求拦截器 service.interceptors.request.use(config=>{ return config },err=>{ return Promise.reject(err) //返回错误 }) // 响应拦截器 service.interceptors.response.use(res=>{ return res },err=>{ return Promise.reject(err) //返回错误 }) export default service
After writing, expose the created instance object and introduce it in html.js
The function of the html.js file is to call the instance object of requests and all access Store it in this file (api) and import it as needed when using it.
import request from "./requests"; export const GetPosts = () => request.get('posts/1') export const GetsearchData = (params) => request.get('/list',{params}) export const PostPosts = (params) => request.post('posts',params)
Introduced files:
<template> <el-button type="primary" @click="clickGet">点我发送get请求</el-button> <el-button type="primary" @click="clickPost">点我发送post请求</el-button> <el-button type="primary" @click="clickPut">点我发送put请求</el-button> <el-button type="primary" @click="clickDel">点我发送delete请求</el-button> </template> <script> import { GetPosts, PostPosts } from "../../utils/html" export default { setup(){ function clickGet(){ GetPosts().then(res => { console.log(res) }) // axios({ // method: 'GET', // url: 'http://localhost:3000/posts' // }).then(res => { // console.log(res) // }) } function clickPost(){ PostPosts({ title: '我超级喜欢打游戏', author: '账本儿erer', age: '24' }).then(res => { console.log(res) }) } function clickPut(){ } function clickDel(){ } return { clickDel, clickGet, clickPost, clickPut } } } </script> <style> </style>
The above is the detailed content of How vue3 solves the axios request encapsulation problem. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

It is very common to use axios in Vue applications. axios is a Promise-based HTTP client that can be used in browsers and Node.js. During the development process, the error message "Uncaught(inpromise)Error: Requestfailedwithstatuscode500" sometimes appears. For developers, this error message may be difficult to understand and solve. This article will explore this

Recently, during the development of Vue applications, I encountered a common problem: "TypeError: Failedtofetch" error message. This problem occurs when using axios to make HTTP requests and the backend server does not respond to the request correctly. This error message usually indicates that the request cannot reach the server, possibly due to network reasons or the server not responding. What should we do after this error message appears? Here are some workarounds: Check your network connection due to

How to solve the problem of "Error: NetworkError" when using axios in Vue application? In the development of Vue applications, we often use axios to make API requests or obtain data, but sometimes we encounter "Error: NetworkError" in axios requests. What should we do in this case? First of all, you need to understand what "Error:NetworkError" means. It usually means that the network connection

Efficiently utilize Vue and Axios to implement batch processing of front-end data. In front-end development, data processing is a common task. When we need to process a large amount of data, processing the data will become very cumbersome and inefficient if there is no effective method. Vue is an excellent front-end framework, and Axios is a popular network request library. They can work together to implement batch processing of front-end data. This article will introduce in detail how to efficiently use Vue and Axios for batch processing of data, and provide relevant code examples.

Choice of data request in Vue: AxiosorFetch? In Vue development, handling data requests is a very common task. Choosing which tool to use for data requests is a question that needs to be considered. In Vue, the two most common tools are Axios and Fetch. This article will compare the pros and cons of both tools and give some sample code to help you make your choice. Axios is a Promise-based HTTP client that works in browsers and Node.

A complete guide to implementing file upload in Vue (axios, element-ui) In modern web applications, file upload has become a basic function. Whether uploading avatars, pictures, documents or videos, we need a reliable way to upload files from the user's computer to the server. This article will provide you with a detailed guide on how to use Vue, axios and element-ui to implement file upload. What is axiosaxios is a prom based

Using Vue to build custom elements WebComponents is a collective name for a set of web native APIs that allow developers to create reusable custom elements (customelements). The main benefit of custom elements is that they can be used with any framework, even without one. They are ideal when you are targeting end users who may be using a different front-end technology stack, or when you want to decouple the final application from the implementation details of the components it uses. Vue and WebComponents are complementary technologies, and Vue provides excellent support for using and creating custom elements. You can integrate custom elements into existing Vue applications, or use Vue to build

What should I do if "Error: timeoutofxxxmsexceeded" occurs when using axios in a Vue application? With the rapid development of the Internet, front-end technology is constantly updated and iterated. As an excellent front-end framework, Vue has been welcomed by everyone in recent years. In Vue applications, we often need to use axios to make network requests, but sometimes the error "Error: timeoutofxxxmsexceeded" occurs.
