对于前端同学来说,请求后端接口是一个非常通用的东西。在十几年前的时候,我们还用 Ajax 去请求后端接口。但在 2023 年的今天,很多框架都很成熟了,我们有了更加快捷的方式 —— Axios 框架。
对于使用 Vue 技术栈的同学来说,其实接口请求框架就三种:vue-resource、Axios、fetch。对于 vue-resource 和 Axios 来说,它们都是用于在 vue.js 应用中进行 HTTP 请求的工具,但它们有一些区别,下面是一些主要的区别和如何选择的考虑因素:
基于以上考虑,一般而言,推荐使用 Axios,因为它更灵活、功能更强大,并且得到了更广泛的社区支持。 如果你的项目已经在使用 Vue-resource,可能需要考虑迁移到 Axios 或其他更为主流的HTTP库。如果项目较小或是初学者,Vue-resource 也可以满足基本需求。
使用 Axios 非常简单,首先需要运行如下代码来安装 Axios 依赖。
npm install axios
随后,我们就可以直接使用 Axios 了,如下代码所示。
import axios from "axios";
axios
.get("/api/data/winTogether/service")
.then(response => {
console.log("request..");
this.service = response.data.service;
})
.catch(error => {
console.log("fail....");
});
如上代码所示,直接引入 axios,随后使用 axios 对象的 get 方法便可发起一个请求。
很多时候,我们没有对应的后台接口,这时候我们需要自己 Mock 数据,那么我们可以使用 Mock.js 来模拟返回数据。
使用 Mock.js 也很简单,首先安装对应的依赖。
npm install mockjs
随后,我们引入 Mock 对象,并使用 mock() 方法便可模拟返回特定数据,如下代码所示。
import Mock from "mockjs";
// 注意这里的 url 需要与请求的接口保持一致
Mock.mock("/api/data/winTogether/service", {
service: [
{
subtitle: "xxxx网格站加盟",
desc: "通过自有或租赁的仓库进行分拣商品"
}
]
});
当你调用接口比较多的时候,你会发觉 Axios 的使用很繁琐,有很多重复的操作。这时候,我们可以对 Axios 进行二次封装,从而来提高我们的开发效率。关于 Axios 的二次开发,网上有很多资料,我自己也找了一些比较不错的,感兴趣的可以看看参考资料部分。