第三章 前端发起HTTP请求

简介: 第三章 前端发起HTTP请求

1. XMLHttpRequest API 回顾与使用案例

XMLHttpRequest (XHR) 是一个较早的、由浏览器提供的API,用于在后台(异步)与服务器交换数据。它允许网页从服务器请求新的数据并在不重新加载整个网页的情况下更新部分网页内容。

// 创建一个新的XMLHttpRequest对象实例
var xhr = new XMLHttpRequest();

// 设置请求方法和URL
xhr.open('GET', 'https://api.example.com/data');

// 设置请求完成后的回调函数
xhr.onload = function() {
  if (xhr.status === 200) { // HTTP状态码为200表示成功
    var data = JSON.parse(xhr.responseText); // 解析返回的数据
    console.log(data);
  } else {
    console.error(xhr.statusText); // 输出错误信息
  }
};

// 发送请求
xhr.send();

// 可以设置请求头和其他选项
xhr.setRequestHeader('Content-Type', 'application/json');
xhr.timeout = 3000; // 设置超时时间(毫秒)

2. Fetch API 的现代应用实践

Fetch API 是对 XMLHttpRequest 的更现代且基于 Promise 的替代方案,提供了一种更简洁的语法结构,并支持更多的高级功能,如更好的错误处理和流式读取响应体。

// 使用Fetch发起GET请求
fetch('https://api.example.com/data')
  .then(response => {
    if (!response.ok) {
      throw new Error("HTTP error " + response.status);
    }
    return response.json(); // 如果响应是JSON格式,则解析
  })
  .then(data => {
    console.log(data);
  })
  .catch(error => {
    console.error('Error:', error);
  });

// 设置请求头并发送POST请求
fetch('https://api.example.com/submit', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    username: 'user1',
    password: 'password123'
  })
})
.then(handleResponse)
.catch(handleError);

function handleResponse(response) {
  // 对响应进行进一步处理
}

function handleError(error) {
  console.error('Error fetching data:', error);
}

3. Axios 库的功能特点与实际应用示例

Axios 是一个流行的JavaScript库,特别适用于基于Node.js的环境以及浏览器端,提供了丰富的功能集和易于使用的API来处理HTTP请求。

// 安装axios(如果在Node.js环境中)
npm install axios

// 在项目中导入axios
import axios from 'axios';

// 使用Axios发起GET请求
axios.get('https://api.example.com/data')
  .then(response => {
    console.log(response.data);
  })
  .catch(error => {
    console.error(error);
  });

// 发起POST请求并传递数据
axios.post('https://api.example.com/submit', {
  username: 'user1',
  password: 'password123'
}, {
  headers: {
    'Content-Type': 'application/json'
  }
})
.then(response => {
  // 处理成功的POST操作
})
.catch(error => {
  // 处理错误
});

// Axios还支持配置默认值、取消请求、转换请求和响应数据等高级特性

4. 其他常用HTTP客户端库对比分析

  • jQuery.ajax:对于使用jQuery的项目来说,$.ajax() 方法是一个方便的选择,它封装了底层的XMLHttpRequest过程,简化了网络请求的编写,但在现代前端开发中,随着原生Promise和Fetch API的普及,其使用频率有所下降。
  • superagent:这是一个灵活、小型且强大的库,适合Node.js和浏览器环境。它具有简单易用的链式调用API和自动处理跨域请求等功能,同时支持各种HTTP方法和中间件插件。


4.1 jQuery.ajax 的使用与特点

jQuery库中的$.ajax()方法提供了一种简化版的HTTP请求方式,适用于那些仍在使用jQuery或者对兼容性有较高要求的项目。

// 使用jQuery发起GET请求
$.ajax({
  url: 'https://api.example.com/data',
  method: 'GET',
  dataType: 'json', // 指定预期的数据类型(如json、jsonp等)
  success: function(data, textStatus, jqXHR) {
    console.log('Data received:', data);
  },
  error: function(jqXHR, textStatus, errorThrown) {
    console.error('Error occurred:', errorThrown);
  }
});

// 发起POST请求并传递数据
$.ajax({
  url: 'https://api.example.com/submit',
  method: 'POST',
  contentType: 'application/json', // 设置请求头内容类型
  data: JSON.stringify({ username: 'user1', password: 'password123' }),
  success: function(response) {
    // 处理成功的POST操作
  },
  error: function(xhr, status, error) {
    // 处理错误
  }
});

特点:

  • jQuery.ajax提供了简洁且易于理解的API,适合初级开发者快速上手。
  • 兼容性良好,支持多种浏览器和版本。
  • 支持多种数据类型转换,包括JSON、XML、HTML、script、jsonp等。
  • 内置了对跨域资源共享(CORS)的支持,通过jsonp或者xhr2实现。
  • 提供了丰富的配置选项和回调函数,便于进行错误处理和自定义需求。

4.2 superagent 库的功能特性

superagent 是一个强大且灵活的JavaScript HTTP客户端库,支持Node.js和浏览器环境,其API设计旨在方便地发送各种类型的HTTP请求。

// 安装superagent
npm install superagent

// 引入superagent
const request = require('superagent');

// 使用superagent发起GET请求
request
  .get('https://api.example.com/data')
  .then(response => {
    console.log('Data received:', response.body);
  })
  .catch(error => {
    console.error('Error occurred:', error);
  });

// 发起POST请求并传递数据
request
  .post('https://api.example.com/submit')
  .set('Content-Type', 'application/json') // 设置请求头
  .send({ username: 'user1', password: 'password123' }) // 发送请求体数据
  .then(response => {
    // 处理成功的POST操作
  })
  .catch(error => {
    // 处理错误
  });


特点:

  • 简洁直观的链式调用API。
  • 跨平台支持,既可用于Node.js,也可在浏览器端使用。
  • 自动解析响应体为JSON格式。
  • 支持文件上传和其他复杂的HTTP请求场景。
  • 可以通过插件扩展功能,例如支持Promise、进度事件监听等。


5. 总结

  • XMLHttpRequest 较为原始,使用起来相对繁琐,但兼容性极好。
  • Fetch API 更现代化且简洁,但由于早期对错误处理和请求取消的支持不足而受到一些批评,但这些问题后来已在某些浏览器中得到改进。
  • Axios 结合了Promise的优势,提供了一致的接口进行跨平台请求,并补充了一些Fetch API缺失的特性,比如自动转换响应数据类型、拦截器和取消请求的能力。
  • jQuery.ajax 和 superagent 则分别针对依赖jQuery的应用程序和需要更多灵活性及额外特性的场景提供了便利。

相关文章
|
4月前
|
JSON 监控 API
掌握使用 requests 库发送各种 HTTP 请求和处理 API 响应
本课程全面讲解了使用 Python 的 requests 库进行 API 请求与响应处理,内容涵盖环境搭建、GET 与 POST 请求、参数传递、错误处理、请求头设置及实战项目开发。通过实例教学,学员可掌握基础到高级技巧,并完成天气查询应用等实际项目,适合初学者快速上手网络编程与 API 调用。
535 130
|
7月前
|
JavaScript 前端开发 API
Node.js中发起HTTP请求的五种方式
以上五种方式,尽管只是冰山一角,但已经足以让编写Node.js HTTP请求的你,在连接世界的舞台上演奏出华丽的乐章。从原生的 `http`到现代的 `fetch`,每种方式都有独特的风格和表现力,让你的代码随着项目的节奏自由地舞动。
730 65
|
5月前
HTTP协议中请求方式GET 与 POST 什么区别 ?
GET和POST的主要区别在于参数传递方式、安全性和应用场景。GET通过URL传递参数,长度受限且安全性较低,适合获取数据;而POST通过请求体传递参数,安全性更高,适合提交数据。
600 2
|
6月前
|
Go 定位技术
Golang中设置HTTP请求代理的策略
在实际应用中,可能还需要处理代理服务器的连接稳定性、响应时间、以及错误处理等。因此,建议在使用代理时增加适当的错误重试机制,以确保网络请求的健壮性。此外,由于网络编程涉及的细节较多,彻底测试以确认代理配置符合预期的行为也是十分重要的。
288 8
|
6月前
|
缓存
|
5月前
|
JSON JavaScript API
Python模拟HTTP请求实现APP自动签到
Python模拟HTTP请求实现APP自动签到
|
5月前
|
数据采集 JSON Go
Go语言实战案例:实现HTTP客户端请求并解析响应
本文是 Go 网络与并发实战系列的第 2 篇,详细介绍如何使用 Go 构建 HTTP 客户端,涵盖请求发送、响应解析、错误处理、Header 与 Body 提取等流程,并通过实战代码演示如何并发请求多个 URL,适合希望掌握 Go 网络编程基础的开发者。
|
6月前
|
缓存 JavaScript 前端开发
Vue 3 HTTP请求封装导致响应结果无法在浏览器中获取,尽管实际请求已成功。
通过逐项检查和调试,最终可以定位问题所在,修复后便能正常在浏览器中获取响应结果。
285 0
|
6月前
|
Go
如何在Go语言的HTTP请求中设置使用代理服务器
当使用特定的代理时,在某些情况下可能需要认证信息,认证信息可以在代理URL中提供,格式通常是:
482 0
|
8月前
|
Go
在golang中发起http请求以获取访问域名的ip地址实例(使用net, httptrace库)
这只是追踪我们的行程的简单方法,不过希望你跟着探险家的脚步,即使是在互联网的隧道中,也可以找到你想去的地方。接下来就是你的探险之旅了,祝你好运!
458 26

热门文章

最新文章