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)
    👆
})
相关推荐
codeniu4 分钟前
@logicflow/vue-node-registry 在 Vite 中无法解析的踩坑记录与解决方案
前端·javascript
孟祥_成都10 分钟前
AI 术语满天飞?90% 的人只懂名词,不懂为什么!
前端·人工智能
Lupino37 分钟前
被 React “玩弄”的 24 小时:为了修一个不存在的 Bug,我给大模型送了顿火锅钱
前端·react.js
米丘44 分钟前
了解 Javascript 模块化,更好地掌握 Vite 、Webpack、Rollup 等打包工具
前端
Heo1 小时前
深入 React19 Diff 算法
前端·javascript·面试
滕青山1 小时前
个人所得税计算器 在线工具核心JS实现
前端·javascript·vue.js
小怪点点1 小时前
手写promise
前端·promise
国思RDIF框架1 小时前
RDIFramework.NET Web 敏捷开发框架 V6.3 发布 (.NET8+、Framework 双引擎)
前端
Mintopia1 小时前
如何在有限的时间里,活出几倍的人生
前端
炫饭第一名1 小时前
速通Canvas指北🦮——变形、渐变与阴影篇
前端·javascript·程序员