vue---Axios网络请求封装

一、封装意义

封装是因为axios使用率实在是太高了,为了程序后期的可维护性,我们会把同样的东西放在一起,后期找起来会很方便,这就是封装的主要意义。在日常应用过程中,一个项目中的网络请求会很多,此时一般采取的方案是将网络请求封装起来。

二、拦截器

拦截器最常用,因为在发送网络请求之前和获取到网络请求给我们返回的数据之前都可能需要把这个请求给拦截一下,做一些额外的处理。

拦截分为两类:①发送数据之前 ②获取数据之前

三、封装过程

1、首先需要安装axios,在终端输入:cnpm install --save axios

2、安装querystring,在终端输入:cnpm install --save querystring

3、启动程序,在终端输入:npm run serve

4、在src中创建一个文件夹叫utils,在utils中创建一个网络请求文件叫request.js 

5、当methods="post"要额外做处理,因为post参数的格式需要我们转化,这个时候就可以放到拦截器里面,日后再使用这个网络请求的时候,就不需要操心格式的问题了。

6、在request.js中输入:

import axios from "axios"
import querystring from "querystring"
const errorHandle = (status,info) =>{
    switch(status){
        case 400:
            console.log("语义有错");
            break;
        case 401:
            console.log("服务器认证失败");
            break;
        case 403:
            console.log("服务器拒绝访问");
            break;
        case 404:
            console.log("地址错误");
            break;
        case 500:
            console.log("服务器遇到意外");
            break;
        case 502:
            console.log("服务器无响应");
            break;
        default:
            console.log(info);
            break;
    }
}

//创建一个属于自己的网络请求的对象
const instance = axios.create({
    //这一块区域放置网络请求的公共配置
    timeout:5000
})

//发送数据之前
//拦截器的对象叫interceptors再通过request(发送的意思),通过use方法处理这个拦截器

instance.interceptors.request.use(
    config =>{
        if(config.methods ==="post"){
            config.data = querystring.stringify(config.data)
        }
        //config包含网络请求的所有信息
        return config;
    },
    error =>{
        return Promise.reject(error)
    }
)

//获取数据之前,response(响应对象)
instance.interceptors.response.use(
    response =>{
        return response.status === 200 ? Promise.resolve(response) : Promise.reject(response)
        //状态码是200就resolve成功,如果不是则reject失败
    },
    error =>{
        const { response } = error;
        errorHandle(response.status,response.info)
    }
)
export default instance;

注:不管是哪个状态码错误,代表整个网络请求是成功的,如果是走了error代表整个网络请求在发送和接收过程中出现问题。

7、在src中创建一个文件夹叫api(api内放置的网络请求,utils中的request.js只是网络请求的方法)。

8、在api文件夹下创建path.js和index.js

9、打开path.js,输入:

const base = { //放置所有的路径
    //公共路径 
    baseUrl:"http://iwenwiki.com",
    chengpin:"/api/blueberrypai/getChengpinDetails.php"
}

//base导出
export default base;

10、打开index.js,输入:

//放置所有网络请求的方法
import axios from "../utils/request"
import path from "./path"

const api = {
    //成品详情地址,当访问这个getChengpin方法,就能拿到这个网络请求的结果了
    getChengpin(){
        return axios.get(path.baseUrl + path.chengpin)
    }
}
export default api;

11、打开HelloWorld.vue,输入:

<template>
</template>

<script>
    import api from "../api/index"
    export default{
        name:'HelloWorld',
        props{
            msg:String
        },
        mounted(){
            api.getChengpin().then(res =>{
                    console.log(res.data);
            })
        }
    }
</script>

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vue-element-admin中,可以使用axios进行转发设置。axios是一个基于Promise的HTTP客户端,用于浏览器和Node.js。它可以将请求发送到后端服务器并接收响应数据。 要设置axios的转发,你可以按照以下步骤进行操作: 1. 打开项目目录下的`src/utils/request.js`文件。这是封装axios请求方法的文件。 2. 在该文件中找到`createRequest`函数,在函数体内找到`service`对象。 3. `service`对象是一个axios实例,你可以通过该实例来设置转发。例如,可以使用`service.interceptors.request.use()`方法来添加请求拦截器,使用`service.interceptors.response.use()`方法来添加响应拦截器。 4. 在请求拦截器中,你可以对请求进行一些处理,例如添加请求头、设置token等。 5. 在响应拦截器中,你可以对响应进行一些处理,例如对错误进行统一处理、对返回数据进行格式化等。 6. 另外,你还可以在`src/api`文件夹中的每个API接口文件中,根据需要使用axios进行转发设置。 总结起来,要在vue-element-admin项目中设置axios的转发,你需要找到`src/utils/request.js`文件,并根据需要使用`service.interceptors.request.use()`和`service.interceptors.response.use()`方法进行拦截器的设置。这样可以对请求和响应进行统一处理和转发。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue-element-admin:vue-element-admin](https://download.csdn.net/download/weixin_42168745/16228234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [vue-element-admin-template](https://download.csdn.net/download/weixin_42142062/15991791)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [浏览器显示数据库中数据的条形图柱状图 前后端分离vue.js+spring boot 计算机软件工程课程设计毕业设计 ...](https://download.csdn.net/download/Amzmks/88275824)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值