Vue全栈开发旅游网项目(11)-用户管理前端接口联调

联调基本步骤

1.阅读接口文档 2.配置接口地址 3.使用axios获取数据 4.将数据设置到模型层

1.发送验证码联调

1.1 配置接口地址

文件地址:src\utils\apis.js

javascript 复制代码
//系统相关的接口
const SystemApis = {
    sliderListUrl:apiHost+"/system/slider/list/",
    //发送验证码
    sendSmsCodeUrl:apiHost+"/system/send/sms/"
}

1.2 使用axios获取数据

文件地址:src\components\common\SendSmsCode.vue

html 复制代码
<script setup>
//导入异步提交工具
import { ajax } from '@/utils/ajax';
//导入接口地址列表
import { SystemApis } from "@/utils/apis"
//导入提示框组件
import { showToast } from 'vant';

//发送验证码
const sendSmsCode = () => {
    //判断手机号是否输入
    if (!props.phoneNum) {
        showToast('请输入手机号码')
        return false
    }
    //调用接口,发送短息
    ajax.post(SystemApis.sendSmsCodeUrl,{
        phone_num:props.phoneNum
    }).then(({data})=>{  
        //提示验证码已经发送
        let message = `验证码为:${data.sms_code},${data.timeout/60}分钟内有效`
        showToast(message)
        //开始倒计时
        isSmsSend.value = true
        countDown()
      }).catch(err=>{
        //如果产生异常,提示重新操作
        isSmsSend.value = false
        sendBtnText.value = '点击发送验证码'
      })
}
</script>

data.timeoutdata.sms_codesystem/forms.py中调节格式:

1.3 代码效果展示

2.用户注册接口联调

2.1 配置接口地址

文件地址:src\utils\apis.js

javascript 复制代码
//用户相关的接口
const AccountApis={
    //用户注册
    registerUrl:apiHost+'/accounts/user/api/register/'
}
//对外暴露
export{
    AccountApis
}

2.2 使用axios获取数据

文件地址:src\views\accounts\Register.vue

javascript 复制代码
<script setup>
//导入异步提交工具
import { ajax } from '@/utils/ajax';
//导入接口地址列表
import { AccountApis } from '@/utils/apis';
//导入提示框组件
import { showToast } from 'vant';

const onSubmit = () => {
    // 提交表单
    // 1.调用接口
    ajax.post(AccountApis.registerUrl,{
        username:form.value.username,
        password:form.value.password,
        sms_code:form.value.sms_code,
        nickname:form.value.nickname
    }).then((data)=>{
        // 2.提示用户
        showToast('注册成功')
        // 3.跳转到个人中心页面
        router.push({name:'Mine'})
    })
}
</script>

2.3 输入错误信息提示

由于格式原因,避免一一调试,

账号被占用的400提示,选择用弹窗的提示模式弹出。

文件地址:src\utils\ajax.js

javascript 复制代码
//响应拦截器
ajax.interceptors.response.use((reqs)=>{
    return reqs
},(err)=>{
    if(err.response.status==401){
        window.alert('未登录,即将跳转到登陆页面')
    }
    👇
    if(err.response.status==400){
        window.alert('手机号码被占用')
    }
    return Promise.reject(err)
    👆
})
相关推荐
某公司摸鱼前端8 分钟前
uniapp socket 封装 (可拿去直接用)
前端·javascript·websocket·uni-app
要加油哦~10 分钟前
vue | 插件 | 移动文件的插件 —— move-file-cli 插件 的安装与使用
前端·javascript·vue.js
小林学习编程15 分钟前
Springboot + vue + uni-app小程序web端全套家具商场
前端·vue.js·spring boot
柳鲲鹏17 分钟前
WINDOWS最快布署WEB服务器:apache2
服务器·前端·windows
weixin-a153003083161 小时前
【playwright篇】教程(十七)[html元素知识]
java·前端·html
ai小鬼头2 小时前
AIStarter最新版怎么卸载AI项目?一键删除操作指南(附路径设置技巧)
前端·后端·github
一只叫煤球的猫2 小时前
普通程序员,从开发到管理岗,为什么我越升职越痛苦?
前端·后端·全栈
vvilkim2 小时前
Electron 自动更新机制详解:实现无缝应用升级
前端·javascript·electron
vvilkim3 小时前
Electron 应用中的内容安全策略 (CSP) 全面指南
前端·javascript·electron
aha-凯心3 小时前
vben 之 axios 封装
前端·javascript·学习