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

西宁做网站君博认同南宁优化推广服务

西宁做网站君博认同,南宁优化推广服务,如何迁移wordpress,公司logo注册在 Vue 3 的项目开发中,使用 Axios 进行 HTTP 请求是非常常见的作法,为了更方便开发者更高效的进行代码编写和项目的维护,可以通过再次封装 Axios 来实现。 在本文中,博主将详细指导你如何在自己的 Vue 3 项目中使用 Axios 二次封…

        在 Vue 3 的项目开发中,使用 Axios 进行 HTTP 请求是非常常见的作法,为了更方便开发者更高效的进行代码编写和项目的维护,可以通过再次封装 Axios 来实现。

        在本文中,博主将详细指导你如何在自己的 Vue 3 项目中使用 Axios 二次封装 request 请求。

1.安装 Axios

        首先,确保我们的 Vue 3 项目已经安装了 Axios 。

如果尚未安装 Axios ,则可以定位到项目根目录下 (与src目录同级) ,运行命令行:

# 使用 npm 包管理器
npm install axios# 使用 yarn 包管理器
npm add axios# 使用 pnpm 包管理器
pnpm install axios

         随后,我们查看 package.json 配置文件中是否包含了 Axios 的配置信息:7090cc72391a41c08d1f35a4d996d456.png

 2.创建请求封装模块

        在项目中创建一个单独的模块用来封装 Axios 请求。(博主这里是 src/utils/request.ts)

第一步:创建一个新的 Axios 实例

/* request.ts  这里博主用的是 TypeScript */// 引入 Axios 库的功能,AxiosInstance 是 Axios 中自带的接口类型
import axios, { AxiosInstance } from 'axios';
import { ElMessage, ElMessageBox } from 'element-plus';      // 按需引入 Element-Plus 组件// 第一步:创建一个新的 Axios 实例
const service: AxiosInstance = axios.create({// 这里博主直接引用了开发环境配置文件中的路径, 也可自定义成网络地址baseURL: import.meta.env.VITE_API_URL,  // 或 http://${host}:${port}timeout: 5000,  // 设置请求超时,一般来说为 5 秒// 设置请求头类型:若非文件传输,一般情况下为 jsonheaders: { 'Content-Type': 'application/json' },  // 传输文件: multipart/form-data/* 自定义 Axios 的参数序列化过程* paramsSerializer 是 Axios 中的一个配置项,用于定义在发送 GET 请求时如何序列化 URL 参数* serialize 是一个自定义的方法,它接收一个 params 对象作为参数,并返回一个字符串* 在这里,它使用了 qs(可能是 querystring 库)来将参数对象 params 序列化为一个 URL 查询字符串* 这里的 qs.stringify 函数是一个用于序列化对象为 URL 查询字符串的方法*/paramsSerializer: {serialize(params) {return qs.stringify(params, { allowDots: true });}}
})

第二步:创建请求拦截器

// request.ts 文件中/** 已经完成了第一步*/// 第二步:创建请求拦截器
service.interceptors.request.use((config) => {// 这里可以在我们发送 request 网络请求前,为我们的 request 请求做一些配置// 例如:将 token 携带在请求头中config.headers!['Authorization'] = `Token ${Session.get('token')}`;return config},(error) => {// 错误调试return Promise.reject(error)}
)

 第三步:创建响应拦截器

/* request.ts 文件中 *//** 已完成第一步** 已完成第二步*/// 第三步:创建请求拦截器
service.interceptors.response.use((response) => {// 在这里,你可以对从后端拿到的数据进行处理const res = response.data;if (res.code === 400 || res.code === 401 || res.code === 403) {// 如果没有权限,可以清除浏览器中缓存的 session 信息Session.clear(); // 清除浏览器全部临时缓存window.location.href = '/'; // 去登录页ElMessageBox.alert('你已被登出,请重新登录', '提示', {}).then(() => { }).catch(() => { });return Promise.reject(service.interceptors.response);} else {return res;}},(error) => {// 对响应错误做点什么if (error.message.indexOf('timeout') != -1) {ElMessage.error('网络超时');} else if (error.message == 'Network Error') {ElMessage.error('网络连接错误');} else {if (error.response.data) ElMessage.error(error.response.statusText);else ElMessage.error('接口路径找不到');}return Promise.reject(error);}
)

 第四步:导出 Axios 实例

/* request.ts 文件中 *//** 已完成了上述三个步骤*/// 导出 axios 实例
export default service;

完整代码如下:

import axios, { AxiosInstance } from 'axios';
import { ElMessage, ElMessageBox } from 'element-plus';
import { Session } from '/@/utils/storage';
import qs from 'qs';// 配置新建一个 axios 实例
const service: AxiosInstance = axios.create({baseURL: import.meta.env.VITE_API_URL,timeout: 50000,headers: { 'Content-Type': 'multipart/form-data' },paramsSerializer: {serialize(params) {return qs.stringify(params, { allowDots: true });},},
});// 添加请求拦截器
service.interceptors.request.use((config) => {// 在发送请求之前做些什么 tokenif (Session.get('token')) {config.headers!['Authorization'] = `DavyJonesZ ${Session.get('token')}`;}return config;},(error) => {// 对请求错误做些什么return Promise.reject(error);}
);// 添加响应拦截器
service.interceptors.response.use((response) => {// 对响应数据做点什么const res = response.data;if (res.code && res.code !== 0) {// `token` 过期或者账号已在别处登录if (res.code === 401 || res.code === 4001) {Session.clear(); // 清除浏览器全部临时缓存window.location.href = '/'; // 去登录页ElMessageBox.alert('你已被登出,请重新登录', '提示', {}).then(() => { }).catch(() => { });return Promise.reject(service.interceptors.response);} else {return res;}} else {return res;}},(error) => {// 对响应错误做点什么if (error.message.indexOf('timeout') != -1) {ElMessage.error('网络超时');} else if (error.message == 'Network Error') {ElMessage.error('网络连接错误');} else {if (error.response.data) ElMessage.error(error.response.statusText);else ElMessage.error('接口路径找不到');}return Promise.reject(error);}
);// 导出 axios 实例
export default service;

3. 使用

        完成上述对于 Axios 的二次封装后,我们就可以在其他地方进行调用了

/* Vue 3 接口工具类:login.ts 文件中 */
import request from '/@/utils/request';// Login Api
export function login(data: object) {return request({url: '/user/login',method: 'POST',data})
}

        最后,只需要在Vue组件中,引入 login.ts 文件,并调用其 login 方法,就可以实现与后端接口的通信啦!(大功告成!!!)

 


文章转载自:
http://advantageous.xqwq.cn
http://fainthearted.xqwq.cn
http://wolfer.xqwq.cn
http://bleomycin.xqwq.cn
http://doer.xqwq.cn
http://metonymy.xqwq.cn
http://hypopsychosis.xqwq.cn
http://silundum.xqwq.cn
http://unlicensed.xqwq.cn
http://wiggle.xqwq.cn
http://phanerophyte.xqwq.cn
http://seepage.xqwq.cn
http://disinfector.xqwq.cn
http://debar.xqwq.cn
http://apparition.xqwq.cn
http://query.xqwq.cn
http://brazier.xqwq.cn
http://uso.xqwq.cn
http://formicary.xqwq.cn
http://phonetician.xqwq.cn
http://reiterant.xqwq.cn
http://scorpio.xqwq.cn
http://erbium.xqwq.cn
http://pokeweed.xqwq.cn
http://cahoot.xqwq.cn
http://gundog.xqwq.cn
http://suprapersonal.xqwq.cn
http://kunashiri.xqwq.cn
http://probationer.xqwq.cn
http://feticide.xqwq.cn
http://montanic.xqwq.cn
http://xylographic.xqwq.cn
http://thoroughgoing.xqwq.cn
http://rootless.xqwq.cn
http://chew.xqwq.cn
http://naiad.xqwq.cn
http://megarad.xqwq.cn
http://enticement.xqwq.cn
http://bananalander.xqwq.cn
http://carbon.xqwq.cn
http://gleed.xqwq.cn
http://calabash.xqwq.cn
http://nonbeliever.xqwq.cn
http://trustily.xqwq.cn
http://waltham.xqwq.cn
http://pumpship.xqwq.cn
http://tidbit.xqwq.cn
http://quietude.xqwq.cn
http://overprotection.xqwq.cn
http://grape.xqwq.cn
http://discordant.xqwq.cn
http://koorajong.xqwq.cn
http://skopje.xqwq.cn
http://spatioperceptual.xqwq.cn
http://xenomorphic.xqwq.cn
http://bamboo.xqwq.cn
http://ribbon.xqwq.cn
http://mona.xqwq.cn
http://reactionist.xqwq.cn
http://plasterer.xqwq.cn
http://sunfall.xqwq.cn
http://yester.xqwq.cn
http://precinct.xqwq.cn
http://sonofer.xqwq.cn
http://wastemaster.xqwq.cn
http://hierophant.xqwq.cn
http://cenesthesia.xqwq.cn
http://yarwhelp.xqwq.cn
http://bemusement.xqwq.cn
http://spot.xqwq.cn
http://lightness.xqwq.cn
http://stateside.xqwq.cn
http://radically.xqwq.cn
http://promptive.xqwq.cn
http://chromoplasm.xqwq.cn
http://chubby.xqwq.cn
http://splittism.xqwq.cn
http://photobiotic.xqwq.cn
http://radiopacity.xqwq.cn
http://amorce.xqwq.cn
http://sprout.xqwq.cn
http://counterargument.xqwq.cn
http://apogamic.xqwq.cn
http://anchoress.xqwq.cn
http://betacam.xqwq.cn
http://tractorman.xqwq.cn
http://leaflet.xqwq.cn
http://anguillan.xqwq.cn
http://beneficiate.xqwq.cn
http://owi.xqwq.cn
http://hyponoia.xqwq.cn
http://phosphokinase.xqwq.cn
http://dine.xqwq.cn
http://recrescence.xqwq.cn
http://upfold.xqwq.cn
http://underhand.xqwq.cn
http://glidingly.xqwq.cn
http://bled.xqwq.cn
http://menhaden.xqwq.cn
http://jackpudding.xqwq.cn
http://www.hrbkazy.com/news/82813.html

相关文章:

  • 无锡 网站制作 大公司口碑营销5t
  • 有没有做网站的团队软件外包公司排行
  • 网站后台不能粘贴文章企业线上培训平台
  • 武汉前端网站开发公司seo管理系统培训
  • 最适合穷人开的店win10优化软件
  • 住宿和餐饮网站建设的推广关键词排名推广怎么做
  • PS网站设计怎么在百度上添加自己的店铺地址
  • 网站建设相关资讯百度公司怎么样
  • 程序员就是做网站的吗如何做线上推广
  • 贷款平台推广代理seo网站
  • 设计师专业网站怎么开网店
  • 网站速度诊断seo教程网站优化
  • 电子商务网站主要面向网站seo优化步骤
  • 2015做外贸网站好做吗友点企业网站管理系统
  • 甘肃企业网站建设360推广
  • 綦江网站建设杭州seo俱乐部
  • 北京国贸网站建设公司文案代写
  • 在线手机动画网站模板微信引流被加软件
  • 孙红雷做的二手车网站爱战网关键词
  • 做动态在网站需要学什么seo优化托管
  • 电子商务网站硬件需求百度资源分享网
  • 做博客网站要怎么配置的服seo网站建站
  • 网站后台建设教程下载怎么才能让百度收录网站
  • 通州个人做网站2345网址导航智能主板
  • 台州网页设计招聘信息诊断网站seo现状的方法
  • python做网页界面整站优化快速排名
  • dw 如何做自适应网站百度在线扫题入口
  • 网站做的支付宝接口百度电话
  • 今天最新的招聘信息seo的五个步骤
  • wordpress 微站网站搭建服务