IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue3封装axios 处理跨域,引用element-plus loading,响应拦截引用Router -> 正文阅读

[JavaScript知识库]vue3封装axios 处理跨域,引用element-plus loading,响应拦截引用Router

就是先封装axios成一个工具类,然后axios默认是不允许跨域的,得配置一下,最后在发起请求到收到响应可以选择性的调用element-plus loading,使页面交互更契合,然后有些接口在返回时可能检测到未登录,所以在axios封装工具类中,应该用路由转跳到登录或首页

main.js如下

import { createApp } from 'vue'
import App from './App.vue'
import router from './router'

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import http from '@/http'
const app = createApp(App)
app.use(router)
app.use(ElementPlus)
let lsy=app.mount('#app')
http.setMyLoading(lsy.$loading)
http.setRouter(lsy.$router)

这里是lsy而不是app,因为app现在还不是vue实例

新建http.js工具文件

http.js如下

import axios from 'axios'

import qs from 'qs' //qs 是一个增加了一些安全性的查询字符串解析和序列化字符串的库
axios.defaults.withCredentials=true; //请求携带cookie 


var MyLoading=null;
var MyRouter=null;
var baseURL='/api';
const instance = axios.create({
    baseURL
  })


let interceptorsRequest=function(config){
    config.headers['token'] =null;
    return config;
}
// 在发送请求之前带上一些东西,config是请求的配置对象,如果直接返回就等于什么都不带
   
instance.interceptors.request.use(interceptorsRequest)



//用创建的axios实例生成请求拦截器
let interceptorsResponse=function(response){
    if(response.data.code==401){
        console.log(this.MyRouter)
        console.log("需要登录");
        return;
    }
    return response;
}
instance.interceptors.response.use(interceptorsResponse)

let myAxios=function(method,url,params,isLoading=false){
    let tempLoad=null;
    if(isLoading){tempLoad=this.MyLoading}else{
        tempLoad=function(){return null}
    }
    if(method=="post"||method=='Post'||method=='POST'){params=qs.stringify(params)}
    let resolveAndReject=function(resolve,reject){
        let success=function(response){return resolve(response.data)}
        let error=function(error){return reject(error)}
        let object={method:method,url,data:params}
        let option={lock: true,text: '加载中',background: 'rgba(0, 0, 0, 0.7)'}
        let loading=tempLoad(option)
        instance(object,{withCredentials:true}).then(success).catch(error)
        if(loading){loading.close();}
    }
    return new Promise(resolveAndReject);
     //Promise构造函数接收一个函数作为参数,该参数的两个参数是resolve,reject,
     //它们由javaScript引擎提供,其中resolve函数的作用是当Promise对象转移成功,调用resolve并将操作结果作为参数传递出去
     //reject函数的作用是单Promise对象的状态变成为失败时,将操作报出的错误作为其参数传递出去
 }


 let setMyLoading=function(value){
    this.MyLoading=value;
 }
 
 let setRouter=function(value){
     this.MyRouter=value;
 }

 export default{myAxios,setMyLoading,setRouter}


然后负责每个具体请求的js工具类
如其中一个request.js

request.js如下

import http from '@/http'


let token=localStorage.getItem('token')

const post=function(url,data){
   return http.myAxios("post",url,data)
}

const get=function(url,data){
    return http.myAxios("get",url,data)
}

let test=function(path,data){
  return post(path,data)
}
//接口导出
export {test}

配置一下代理跨域

在vue.config.js中修改

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  transpileDependencies: true,
  productionSourceMap: false ,// 打包时不会生成.map文件,加快打包速度
  lintOnSave: false,//将leslint检测机制关闭即可 
  devServer: {
    proxy: {//https://www.jianshu.com/p/ca7d5918cebe
        '/api': {
            // 此处的写法,目的是为了 把上面  /api 替换成 http://127.0.0.1:3000/
            // 如果使用的是自己封装的请求函数 那么你应该这样写 baseURL: '',
            // 注意这里的 api 是必须的,因为是有代理的缘故
            target: 'http://localhost:8081',
            // 允许跨域
            changeOrigin: true,
            ws: true,
            pathRewrite: {'^/api': ''}
        }
    }
  }
})

proxy:{}对象是我添加的

最后调用

<template>
    <el-button type="primary" v-on:click="myclick">点击弹框</el-button>
</template>
<script >
import {test} from '@/request'
export default {
    name: 'MyView',
    methods: {
      myclick(){         
            let mysuccess=function(res){console.log("返回的数据",res)}
            test('/lsy',null).then(mysuccess);
        }
}
}
</script>
<style scoped>

</style>

打完收工

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-22 20:27:56  更:2022-03-22 20:30:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:41:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码