当前位置: 首页 > news >正文

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

联调基本步骤

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

1.发送验证码联调

1.1 配置接口地址

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

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

1.2 使用axios获取数据

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

<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 = truecountDown()}).catch(err=>{//如果产生异常,提示重新操作isSmsSend.value = falsesendBtnText.value = '点击发送验证码'})
}
</script>

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

1.3 代码效果展示

 

2.用户注册接口联调

2.1 配置接口地址

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

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

2.2 使用axios获取数据

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

<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

//响应拦截器
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)👆
})

http://www.lryc.cn/news/484068.html

相关文章:

  • react 中 useContext Hook 作用
  • 【HarmonyOS】鸿蒙系统在租房项目中的项目实战(一)
  • 前 K 个高频元素
  • 【ubuntu】Geogebra
  • vue2和vue3的区别详解
  • 一文读懂LEED绿建
  • git上feature合并到development分支
  • NVR录像机汇聚管理EasyNVR多品牌NVR管理工具/设备:大华IPC摄像头局域网访问异常解决办法
  • 校园二手交易网站毕业设计基于SpringBootSSM框架
  • 基于大语言模型意图识别和实体提取功能;具体ZK数值例子:加密货币交易验证;
  • 论文笔记 SuDORMRF:EFFICIENT NETWORKS FOR UNIVERSAL AUDIO SOURCE SEPARATION
  • 机器学习系列----KNN分类
  • 贪心算法day 06
  • HTML之列表学习记录
  • Redo与Undo的区别:数据库事务的恢复与撤销机制
  • 【话题讨论】AI赋能电商:创新应用与销售效率的双轮驱动
  • 重构开发之道,Blackbox.AI为技术注入智能新动力
  • 机器学习在医疗健康领域的应用
  • M芯片Mac构建Dockerfile - 注意事项
  • 系统架构设计师论文
  • 速盾:CDN 和高防有什么区别?
  • goframe开发一个企业网站 rabbitmq队例15
  • 设计模式-七个基本原则之一-迪米特法则 + 案例
  • 【数学二】线性代数-二次型
  • 320页PDF | 集团IT蓝图总体规划报告-德勤(限免下载)
  • HTB:Sea[WriteUP]
  • Java 网络编程(一)—— UDP数据报套接字编程
  • ECharts图表图例8
  • Redis中的线程模型
  • [产品管理-77]:技术人需要了解的常见概念:科学、技术、技能、产品、市场、商业模式、运营