一文详解fetch,ajax,axios的区别以及使用_javascript技巧

fetch,ajax,axios这些都是发起前端请求的工具,除了这些外还有jquery的$.ajax。ajax和$.ajax都是基于XMLHttpRequest。

XMLHttpRequest是一种在浏览器中用于与服务器进行异步通信的对象,它是实现 AJAX(Asynchronous JavaScript and XML,异步的 JavaScript 与 XML 技术)的核心。通过 XMLHttpRequest,可以在不刷新整个页面的情况下与服务器交换数据并更新部分网页内容。而jquery的$.ajax简化了XMLHttpRequest的使用。

ajax:是最早用于实现异步数据交互的技术,出现时间较早。兼容性非常好,能在所有主流浏览器(包括一些较旧版本的浏览器)中使用。

fetch:是 ES6 引入的新的 API,现代浏览器基本都支持,但在一些旧版本浏览器中需要使用 polyfill 来实现兼容。

axios:是一个基于promise的 HTTP 客户端,用于浏览器和 Node.js。由于是第三方库,使用时需要引入,不过它通过内部处理兼容了不同浏览器,也能在 Node.js 环境使用。

这里使用express框架创建一个简单的node服务,里面有一个接口,以便演示使用。

创建好项目文件夹后在cmd里面输入命令

npm i express

使用cors中间件来配置跨域,安装命令

// 引入 express 模块const express = require('express');// 引入 cors 模块const cors = require('cors'); // 创建 express 应用实例const app = express();// 定义端口号const port = 3000; // 配置 cors 中间件,允许来自 8080 端口的跨域请求const corsOptions = { origin: 'http://localhost:8080',};app.use(cors(corsOptions)); // 定义一个 GET 请求的接口app.get('/api/data', (req, res) => { // 定义要返回的数据 const data = { message: '接口的数据', list: [1, 2, 3] }; // 设置响应头,指定返回的数据格式为 JSON res.setHeader('Content-Type', 'application/json'); // 发送 JSON 数据作为响应 res.send(JSON.stringify(data));}); // 启动服务器,监听指定端口app.listen(port, () => { console.log(`服务器正在运行,访问地址为 http://localhost:${port}/api/data`);});

打开终端输入node app.js 启动,看到这个表示成功了,点击地址可以看到接口返回的数据

运行结果,打印可以看到已经拿到了接口的数据了,在浏览器网络中也可以看到请求已经成功了

axios是第三方库,在使用前需要安装,命令

 axios在实际开发中用的比较多,这里在演示下axios发put,post,delete请求。首先修改下后端代码,添加上put,post,delete接口。(修改完代码后记得重启下--在执行一次node app.js)

运行效果,从打印结果可以看到调用接口的时候数据发生了变化

到此这篇关于fetch,ajax,axios的区别以及使用的文章就介绍到这了,更多相关fetch,ajax,axios区别及使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!


本文地址: https://www.earthnavs.com/jishuwz/c3edb31c7e2bb94e54ec.html
全局中部横幅
今日头条

该站点未添加描述description...

360游戏中心,我创造你快乐

360游戏中心是超好玩的的免费安全游戏平台,为亿万360玩家提供各种新鲜好玩的免费游戏及超值游戏礼包福利-360游戏中心,我创造你快乐!

Linux命令大全(手册)

专注于Linux命令大全与详解的在线命令查询网站,包含Linux命令手册、Linux命令详解、Linux命令学习与shell脚本编程大全等优质学习资料,准确,丰富,稳定,在技术之路上为您护航!

Google

全面、及时的新闻报道,Google新闻为您汇集来自世界各地的新闻来源。

邮箱登录

邮箱登录-次幂数据

首页

该站点未添加描述description...

灵曜

灵曜是一款端口映射及内网穿透软件,使您无需服务器,无需公网IP,无需设置路由器即可对外发布应用,远程桌面,支付调试,NAS云盘,游戏联机等都可使用,支持http,https,tcp协议.

翱联旅游网

翱联旅游网是您一站式的旅行专家,致力于为您打造无与伦比的旅游体验。在这里,您将开启一段精彩纷呈的探索之旅。我们拥有海量的旅游资源,涵盖全球热门目的地以及小众秘境,无论是浪漫的海滨度假、神秘的古老遗迹、壮丽的山川湖泊,还是充满异域风情的城市漫步,翱联旅游网都能满足您的多元需求。

云搜站导航

云搜站导航(yunsouzhan.cn)专注为职场人士提供高效办公解决方案,聚合PPT模板、Excel工具、在线协作平台、行政管理系统等实用资源,严选全网可商用、免版权素材,每日人工更新验证,网址大全,助力提升工作效率。即点即用,无广告干扰!

小微视频网

小微视频网,提供了影视解说,小品剧情,教育培训,软件下载,资源下载,SEO教程,网赚技术教程,分享小微视频教程门户网站。