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

永康企业网站建设网站301跳转

永康企业网站建设,网站301跳转,网站群管理建设工作,龙岩网站建设teams熊掌号目录 前言 开篇语 准备工作 正文 概念 封装工具包 示例 结束语 前言 开篇语 本系列为短篇,每次讲述少量知识点,无需一次性灌输太多的新知识点。该主题文章主要是围绕前端、全栈开发相关面试常见问题撰写的,希望对诸位有所帮助。 如…

目录

前言

开篇语

准备工作

正文

概念

封装工具包

示例

结束语


前言

开篇语

本系列为短篇,每次讲述少量知识点,无需一次性灌输太多的新知识点。该主题文章主要是围绕前端、全栈开发相关面试常见问题撰写的,希望对诸位有所帮助。

如果您需要为面试八股文做准备,笔者建议重点关注加粗强调部分,它们是概念中的关键词。

准备工作

软件:【参考版本】Visual Studio Code

第三方js库(框架):【参考版本】Vue3,Axios(ver1.7.9)

搭建工具:Vite

系统版本: Win10/11

正文

概念

为了实现前后端交互,在前端我们需要向后端接口发送http请求,并根据反馈的结果进行数据的渲染。在Vue3中,我们可以使用第三方库Axios实现这一功能。

Axios是一个基于Promise的http客户端,用于浏览器和 Node.js 环境。它提供了简单易用的API,用于发送http请求并处理响应。它提供了请求拦截器响应拦截器,可以在请求发送前或响应到达后对其进行处理,如添加认证头、处理错误等。此外,Axios会自动将请求和响应的JSON数据转换为JavaScript对象,无需手动解析。

本文中的开发环境为Windows10,使用npm安装Axios。

封装工具包

对于项目开发来说,发送Http是一种非常常见的需求,因此我们可以将发送请求的共同代码封装为工具包,以降低代码冗余度,同时方便开发。

新建一个utils工具包(如果没有创建的话),新建两个js文件——http.jspostApi.js

在http.js中,添加如下代码——

import axios from "axios";const instance = axios.create({timeout: 3000,headers: { "X-Custom-Header": "foobar" },
});// 添加请求拦截器
instance.interceptors.request.use(function (config) {// 在发送请求之前做些什么return config;},function (error) {// 对请求错误做些什么return Promise.reject(error);}
);// 添加响应拦截器
instance.interceptors.response.use(function (response) {// 对响应数据做点什么return response.data;},function (error) {// 对响应错误做点什么return Promise.reject(error);}
);export default instance;

然后,在postApi.js中,添加如下的代码——

import http from "@/utils/http"export const postApi = (routePath, params = null) => {// 接口路径添加/api以配置跨域,根据后端给的接口来const path = '/api' + routePath;if (params != null) {// 需要FormData类型数据作为参数const formData = new FormData();Object.entries(params).forEach(([key, value]) => {formData.append(key, value)})return http.post(path, formData)} else {// 不需要参数return http.post(path)}
}

这里演示的是发送post请求的方式,如果需要发送get请求,则可以类比使用http.get(path)。

示例

在项目中,一个实际的发送Axios的示例如下——

const handleLogin = () => {formLogin.value.validate().then(async () => {try {// 向登录接口发送登录请求信息const res = await postApi('/login', data.user);if (res.code == 200) {ElMessage({message: '登录成功',type: 'success',duration: 1000});setTimeout(async () => {// 解构用户信息并存储const { userId, userName, superAdmin, menuList, permissionCodeList } = res.data;const user = { userId, userName, superAdmin };await store.dispatch('setUserAction', { user, menuList, permissionCodeList });// 跳转主页if (menuList.length > 0) {router.push("/main");}}, 1200);} else {// 返回登录失败信息ElMessage.error(res.info);// 重新获取验证码data.src = '/api/checkCode?' + (Math.random().toString().replace(".", ""));data.user.checkCode = "";}} catch (err) {ElMessage.error(err);}}).catch(err => {ElMessage.error(JSON.stringify(err));})
}

该示例结合了Element-Plus组件,简单实现了发送用户账户密码信息完成登录请求的功能。

结束语

本期内容到此结束。关于本系列的其他博客,可以查看我的面试题专栏。

本系列的博客主要是记录学习经历,并总结阶段的知识点。全篇的操作过程由笔者完成并核验,在部分定义上有参考其他的内容。希望这对您有所帮助,并真心地祝您早日找到心仪的工作岗位。

==期待与你在下一期博客中再次相遇==

——分解的【H2O2】

http://www.dtcms.com/a/517867.html

相关文章:

  • 旅游网站简介惠州app开发公司
  • ai里做的图片方网站上不清楚c 网站建设可视化实现
  • 那种退不掉的网站怎么做的广州做模板网站的公司
  • 阜阳网站建设价格低衣柜推拉门图案设计网站
  • 网站如何引导wordpress获取文章标签
  • 医疗设备公司的网站怎么做找网络推广策畿
  • 南昌做网站哪里好蚌埠企业做网站
  • 【开题答辩全过程】以 基于大数据农产品管理系统为例,包含答辩的问题和答案
  • 松江品划做企业网站浙江省住房和城乡建设厅官方网站
  • 使用wordpress快速建站视频教程怎么做盲盒
  • 基于Python楼王争霸劳动竞赛数据处理分析
  • 阿里巴巴网站建设的基本情况WordPress页脚随机文章
  • 南京企业网站seo做网站怎么做鼠标跟随
  • 沈阳网站关键字优化什么值得买网站模版
  • 51c大模型~合集26
  • 深圳网站开发的公司电话薪酬体系搭建工具
  • 餐饮设计公司网站xml做网站源码
  • 自己做网站排名wordpress 获取标签所有文章
  • 做网站数据库表设计抖音seo怎么做
  • OCR的“文艺复兴”:实测登顶HuggingFace的PaddleOCR-VL与DeepSeek-OCR
  • 什么学做网站网站开发顶岗实践总结
  • 用手机可以做网站wordpress文件读取漏洞
  • Python学习(11) ----- Python的泛型
  • 庆阳有人做农资网站吗wordpress+重装教程
  • 石家庄求职信息网百度seo关键词怎么设置
  • 仿360电影网站源码网站离线浏览器 怎么做
  • 怎么下载建设银行网站thinkphp开源cms系统
  • 从海量文档到精准数据:文档抽取技术驱动金融财税决策新范式
  • 如何对网站页面进行优化虚拟主机比较
  • 云智网站建设公司常州溧阳建设工程管理中心网站