Vue前端异步方法

例子

java 复制代码
// 确认验证码
const clickSureCode=async()=>{
    let reslut = await UserSureCodeService(userInfo.value)
    console.log("异步后"+reslut.data)
    if(reslut.code === 0){
        ElMessage.success("邮箱验证成功")
        originEmail.value=reslut.value
        // 更改修改状态
        cancleEmail()
    }else{
        ElMessage.error(reslut.value)
    }

}

async()表示该方法是异步,await 表示在执行完UserSureCodeService 方法后,在执行接下来的console.log("异步后"+reslut.data )。如果不使用,这个data数据会是Undefine。

这里使用了Axios的简明写法。要使用Axios有以下步骤:

  1. npm install axios
  2. 在你的 JavaScript 文件中,使用 import 关键字引入 Axios。即import axios from 'axios';

可以在request中封装一系列方法。

java 复制代码
//导入axios  npm install axios
import axios from 'axios';
import{ElMessage} from 'element-plus'

import router from '@/router/router.js'
//定义一个变量,记录公共的前缀  ,  baseURL
const baseURL = '/api';
const instance = axios.create({baseURL})

//添加响应拦截器
instance.interceptors.response.use(
    result=>{
        if(result.data.code===0){
            return result.data;
        }
        ElMessage.error(result.data.message)
        // 异步操作转为失败
        return Promise.reject(result.data);
    },
    err=>{
    //如果响应状态码时401,代表未登录,给出对应的提示,并跳转到登录页
         if(err.response.status===401){
            ElMessage.error('请先登录!')
            // 跳转到登录
            router.push('/login')
        }else{
                ElMessage.error('服务异常');
            }
        return Promise.reject(err);//异步的状态转化成失败的状态
    }   
)

//导入token状态
import { useTokenStore } from '@/store/token.js';


//添加请求拦截器
instance.interceptors.request.use(
    (config)=>{
        //在发送请求之前做什么
        let tokenStore = useTokenStore()
        //如果token中有值,在携带
        if(tokenStore.token){
            config.headers.Authorization=tokenStore.token
        }
        return config
    },
    (err)=>{
        //如果请求错误做什么
        Promise.reject(err)
    }
)


export default instance;

这里封装了一个对象instance,它又Aixos创建而来,还给他添加了拦截器功能。

应用

java 复制代码
import request from  '@/utils/request.js'
 
// 登录
export const loginUserService=(registerData)=>{
    const params = new URLSearchParams()
    for (let key in registerData){
        params.append(key,registerData[key])
    }
    return request.post('/user/login',params)
}

首先导入request.js,utils是我自己的创建的包,这里只是路径而已。此时前端要访问后端方法路径,只需要request.post或request.get即可。

相关推荐
蟾宫曲3 小时前
在 Vue3 项目中实现计时器组件的使用(Vite+Vue3+Node+npm+Element-plus,附测试代码)
前端·npm·vue3·vite·element-plus·计时器
秋雨凉人心3 小时前
简单发布一个npm包
前端·javascript·webpack·npm·node.js
liuxin334455663 小时前
学籍管理系统:实现教育管理现代化
java·开发语言·前端·数据库·安全
qq13267029403 小时前
运行Zr.Admin项目(前端)
前端·vue2·zradmin前端·zradmin vue·运行zradmin·vue2版本zradmin
LCG元4 小时前
Vue.js组件开发-使用vue-pdf显示PDF
vue.js
魏时烟4 小时前
css文字折行以及双端对齐实现方式
前端·css
哥谭居民00015 小时前
将一个组件的propName属性与父组件中的variable变量进行双向绑定的vue3(组件传值)
javascript·vue.js·typescript·npm·node.js·css3
烟波人长安吖~5 小时前
【目标跟踪+人流计数+人流热图(Web界面)】基于YOLOV11+Vue+SpringBoot+Flask+MySQL
vue.js·pytorch·spring boot·深度学习·yolo·目标跟踪
踢足球的,程序猿5 小时前
Android native+html5的混合开发
javascript
2401_882726485 小时前
低代码配置式组态软件-BY组态
前端·物联网·低代码·前端框架·编辑器·web