【VUE】6、VUE项目中引入axios

这篇具有很好参考价值的文章主要介绍了【VUE】6、VUE项目中引入axios。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、初识 axios

Axios,是一个基于 promise 的网络请求库,作用于 node.js 和浏览器中,它是 isomorphic 的(即同一套代码可以运行在浏览器和 node.js 中)。在服务端它使用原生 node.js http 模块, 而在客户端 (浏览端) 则使用 XMLHttpRequest。

  • 主要特点:

从浏览器创建 XMLHttpRequests
从 node.js 创建 http 请求
支持 Promise API
拦截请求和响应
转换请求和响应数据
取消请求
自动转换JSON数据
客户端支持防御XSRF

2、安装 axios

  • 1、安装 axios
npm install axios
  • 2、挂载 axios
    在 main.js 文件中,添加如下内容:
import axios from 'axios'
Vue.prototype.$http= axios

我们便可以通过 this.$http 的方式来发起请求了

3、配置网络代理

const {defineConfig} = require('@vue/cli-service')

module.exports = defineConfig({
    transpileDependencies: true,
    devServer: {
        // 指定使用的ip地址,默认为localhost,如果使用'0.0.0.0'则可以被外部访问
        host: '0.0.0.0',
        // 指定服务监听的端口号
        port: 9527,
        // 代理
        proxy: {
            [process.env.VUE_APP_BASE_API]: {
                target: 'http://localhost:8080',
                changeOrigin: true,
                pathRewrite: {
                    ['^' + process.env.VUE_APP_BASE_API]: ''
                }
            }
        }
    }
})

其中,process.env.VUE_APP_BASE_API 为我们在多环境配置文件中配置的请求路径,例如,.env.development 文件:

# Asurplus管理系统/开发环境
VUE_APP_BASE_API = '/dev-api'

则我们发出的请求路径为:

http://localhost:9527/dev-api/xxx

4、使用 axios

httpTest() {
  this.$http.get(process.env.VUE_APP_BASE_API + '/test').then(res => {
    console.log(res)
  })
}

得到的响应:

{
    "data":{
        "msg":"操作成功",
        "code":200,
        "data":"this is data"
    },
    "status":200,
    "statusText":"OK",
    "headers":{
        "connection":"close",
        "content-encoding":"gzip",
        "content-type":"application/json;charset=UTF-8",
        "date":"Mon, 03 Apr 2023 06:47:10 GMT",
        "transfer-encoding":"chunked",
        "vary":"Accept-Encoding",
        "x-powered-by":"Express"
    },
    "config":{
        "transitional":{
            "silentJSONParsing":true,
            "forcedJSONParsing":true,
            "clarifyTimeoutError":false
        },
        "adapter":[
            "xhr",
            "http"
        ],
        "transformRequest":[
            null
        ],
        "transformResponse":[
            null
        ],
        "timeout":0,
        "xsrfCookieName":"XSRF-TOKEN",
        "xsrfHeaderName":"X-XSRF-TOKEN",
        "maxContentLength":-1,
        "maxBodyLength":-1,
        "env":{

        },
        "headers":{
            "Accept":"application/json, text/plain, */*"
        },
        "method":"get",
        "url":"/dev-api/test"
    },
    "request":{

    }
}

可以看到,包括一些网络的响应状态及信息也一起拿到了,但是这样我们每次都需要判断 httpStatus 是否为 200,才能进行正常的业务逻辑处理,非常繁琐

5、配置请求拦截器和响应拦截器

import axios from 'axios'
import {Message} from 'element-ui'

axios.defaults.headers['Content-Type'] = 'application/json;charset=utf-8'
// 创建axios实例
const service = axios.create({
    // axios中请求配置有baseURL选项,表示请求URL公共部分
    baseURL: process.env.VUE_APP_BASE_API,
    // 超时
    timeout: 10000
})
// request拦截器
service.interceptors.request.use(config => {
    // get请求映射params参数
    if (config.method === 'get' && config.params) {
        let url = config.url + '?';
        for (const propName of Object.keys(config.params)) {
            const value = config.params[propName];
            const part = encodeURIComponent(propName) + "=";
            if (value !== null && typeof (value) !== "undefined") {
                if (typeof value === 'object') {
                    for (const key of Object.keys(value)) {
                        let params = propName + '[' + key + ']';
                        const subPart = encodeURIComponent(params) + "=";
                        url += subPart + encodeURIComponent(value[key]) + "&";
                    }
                } else {
                    url += part + encodeURIComponent(value) + "&";
                }
            }
        }
        url = url.slice(0, -1);
        config.params = {};
        config.url = url;
    }
    return config
}, error => {
    Promise.reject(error)
})

// response拦截器
service.interceptors.response.use(res => {
        // 未设置状态码则默认成功状态
        const code = res.data.code || 200;
        // 获取错误信息
        const msg = res.data.msg
        if (200 !== code) {
            Message({
                message: msg,
                type: 'error'
            })
            return Promise.reject(new Error(msg))
        }
        // 返回响应信息
        else {
            return res.data
        }
    },
    error => {
        let {message} = error;
        if (message === "Network Error") {
            message = "后端接口连接异常";
        } else if (message.includes("timeout")) {
            message = "系统接口请求超时";
        } else if (message.includes("Request failed with status code")) {
            message = "系统接口" + message.substr(message.length - 3) + "异常";
        }
        Message({
            message: message,
            type: 'error',
            duration: 5 * 1000
        })
        return Promise.reject(error)
    }
)

export default service
  • 1、请求拦截器

1、默认请求头内容:Content-Type=application/json;charset=utf-8,如需要传递 token 等身份验证信息可在请求拦截器中加入
2、配置了默认请求超时时间:10s
3、get 请求如果传递了 params 参数,则将参数按照 ?key=value&key1=value1 的方式拼接在请求地址上

  • 2、响应拦截器

1、默认以返回的 code = 200 为成功响应,返回响应信息中的 data 对象
2、请求业务层面的错误响应则直接提示业务响应对象中的 msg 信息
3、请求网络层面的错误响应根据错误类型提示响应的提示信息

6、封装请求

  • 1、test.js
import request from '@/utils/request'

export function test(data) {
    return request({
        url: '/test',
        method: 'post',
        data: data
    })
}
  • 2、发起请求

引入我们刚刚配置的请求拦截器和响应拦截器,data 为我们需要传递的参数,在组件中使用:

import {test} from "@/api/test";
methods: {
  httpTest() {
    test(this.data).then(res => {
      console.log(res)
    })
  }
}

得到的响应:

{
    "msg":"操作成功",
    "code":200,
    "data":"this is data"
}

如您在阅读中发现不足,欢迎留言!!!文章来源地址https://www.toymoban.com/news/detail-409977.html

到了这里,关于【VUE】6、VUE项目中引入axios的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue写一个axios的拦截器

    要编写并生效Axios拦截器,可以按照以下步骤进行操作: 1.创建一个文件:在你的项目中,创建一个新的JavaScript文件,例如interceptors.js,用于编写拦截器代码。 2.导入所需的库和模块:在interceptors.js文件中,导入所需的Axios库和其他依赖项。 // 其他依赖项的导入 3.创建Axios实

    2024年02月12日
    浏览(47)
  • axios封装—vue3项目

    前言 axios的API很友好,可以在项目中直接使用。但是在大型项目中,http请求很多,且需要区分环境, 每个网络请求有相似需要处理的部分,会导致代码冗余,破坏工程的可维护性,扩展性,所以需要对axios请求进行相应的封装 正文 安装axios 封装请求api 1. 在src目录下新建个

    2024年02月07日
    浏览(28)
  • Vue电商项目--axios二次封装

    刚刚经过postman工具测试,发现接口果然发生了改变。 新的接口为 http://gmall-h5-api.atguigu.cn   如果服务器返回的数据code字段200,代表服务器返回数据成功 整个项目,接口前缀都有/api字样 XmlHttpRequest,fetch,JQ,Axios这些都是很优秀的网络请求库 为什么需要进行二次封装axios? 请

    2024年02月01日
    浏览(39)
  • Vue项目中axios的二次封装

    Vue 项目使用过程中一般会对 axios 进行二次封装, 以期在合适的时机处理一些全局的需求, 比如常见的 请求拦截器 和 响应拦截器. 接下来简单聊聊具体的操作步骤. 执行以下指令: 在 src 文件夹下创建 api 文件夹, 并创建 index.js、axios.js 和 users.js 文件. index.js 文件的作用的将当前

    2024年01月19日
    浏览(72)
  • Vue项目搭建及使用vue-cli创建项目、创建登录页面、与后台进行交互,以及安装和使用axios、qs和vue-axios

    目录 1. 搭建项目 1.1 使用vue-cli创建项目 1.2 通过npm安装element-ui 1.3 导入组件 2 创建登录页面 2.1 创建登录组件 2.2 引入css(css.txt) 2.3 配置路由 2.5 运行效果 3. 后台交互 3.1 引入axios 3.2 axios/qs/vue-axios安装与使用 3.2.1 安装axios 3.2.2 发送get请求: 3.2.3 发送post请求: 3.2.4 简化axio

    2024年02月07日
    浏览(39)
  • Vue项目中axios的原理(详细到源码)

    关于 axios 的基本使用,上篇文章已经有所涉及,这里再稍微回顾下: 构建一个 Axios 构造函数,核心代码为 request 导出 axios 实例 上述就已经能够实现 axios({ }) 这种方式的请求 下面是来实现下 axios.method() 这种形式的请求 将 Axios.prototype 上的方法搬运到 request 上 首先实现个工

    2024年01月20日
    浏览(66)
  • 基于Axios完成前后端分离项目数据交互

    npm i axios -S 封装一个请求工具:request.js  在vue 的 methods 中使用 :    或者直接在vue 中引用使用:  但是现在就运行程序则会报错 方法一:增加一个 CorsConfig 类  方法二:在controller层上加上@CrossOrigin 注解  两个方法任选其中一个就行。现在将前后端启动就可以进行数据交互

    2024年02月11日
    浏览(27)
  • Vue+Vite项目初建(axios+Unocss+iconify)

    npx --package @vue/cli vue 项目成功启动后,进入http://localhost:3200,即可进入创建好的页面(假设启动端口为3200) 假设有本地服务器地址localhost:8000提供接口服务,接口为localhost:8000/token,修改代码 执行代码,如果后端服务器执行正常,就会有相应的返回值 npm install -D unocss 修改 vit

    2024年02月19日
    浏览(29)
  • Vue3创建项目(四)axios封装及接口配置

    项目结构:  目录  🍉🍉🍉index.ts  🍉🍉🍉 api.ts 看完需要预计花费10分钟。 请求拦截器与响应拦截器  阅读下面代码需先了解以下内容:         请求拦截器:     请求拦截器的作用是在请求发送前进行一些操作,例如在每个请求体里加上token,每次请求携带token传给

    2024年02月03日
    浏览(37)
  • 再vue项目中使用axios原生发送post请求

    前言:在大多数项目开发中,都是采用前后端分离架构,在此情况下都采用一些成熟的框架,类似于ruoyi,因为成熟所以前端的请求都进行了各种封装,有时想单独发起一个简单的请求,还有点麻烦,因此记录一下。 因为是前后端分离,当前前端使用的端口是81,后端运行的

    2024年02月14日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包