模拟接口数据之使用Fetch方法实现


前言

在前后端分离的项目,模拟数据显示格外重要。要么接口出现异常,要么后台接口还未能调用成功…

网上有很多关于处理mock数据的依赖插件,那么在不需要其他依赖的情况下,配置本地mock数据,需要怎样获取呢?

咱这里直接使用Es6提供的Fetch内置方法

  • 该fetch()方法启动从服务器获取资源的过程。
  • 该fetch()方法返回一个解析为 Response 对象的 Promise。
  • 😀不再需要 XMLHttpRequest。

本文基于vite+vue3+ts项目构建详细步骤(配置多语言版本)项目格式扩展,如需了解请移步。


一、package.json配置mock执行脚本

"mock": "vite serve --mode mock",

在这里插入图片描述

二、封装接口,区分走ajax还是fetch

这里只封装getpost方法。

  • 使用vite中的import.meta.env.MODE判断

/**
 * 发起GET请求, 泛型 T 定义返回数据 data 项类型, U 定义请求数据类型
 * @param {string} url 请求链接
 * @param {object} params 请求参数
 * @param {object} config 配置
 */
export const get = <U = unknown, T = unknown>(
  url: string,
  params?: U,
  config?: AxiosRequestConfig,
) => {
  console.log(config?.baseURL)
  if (import.meta.env.MODE === 'mock') {
    return fetch(`/mock${url}.json`)
  } else {
    return axios.get<T, T>(
      url, { params: { ...params, t: Date.now() }, ...config },
    )
  }
}

/**
 * 发起POST请求, 泛型 T 定义返回数据 data 项类型, U 定义请求数据类型
 * @param {string} url 请求链接
 * @param {object} params 请求参数
 * @param {object} config 配置
 */
export const post = <U = unknown, T = unknown>(
  url: string,
  params?: U,
  config: AxiosRequestConfig = {},
) => {
  console.log('config_config', config)
  if (import.meta.env.MODE === 'mock') {
    return fetch(`/mock${url}.json`)
  }
  if (Array.isArray(params)) {
    return axios.post<T, T>(url, [...params], config)
  }
  return axios.post<T, T>(url, { ...params }, config)
}

在这里插入图片描述

三、创建mock目录,及相关接口文件

现在项目根目录新建mock文件夹,然后根据实际接口新建对应文件
例如:接口路径为 /usr/getUser
在mock文件夹下新建usr目录,然后再usr内新建getuser.json文件

{
    "code": 200,
    "data": {
        "userName": "用户名",
        "emali": "shimianshijian@qa.com"
    },
    "message": "OK"
}

在这里插入图片描述

四、定义接口

  • /src/usr/index.ts定义/usrgetUser接口
import { get, post } from ".."
export const getUser = () => {
    return get<null, null>('/usr/getUser')
}
export const getUserP = () => {
    return post<null, null>('/usr/getUser')
}

在这里插入图片描述

  • 在main,js调用
import { getUser, getUserP } from './server/usr'
getUser()
getUserP()

五、使用mock数据

使用模拟数据

npm run mock

如图可看到请求类型为fetch,并返回了对应数据
在这里插入图片描述
在这里插入图片描述

优化fetch返回数据

  • 不过打印出来的数据并不是想要的效果,别急,咱可再次封装fetch方法,使其返回需要的对象数据
    在这里插入图片描述
  • 封装fetch

封装fetch并修改getpost中的fetch,代码如下

export const getFetchData = async(url: string) => {
  const fetchFile = await fetch(url)
  const fetchENV = await fetchFile.json()
  return fetchENV
};
...

/**
 * 发起GET请求, 泛型 T 定义返回数据 data 项类型, U 定义请求数据类型
 * @param {string} url 请求链接
 * @param {object} params 请求参数
 * @param {object} config 配置
 */
export const get = <U = unknown, T = unknown>(
  url: string,
  params?: U,
  config?: AxiosRequestConfig,
) => {
  console.log(config?.baseURL)
  if (import.meta.env.MODE === 'mock') {
    return getFetchData(`/mock${url}.json`)
  } else {
    return axios.get<T, T>(
      url, { params: { ...params, t: Date.now() }, ...config },
    )
  }
}

/**
 * 发起POST请求, 泛型 T 定义返回数据 data 项类型, U 定义请求数据类型
 * @param {string} url 请求链接
 * @param {object} params 请求参数
 * @param {object} config 配置
 */
export const post = <U = unknown, T = unknown>(
  url: string,
  params?: U,
  config: AxiosRequestConfig = {},
) => {
  console.log('config_config', config)
  if (import.meta.env.MODE === 'mock') {
    return getFetchData(`/mock${url}.json`)
  }
  if (Array.isArray(params)) {
    return axios.post<T, T>(url, [...params], config)
  }
  return axios.post<T, T>(url, { ...params }, config)
}

修改后数据打印如下,具体可根据实际拦截器是否返回codemessage这一级别数据(即需要修改为数据同级)
在这里插入图片描述

六、不使用模拟数据

npm run dev

如图可看到请求类型为xhr,说明区分模拟数据生效了
在这里插入图片描述

七、对比其他需要使用依赖相关配置

如上配置,同其他mock方式有同样的效果,且无需再安装各种依赖,简单又实用。

如有启发,可点赞收藏哟~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值