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

医院网站建设价值和意义宣传广告

医院网站建设价值和意义,宣传广告,wordpress简约新闻自媒体主题,网站建设 有限公司一、为什么要对网络请求进行封装? 因为网络请求的使用率实在是太高了,我们有的时候为了程序的一个可维护性,会把同样的东西放在一起,后期找起来会很方便,这就是封装的主要意义。 二、如何进行封装? 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.ds6.com.cn/news/25954.html

相关文章:

  • wordpress创建用户东莞关键词排名快速优化
  • 怎么让网站绑定域名访问网络平台运营是做什么的
  • 鄞州区住房和城乡建设局网站深圳营销型网站开发
  • 做全屏网站图片显示不全免费b站推广网站入口202
  • 西安网站建设价格明细营销型网站的推广方法
  • 做网站的职业规划上海外贸seo
  • 红色网站主题北京百度推广客服电话多少
  • 网站建设 启象科技当日alexa排名查询统计
  • 斯皮尔网站建设什么是seo优化推广
  • 网站图片翻页效果如何做云搜索神器
  • wap网站制作软件公司网站建设哪家公司好
  • 南京做网站多少钱国外网站建设
  • 青海西宁网络科技乌鲁木齐seo
  • 谁做政府网站群内网短视频新媒体推广
  • 网站建设 国际 深圳百度直播平台
  • 电影订票网站怎么做网络安全
  • b2b网站建设百度网盘网页版入口
  • 广州市移动网站建设服务公司关键词查网站
  • 章丘网站优化优化营商环境 提升服务效能
  • 做网贷网站多少钱个人在线做网站免费
  • 现在房子装修流行什么风格seo网站外包公司
  • 做彩票网站制作2023年8月疫情恢复
  • 网站的外部链接怎么做网络营销公司如何建立
  • 1688批发厂家直销seo外链发布
  • 威海企业做网站哪家好广州百度竞价外包
  • 怎么查公司名称是否被注册商标河南整站百度快照优化
  • 菏泽网站建设信息五种新型营销方式
  • 可以做网站的appb站推广2023
  • v电影主题 wordpress开封网站优化公司
  • 深圳做积分商城网站建设营销型网站建设怎么做