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

免费做微网站营销咨询服务

免费做微网站,营销咨询服务,内蒙古建设厅网站官网,四川省人民政府驻上海办事处目录 一、前言二、封装axios三、 解决跨域四、调用接口五、运行结果 一、前言 前端请求后端数据时,会用到axios,但是如果不将axios封装好,会导致代码冗余 二次封装的好处如下: 求头能统一处理便于接口的统一管理解决回调地狱配置…

目录

    • 一、前言
    • 二、封装axios
    • 三、 解决跨域
    • 四、调用接口
    • 五、运行结果

一、前言

前端请求后端数据时,会用到axios,但是如果不将axios封装好,会导致代码冗余
二次封装的好处如下:

  • 求头能统一处理
  • 便于接口的统一管理
  • 解决回调地狱
  • 配置拦截器,给不同的实例配置不同的拦截器,支持以对象形式接受多个拦截器配置

因此,在这里记录一下axios的封装过程。

二、封装axios

安装axios

npm install axios

在目录/src/utils下创建一个http的文件夹
在这里插入图片描述
request.ts文件内容如下:

import axios from 'axios';// 创建 axios 实例
const instance = axios.create({baseURL: 'http://127.0.0.1:4008/api/', // API 基础路径timeout: 100000, // 请求超时时间headers:{'Content-Type': 'application/json;charset=UTF-8',}
});// 请求拦截器
instance.interceptors.request.use(config => {// 在发送请求之前做些什么,例如添加token// config.headers['Authorization'] = 'Bearer your-token';return config;},error => {// 对请求错误做些什么return Promise.reject(error);}
);// 响应拦截器
instance.interceptors.response.use(response => {// 对响应数据做点什么return response;},error => {// 对响应错误做点什么return Promise.reject(error);}
);export default instance;

api.ts文件如下:

import http from './request'export const generateVoice = (params:any) => {return http.request({method: 'POST',url: '/generate_voice',headers: {'Content-Type': 'application/json'},data:JSON.stringify(params)})
}

api.ts文件的目的是为了方便管理接口,你可以把所有接口卸载这里,这样就会在后面调用时更加简洁

三、 解决跨域

vite.config.ts文件中添加如下配置

  server: {port: 4008,host: '0.0.0.0',proxy: {"/api": {target: "http://64.176.215.21:8000/",changeOrigin: false,ws: true,rewrite:(path) => path.replace(/^\/api/, "")}},},

注意 配置以上文件,你的接口就需要每次带上/api前缀

在request.ts文件中,我们已经做好了每次带上/api前缀的代码

 baseURL: 'http://127.0.0.1:4008/api/', // API 基础路径//orbaseURL: '/api/', // API 基础路径

四、调用接口

没有使用api.ts的接口

axios.post('/generate_voice',param).then(response => {console.log(response);}).catch(error => {console.error(error);});

使用api.ts封装好的接口

import {generateVoice} from '@/utils/http/api';generateVoice(param).then(response => {console.log("Voice generated successfully:", response.data);}).catch(error => {console.error("Error generating voice:", error);});

五、运行结果

可以看到控制台返回的乱码数据,表示我们请求后台成功了

在这里插入图片描述

http://www.jinmujx.cn/news/119118.html

相关文章:

  • 宁国网站建设网站搭建的流程
  • 搭建一个网站多少钱网络营销管理
  • wordpress 安装 权限设置网站seo优化公司
  • 重庆网站推广产品企业360搜索引擎下载
  • 大连网站推广怎么收费搜狗竞价推广效果怎么样
  • 律师推广网站排名合肥最新消息今天
  • 网站建设公众号管理seo网站诊断分析报告
  • 天猫淘宝优惠券网站怎么做seo推广沧州公司电话
  • 做网站需要公司资料吗链接是什么意思
  • 网站开发 高级认证网站关键词排名批量查询
  • 广州企业建站平台推广是什么
  • 新手如何做海外网站代购市场调研的基本流程
  • 企业网站推广计划快速排名优化
  • 抓取网站访客数据原理网络精准推广
  • 网站做系统叫什么名字推广平台有哪些?
  • 西安营销型网站建设动力无限微信广告推广如何收费
  • 软件系统开发的大概步骤佛山百度seo代理
  • 企业所得税怎么算一般纳税人seo中国是什么
  • 做网站无锡海南百度推广运营中心
  • 淮安做网站就找卓越凯欣网络营销方案
  • 老虎淘客系统可以做网站吗网络营销公司怎么注册
  • 天元建设集团有限公司联系电话seo搜索引擎优化总结
  • 苏州做网站便宜的公司哪家好win10优化大师有用吗
  • php 建设网站制作网站seo优化徐州百度网络
  • 一个阿里云怎么做两个网站吗大数据培训机构排名前十
  • 网站建设需要哪些知识html简单网页代码
  • 做网站送白酒重庆关键词优化平台
  • 建筑公司网站 新闻网络营销策略有哪几种
  • 菠菜网站怎么做推广网络营销策略制定
  • 易思企业网站破解版网络推广需要什么