首页 > 其他分享 >React 入门第九天:与后端API的集成与数据管理

React 入门第九天:与后端API的集成与数据管理

时间:2024-09-24 15:50:37浏览次数:3  
标签:第九天 axios const setLoading React API useState error data


在React学习的第九天,我集中学习了如何与后端API进行集成。这一步是将静态的React应用转变为动态、可交互的关键。通过与后端通信,我们可以从服务器获取数据、发送用户输入以及处理复杂的业务逻辑。

1. 使用fetch进行数据请求

React没有内置的HTTP库,因此我们通常使用浏览器提供的fetch API或第三方库如axios来发送请求。

以下是一个使用fetch从API获取数据的示例:

import React, { useState, useEffect } from 'react';

function DataFetchingComponent() {
  const [data, setData] = useState([]);
  const [loading, setLoading] = useState(true);

  useEffect(() => {
    fetch('https://api.example.com/data')
      .then(response => response.json())
      .then(data => {
        setData(data);
        setLoading(false);
      })
      .catch(error => {
        console.error('Error fetching data:', error);
        setLoading(false);
      });
  }, []);

  if (loading) {
    return <div>加载中...</div>;
  }

  return (
    <div>
      {data.map(item => (
        <div key={item.id}>{item.name}</div>
      ))}
    </div>
  );
}

export default DataFetchingComponent;

在这个例子中,我们使用useEffect在组件加载时发送HTTP请求,获取的数据存储在data状态中,并根据loading状态显示加载指示。

2. 使用axios进行数据请求

虽然fetch API足够强大,但在实际项目中,开发者更倾向于使用axios,因为它提供了更丰富的功能,如自动处理JSON、支持拦截器等。

import React, { useState, useEffect } from 'react';
import axios from 'axios';

function DataFetchingComponent() {
  const [data, setData] = useState([]);
  const [loading, setLoading] = useState(true);

  useEffect(() => {
    axios.get('https://api.example.com/data')
      .then(response => {
        setData(response.data);
        setLoading(false);
      })
      .catch(error => {
        console.error('Error fetching data:', error);
        setLoading(false);
      });
  }, []);

  if (loading) {
    return <div>加载中...</div>;
  }

  return (
    <div>
      {data.map(item => (
        <div key={item.id}>{item.name}</div>
      ))}
    </div>
  );
}

export default DataFetchingComponent;

axios的使用方法与fetch类似,但它的API更加简洁,并且自动处理了JSON解析。

3. 数据的POST请求与表单处理

除了获取数据外,React应用通常还需要发送数据到服务器,例如处理表单提交。以下是一个简单的POST请求示例:

function SubmitFormComponent() {
  const [inputValue, setInputValue] = useState('');

  const handleSubmit = (event) => {
    event.preventDefault();
    axios.post('https://api.example.com/submit', { input: inputValue })
      .then(response => {
        console.log('Data submitted:', response.data);
      })
      .catch(error => {
        console.error('Error submitting data:', error);
      });
  };

  return (
    <form onSubmit={handleSubmit}>
      <input
        type="text"
        value={inputValue}
        onChange={(e) => setInputValue(e.target.value)}
      />
      <button type="submit">提交</button>
    </form>
  );
}

这里我们处理了表单的提交,通过axios.post发送用户输入的数据到服务器。

4. 处理请求状态与错误

在实际应用中,处理请求的各种状态(如加载、成功、失败)是非常重要的。以下是如何在React中优雅地处理这些状态的一个示例:

function EnhancedDataFetchingComponent() {
  const [data, setData] = useState([]);
  const [loading, setLoading] = useState(true);
  const [error, setError] = useState(null);

  useEffect(() => {
    axios.get('https://api.example.com/data')
      .then(response => {
        setData(response.data);
        setLoading(false);
      })
      .catch(error => {
        setError('Failed to fetch data');
        setLoading(false);
      });
  }, []);

  if (loading) {
    return <div>加载中...</div>;
  }

  if (error) {
    return <div>{error}</div>;
  }

  return (
    <div>
      {data.map(item => (
        <div key={item.id}>{item.name}</div>
      ))}
    </div>
  );
}

在这个例子中,我们通过状态管理对加载状态、成功状态和错误状态进行了区分,确保在不同的状态下展示不同的内容。

5. 小结与展望

第九天的学习让我掌握了React与后端API交互的基本方法,从GET请求获取数据到POST请求提交数据,再到如何处理各种状态和错误,这些都是构建动态应用时不可或缺的技能。


标签:第九天,axios,const,setLoading,React,API,useState,error,data
From: https://blog.51cto.com/u_17032682/12100522

相关文章

  • Drive.js 的一些 Api 使用记录
    文章目录2024年drive.js的基础使用想在下一步的时候处理些逻辑呢?(同步)Element的各种选择器2024年drive.js的基础使用安装就跳过了npminstalldriver.js,一行代码就可以搞定官网的BasicUsage基础使用的截图如下:想在下一步的时候处理些逻辑呢?(同步)......
  • 找到一个免费开源APP,自动搭载影像数据、地名地址API等
    找到一个免费的开源APP,代码全开源,APP里也自动搭载了影像数据API、地名地址API还有一些天气及算法API。扒了一个具体操作的教程,供大家参考。APP自助开发教程1、进入星图云开发者平台,点击登录,登录后完成开发者认证2、点击进入星图云开发者平台自助开发模块,选择APP,点击立即开始......
  • asp.net core webapi 获取请求头token
    usingMicrosoft.AspNetCore.Mvc;usingMicrosoft.Extensions.Primitives;usingSystem.Collections.Generic;[ApiController][Route("[controller]")]publicclassMyController:ControllerBase{[HttpGet]publicIActionResultGet(){......
  • 基于SqlAlchemy+Pydantic+FastApi的Python开发框架
    随着大环境的跨平台需求越来越多,对与开发环境和实际运行环境都有跨平台的需求,Python开发和部署上都是跨平台的,本篇随笔介绍基于SqlAlchemy+Pydantic+FastApi的Python开发框架的技术细节,以及一些技术总结。最近这几个月一直忙于Python开发框架的整合处理,将之前开发框架中很多重要......
  • hCaptcha 协议识别 API 对接说明
    hCaptcha协议识别API对接说明本文将介绍一种hCaptcha协议识别API对接说明,它可让用户无需识别和点选hCaptcha验证码图片,仅需通过提交WebsiteKey即可实现后台自动解码,完成验证。接下来介绍下hCaptcha协议识别API的对接说明。注册试用链接注册试用链接申......
  • 为什么要使用API接口获取数据?
    在当今数字化和信息化的时代,数据已成为企业和开发者最宝贵的资产之一。API(应用程序编程接口)作为一种标准化的数据获取方式,正在迅速成为获取和共享数据的首选手段。本文将探讨为什么使用API接口获取数据是现代开发的最佳实践。1.高效的数据访问API接口提供了一种高效的方式......
  • 凡客商品详情API:解锁电商数据的金钥匙
    在电子商务的复杂世界中,获取商品的详细信息对于商家和消费者来说至关重要。凡客诚品作为知名的电商平台,提供了强大的API接口,允许开发者通过编程方式获取商品的详细信息。本文将详细介绍如何使用凡客的API接口来获取商品详情,并探讨其返回值的意义。凡客API接口概述凡客的商品详情API......
  • 如何使用 Bittly 为基于 HTTP 的 API 快速创建 UI 操作界面
    在开发Web应用或服务时,通常会提供不同数量的API接口给客户端或其他第三方使用,当API数量达到一定数量的时候,在处理接口间的调用链以及参数关系时就会变得异常麻烦。在这种情况下便可通过Bittly的面板功能将这些API结构进行组装整理起来组成一个UI控制面板,从而......
  • React的useId,现在Vue3.5终于也有了!
    前言React在很早之前的版本中加了useId,用于生成唯一ID。在Vue3.5版本中,终于也有了期待已久的useId。这篇文章来带你搞清楚useId有哪些应用场景,以及他是如何实现的。关注公众号:【前端欧阳】,给自己一个进阶vue的机会useId的作用他的作用也是生成唯一ID,同一个Vue应用里面每次调用......
  • react native的notifee消息
       reactnative上的notifee组建可发送localnotification和remotepushnotification,可订阅各种Event。我使用的是localnotification。另一个与之对应的是exponotification,也是很好的组建,但我的app未来想用bare类型,脱离expo,所以优先选择notifee。官方文档:https://notife......