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

国家建设协会官方网站市场营销网络

国家建设协会官方网站,市场营销网络,上海网站营销推,中国做网站知名的公司一、为什么要对网络请求进行封装? 因为网络请求的使用率实在是太高了,我们有的时候为了程序的一个可维护性,会把同样的东西放在一起,后期找起来会很方便,这就是封装的主要意义。 二、如何进行封装? 1、将…

一、为什么要对网络请求进行封装?

因为网络请求的使用率实在是太高了,我们有的时候为了程序的一个可维护性,会把同样的东西放在一起,后期找起来会很方便,这就是封装的主要意义。

二、如何进行封装?

1、将Axios的一些配置封装起来

首先在src目录下新建一个文件夹utils,该文件夹用来存放我们自己的一些工具,接着在utils目录下新建一个request.js文件,用来对axios进行封装,目录结构如下:
在这里插入图片描述

接着可以对axios的请求进行一些配置,比如请求超时时间、发送请求之前对请求进行一些拦截、返回数据之前对请求进行一些拦截等等,request.js代码如下,项目基本上都有这些配置,拿来即用:

import axios from 'axios'
import querystring from "querystring";//axios的一些配置信息,相当于对axios做一些封装,这个js文件相当于一个封装好自己的配置的axios
//参考文档https://www.kancloud.cn/yunye/axios/234845/const instance = axios.create({// 网络请求的公共配置timeout: 5000
})//打印获取数据失败的错误信息
const errorHandle = (status,info) => {switch(status){case 400:console.log("语义有误");break;case 401:console.log("服务器认证失败");break;case 403:console.log("服务器拒绝访问");break;case 404:console.log("地址错误");break;case 500:console.log("服务器遇到意外");break;case 502:console.log("服务器无响应");break;default:console.log(info);break;}}//拦截器最常用的//1、发送数据之前(发送请求之前)
instance.interceptors.request.use(config =>{  //成功则进入此方法//config:包含着网络请求的所有信息if(config.method === 'post'){config.data = querystring.stringify(config.data)}return config;},error => { //失败则进入此方法return Promise.reject(error);}
)//2、获取数据之前
instance.interceptors.response.use(response =>{ //成功则进入此方法//无论请求后端成功与否,都会返回响应信息,只不过返回的方法用的不一样return response.status === 200 ? Promise.resolve(response) : Promise.reject(response);},error => { //失败则进入此方法const { response } = error;//错误的处理才是我们需要关注的errorHandle(response.status, response.info)}
)export default instance;

此时,request.js就实现了对axios的初步封装,调用request.js就相当于调用axios,只不过request.js比原本的axios多了一些配置而已。

2、封装网络请求路径

src目录下新建api文件夹,在api文件夹下新建path.js文件,该文件用来对网络请求的路径进行统一管理,目录结构如下:
在这里插入图片描述

我们可以设置一个请求路径的公共前缀,然后只需要在开发的过程中配置后缀即可,然后调用的时候将它们拼接起来,就是一个完整的请求路径了,path.js代码如下:

//axios配置网络请求的路径
const base = {//公共路径(前缀)baseUrl: "http://iwenwiki.com",//不同的子路径(后缀)chengpin: '/api/blueberrypai/getChengpinDetails.php'
}export default base;

3、将请求封装成方法

我们可以将网络请求封装成一个个的函数,统一在一个文件中管理,调用网络请求的时候,直接调用封装好的方法即可,这样前端简洁美观,并且容易维护。

api文件夹下新建一个index.js文件,用来管理网络请求函数,文件目录结构如下:
在这里插入图片描述

引入封装好的axios和请求路径文件,组成一个个的函数即可,index.js代码如下:

//axios网络请求的所有方法都放在这里
import axios from "../utils/request";  //引入自己封装好的axios
import path from "./path";  //引入网络请求的路径const api = {//成品详情地址getChengPin(){return axios.get(path.baseUrl + path.chengpin);}
}export default api;

我们将网络请求封装成getChengPin函数,前端可以直接调用获取返回信息,如果有参数的话,在函数中添加参数即可。

4、前端调用

因为我们的函数没有处理.then,所以要在调用的时候处理,当然这个处理也可以放在封装的函数中,看自己的习惯,调用代码如下:

<template><div class="hello"></div>
</template><script>
import api from "../api/index";
import request from "@/utils/request";
export default {name: 'HelloWorld',mounted() {//函数没有处理.then,所以要在这里处理api.getChengPin().then(res =>{console.log(res.data)})}
}
</script>

三、经过以上步骤,就可以实现对axios网络请求进行封装

http://www.shuangfujiaoyu.com/news/31161.html

相关文章:

  • 二级域名做很多网站seo是什么意思
  • wordpress帐号深圳aso优化
  • 企业网站排名广州网络推广专员
  • 怎么向百度提交网站小学生收集的新闻10条
  • 科技网站的一些案例展示营销渠道有哪些
  • 建设网站的费用佛山网络推广公司
  • 公司网站建设接单动态网站设计毕业论文
  • 扁平化颜色网站sem 优化软件
  • 厦门做网站多少钱如何把网站推广
  • 惠州网站建设 鑫seo引擎优化专员
  • 怎么制作游戏插件网页搜索优化seo
  • 上海公司做网站的价格seo技术公司
  • 张店网站建设定制西安做网站哪家好
  • 返利网站 帐如何做百度搜索推广优化师工作内容
  • 平湖网站制作seo关键词排名优化方法
  • 家政月嫂网站源码百度查找相似图片
  • wordpress外链跳转样式网站优化的主要内容
  • 可以做外国网站文章迅雷磁力链bt磁力天堂
  • 网络服务商提供的adsl上网帐号及口令企业站seo报价
  • 微信平台开发公司成都凌哥seo
  • ps怎么做响应式网站布局图做网站建设优化的公司排名
  • 兼职做美工摄影去哪个网站百度竞价包年推广是怎么回事
  • 哈尔滨 房产网站建设bt磁力bt天堂
  • 室内设计联盟模型下载常州seo建站
  • 微页制作网站模板下载下载百度
  • ecms网站开发论文品牌整合营销
  • 网站制作公司交接网站百度热搜榜
  • 潍坊自助建站模板免费友链平台
  • 旅游网站建设目标产品软文是什么
  • 沈阳哪家做网站好网站运营专员