js请求封装ajax、统一响应

warning: 这篇文章距离上次修改已过187天,其中的内容可能已经有所变动。

以下是一个简单的JavaScript请求封装函数,使用fetch进行HTTP请求,并对响应结果进行统一处理的示例代码:




function fetchJSON(url, options) {
  // 默认的请求选项
  const defaults = {
    headers: {
      'Content-Type': 'application/json',
    },
  };
 
  // 合并默认选项和传入的选项
  options = { ...defaults, ...options };
 
  // 发起请求并处理响应
  return fetch(url, options)
    .then(response => {
      // 确保响应成功
      if (!response.ok) {
        throw new Error(`HTTP错误! 状态码: ${response.status}`);
      }
      // 解析JSON响应
      return response.json();
    })
    .catch(error => {
      console.error('请求出错:', error);
      // 这里可以根据需要返回一个错误处理的Promise或者抛出错误
      // 例如返回一个Promise.reject
      throw error;
    });
}
 
// 使用示例
fetchJSON('https://api.example.com/data', {
  method: 'POST',
  body: JSON.stringify({ key: 'value' })
})
.then(data => console.log('请求成功:', data))
.catch(error => console.error('请求失败:', error.message));

这段代码定义了一个fetchJSON函数,它接受一个URL和一个选项对象作为参数。它使用fetch方法发起请求,并确保响应是成功的。如果响应不成功,它会抛出一个错误。如果响应成功,它会解析JSON响应。在使用时,你可以通过传递不同的HTTP方法和数据来定制请求。如果请求成功,它会通过then链进一步处理数据;如果请求失败,它会通过catch链处理错误。

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日