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

网站开发架设教育门户网站设计欣赏

网站开发架设,教育门户网站设计欣赏,网站导航设置,高端网站建设好的公司文章目录11.对axios二次封装11.1为什么需要进行二次封装axios?11.2在项目当中经常有API文件夹【axios】12.接口统一管理12.1跨域问题12.2接口统一管理12.3不同请求方式的src/api/index.js说明本人其他相关文章链接11.对axios二次封装 安装命令:cnpm inst…

在这里插入图片描述

文章目录

    • 11.对axios二次封装
      • 11.1为什么需要进行二次封装axios?
      • 11.2在项目当中经常有API文件夹【axios】
    • 12.接口统一管理
      • 12.1跨域问题
      • 12.2接口统一管理
      • 12.3不同请求方式的src/api/index.js说明
  • 本人其他相关文章链接

11.对axios二次封装

安装命令:cnpm install --save axios

在src目录下新建api的文件夹,新建axios.js文件,该文件就是“对axios二次封装”。

XMLHttpRequest、fetch、JQuery、axios

11.1为什么需要进行二次封装axios?

请求拦截器、相应拦截器:

  • 请求拦截器,可以在发请求之前可以处理一些业务。
  • 相应拦截器,当服务器数据返回以后,可以处理一些事情。

11.2在项目当中经常有API文件夹【axios】

接口当中:路径都带有 /api

baseURL:“/api”

注意:有的同学axios基础不好,可以参考git|npm关于axios的文档说明。

//对axios二次封装
import axios from "axios";
import nprogress from "nprogress";
//如果出现进度条没有显示:一定是你忘记了引入样式了
import "nprogress/nprogress.css";
//在当前模块中引入store
import store from '@/store';//1、利用axios对象的vreate,区创建一个axios实例
//2.:request就是axios,只不过稍微配置一下
const requests = axios.create({//基础路径,requests发出的请求的时候,路径当中会出现apibaseURL:'/api',//代表请求超时的时间5stimeout: 5000,
})
//3、配置请求拦截器,在发请求之前,请求拦截器可以检测到,可以在请求发出去之前做一些事情
requests.interceptors.request.use(config => {if(store.state.detail.uuid_token){//请求头添加一个字段(userTempId):和后台老师商量好了config.headers.userTempId = store.state.detail.uuid_token;}//需要携带token带给服务器if(store.state.user.token){//请求头添加一个字段(userTempId):和后台老师商量好了config.headers.token = store.state.user.token;}//进度条开始nprogress.start();//config:配置对象,对象里面有一个属性很重要,Header请求头return config;
})
//4、配置响应拦截器
requests.interceptors.response.use((res) => {//成功的回调函数//进度条结束nprogress.done();return  res.data;
},(error) => {//失败的回调函数console.log("响应失败"+error)return Promise.reject(new Error('fail'))
})
//5、对外暴露
export default requests;

12.接口统一管理

项目很小:完全可以再组件的生命周期函数中发请求

项目大:axios.get(‘xxx’)

12.1跨域问题

什么是跨域:协议、域名、端口号不同的请求,称之为跨域。

12.2接口统一管理

  • 第1步:src下的api文件夹下新建index.js文件,统一管理并暴露接口。这样的好处是:万一有100个路径前缀要修改,不用全局搜索挨个修改,而是找到统一管理文件进行单个文件内容修改即可完成效果。
//统一管理项目接口的模块
//引入二次封装的axios(带有请求、响应的拦截器)
import requests from "@/api/axios"//三级菜单的请求地址  /api/product/getBaseCategoryList   GET    没有任何参数
//对外暴露一个函数,只要外部调用这个函数,就想服务器发起ajax请求、获取咱们的三级菜单数据。当前咱们这个函数只需要把服务器返回结果返回即可。
export const reqGetCategoryList = ()=>requests.get(`/product/getBaseCategoryList`);
  • 第2步:配置代理服务器解决跨域问题。在vue.config.js文件内添加devServer配置项。
module.exports = {productionSourceMap:false,// 关闭ESLINT校验工具lintOnSave: false,devServer: {//代理服务器解决跨域proxy: {"/api": {target: "http://39.98.123.211:8510"},}}
};
  • 第3步:在要使用axois调用都端接口的地方,使用import引入暴露的方法名直接使用即可。

12.3不同请求方式的src/api/index.js说明

src/api/index.js

//统一管理项目接口的模块
//引入二次封装的axios(带有请求、响应的拦截器)
import requests from "@/api/axios"
import mockRequests from "@/api/mockAjax"get无参:
export const getCategoryList = ()=>requests.get(`/product/getBaseCategoryList`);
export const mockGetBannerList = ()=> mockRequests.get("/banner")
--------------------------------------------------------------------------------
get有参:
export const reqUpdateCheckedByid = (skuId,isChecked)=>requests({url:`/cart/checkCart/${skuId}/${isChecked}`,method:'get'});
--------------------------------------------------------------------------------
post有参:
export const addOrUpdateShopCar = (skuId, skuNum)=>requests({url:`/cart/addToCart/${skuId}/${skuNum}`, method:"post"});
export const registerUser = (params)=>requests({url: `/user/passport/register`,method: 'post', data: params});
export const reqUserLogin = (data)=>requests({url:'/user/passport/login',data,method:'post'});

本人其他相关文章链接

1.vue尚品汇商城项目-day02【9.Home组件拆分+10.postman测试接口】
2.vue尚品汇商城项目-day02【vue插件-13.nprogress进度条的使用】
3.vue尚品汇商城项目-day02【11.对axios二次封装+12.接口统一管理】
4.vue尚品汇商城项目-day02【14.vuex状态管理库】
5.vue尚品汇商城项目-day02【15.动态展示三级菜单联动】

http://www.yayakq.cn/news/36645/

相关文章:

  • 陕西长城建设工程有限公司网站网站建设的优缺点
  • 中信建设证券官方网站国外 电商网站
  • 厦门网页建站申请比较好杭州科技学校网站建设
  • 如何将自己做的网站推广出去丹阳网站建设咨询
  • 宿州企业网站推广网络营销工作岗位有哪些
  • 一流的网站建设流程山西省住房城乡建设厅门户网站
  • 请问下网站开发怎么弄荣耀官方网站手机商城
  • 北京网站备案速度亚马逊全球开店
  • 重庆智能网站建设设计中国免费图片素材网站
  • 嘉兴做网站专业商城网站设计制作
  • 厦门市海沧区建设局网站大型企业局域网组网方案
  • 查询行业信息的网站美食网页设计报告
  • 旅游电子商务网站的建设上海企业网站设计公司电话
  • 响应式相册网站模板专业app开发设计的公司
  • 建立网站费用表wordpress单本小说
  • 电子商务公司开发网站温州网页设计公司哪家好
  • 网站seo优化效果创客贴官网
  • 微信第三方网站怎么做wordpress多用户 2015
  • 从零开始建网站唐山做网站
  • 信阳建网站网站原型图设计
  • 天门建站农村自建房设计图一层
  • 网站建设任职推广普通话ppt课件免费
  • 网站中上传资料存放ftpwordpress网页
  • 网站界面风格wordpress版本对应的php版本号
  • 北京二次感染最新消息seo网站自动推广
  • 常州网站建设电话电子商务网站域名注册方法
  • wordpress 多站点咸阳城乡建设局网站
  • 好公司网站建设价格做房地产信息网怎么做
  • 有没有做链接的网站吗网站颜色背景代码
  • 做外汇上什么网站看新闻怎么自己做个网站