React与Spring集成:构建动态数据查询与展示应用

React与Spring集成:构建动态数据查询与展示应用

本教程详细讲解如何使用react前端与spring boot后端构建一个简单的web应用。核心内容包括:react组件如何通过表单收集用户输入,利用axios发送get请求到spring `@getmapping` 端点,该端点接收 `@requestparam` 参数并返回json数据。教程重点演示如何在react中正确处理异步api响应,将完整的json数据存储到组件状态中,并有效地解析和展示这些数据,从而实现前后端的数据交互与动态展示。

构建React与Spring动态数据查询应用

在现代Web开发中,前后端分离是常见的架构模式。本教程将指导您如何结合React作为前端框架,以及Spring Boot作为后端服务,构建一个能够接收用户输入、调用后端API并展示动态数据的简单应用。我们将重点关注如何在React中正确处理表单提交、异步请求以及JSON数据的解析与展示。

一、后端服务(Spring Boot Controller)

首先,我们来看后端Spring Boot服务的实现。它负责接收来自前端的请求,处理业务逻辑(在此示例中是调用pollutionService),并返回JSON格式的数据。

import org.json.JSONObject;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.bind.annotation.RestController;@RestControllerpublic class PollutionController {    // 假设 pollutionService 已经注入并提供了获取污染数据的方法    // private final PollutionService pollutionService;     @GetMapping("/pollution/current/city")    public JSONObject getCurrentPollutionDataByCityStateCountry(            @RequestParam(value = "city") String city,            @RequestParam(value = "state") String state,            @RequestParam(value = "country") String country    ) {        try {            // 实际应用中这里会调用服务层获取数据            // return pollutionService.getCurrentPollutionDataByCityStateCountry(city, state, country);            // 模拟数据返回            JSONObject response = new JSONObject();            response.put("date", "Tue Dec 06 22:13:32 CET 2022");            response.put("no2", "48.67");            response.put("pm10", "9.51");            response.put("pm2_5", "5.85");            return response;        } catch (Exception e) {            e.printStackTrace();            return new JSONObject(); // 发生异常时返回空JSON对象        }    }}

后端说明:

@RestController:表明这是一个RESTful控制器,返回的数据将直接写入HTTP响应体。@GetMapping(“/pollution/current/city”):定义了一个GET请求的端点。@RequestParam:用于从URL的查询参数中提取值,并将其绑定到方法的参数上。这里我们期望接收city、state和country三个参数。返回值JSONObject:后端将返回一个JSON对象,其中包含日期、NO2、PM10和PM2.5等数据。

示例响应:

{"date":"Tue Dec 06 22:13:32 CET 2022","no2":"48.67","pm10":"9.51","pm2_5":"5.85"}

二、前端应用(React)

React前端负责渲染表单、收集用户输入、发送HTTP请求到Spring后端,并展示后端返回的数据。

1. React组件结构与状态管理

我们将使用一个类组件App来管理表单的输入状态和从后端获取的数据。

import React, { Component } from 'react';import './App.css';import axios from 'axios'; // 引入axios用于HTTP请求class App extends Component {    constructor(props) {        super(props);        this.state = {            city: 'New York',            state: 'New York', // 注意:这里命名为state以匹配后端参数,原问题中是province            country: 'US',            responseData: null // 用于存储后端返回的完整JSON数据        };        // 绑定事件处理器的this上下文        this.handleInputChange = this.handleInputChange.bind(this);        this.handleSubmit = this.handleSubmit.bind(this);    }    // 处理表单输入变化的通用方法    handleInputChange(event) {        const target = event.target;        const value = target.value;        const name = target.name; // input元素的name属性与state中的键对应        this.setState({            [name]: value // 使用计算属性名更新对应的state        });    }    // 处理表单提交    handleSubmit(event) {        event.preventDefault(); // 阻止表单默认提交行为,避免页面刷新        // 构建请求URL        const apiUrl = `http://localhost:8080/pollution/current/city?city=${this.state.city}&state=${this.state.state}&country=${this.state.country}`;        // 使用axios发送GET请求        axios.get(apiUrl)            .then(response => {                // 将后端返回的完整数据对象存储到state中                this.setState({ responseData: response.data });                // 在异步请求成功并更新state后,才能访问到最新的responseData                // console.log("Response Data:", response.data); // 可以用于调试                alert('数据已成功获取!请查看结果区域。');            })            .catch(error => {                console.error("请求失败:", error);                alert('获取数据失败,请检查控制台。');            });    }    render() {        // 从state中解构出数据,方便在渲染时使用        const { city, state, country, responseData } = this.state;        return (            

城市污染数据查询




{/* 结果展示区域 */} {responseData && (

查询结果:

日期: {responseData.date}

二氧化氮 (NO2): {responseData.no2}

PM10: {responseData.pm10}

PM2.5: {responseData.pm2_5}

)}
); }}export default App;

2. 关键代码解析与改进

a. 状态管理 (this.state)

Zyro AI Background Remover Zyro AI Background Remover

Zyro推出的AI图片背景移除工具

Zyro AI Background Remover 55 查看详情 Zyro AI Background Remover city, state, country: 用于绑定表单输入字段的值,实现受控组件。responseData: 初始化为null。当从后端成功获取数据后,将完整的JSON对象存储到此状态变量中。这是解决原问题中“只获取第一个字段”的关键。

b. 输入处理 (handleInputChange)

这是一个通用的事件处理器,通过event.target.name和event.target.value动态更新state中对应的字段。这使得您可以为多个输入字段使用同一个处理器,保持代码简洁。

c. 表单提交与API请求 (handleSubmit)

event.preventDefault(): 这是非常重要的一步,它阻止了浏览器在表单提交时的默认行为(即页面刷新),这对于单页应用至关重要。构建URL: 使用模板字符串(“)来动态构建包含查询参数的URL,这比字符串拼接更清晰。Axios请求: axios.get(apiUrl)发送GET请求。.then(response => { … }): 请求成功后的回调函数。this.setState({ responseData: response.data }): 这是原问题中最重要的修正点。 应该将整个response.data对象存储到responseData状态中,而不是只取response.data.date。这样,您就可以访问JSON响应中的所有字段(如no2, pm10, pm2_5)。异步注意事项: setState是异步的。在setState调用之后立即访问this.state.responseData可能不会得到最新的值。如果您需要在setState完成后执行操作,应将其放在setState的回调函数中,或者在then块中直接使用response.data。本例中的alert放在then块中,但它显示的是静态消息,实际数据展示依赖render方法。.catch(error => { … }): 请求失败后的回调函数,用于处理网络错误或后端返回的错误状态。

d. 结果展示 (render 方法)

在render方法中,我们通过条件渲染{responseData && (…)来确保只有当responseData有值(即成功获取数据后)才显示结果。通过responseData.date, responseData.no2等方式,可以直接访问并展示后端返回JSON对象中的各个字段。

三、运行应用

后端: 确保您的Spring Boot应用已启动,并在8080端口监听。前端: 在React项目目录下,运行npm start或yarn start启动React开发服务器。打开浏览器访问http://localhost:3000(React默认端口),您将看到带有输入框和提交按钮的表单。输入信息并点击提交,即可在页面上看到后端返回的数据。

四、注意事项与最佳实践

跨域问题 (CORS):如果您的React应用运行在与Spring Boot后端不同的端口或域名上,可能会遇到跨域资源共享(CORS)问题。您需要在Spring Boot后端配置CORS策略,例如在@GetMapping方法上添加@CrossOrigin注解,或全局配置CORS。

import org.springframework.web.bind.annotation.CrossOrigin;// ...@CrossOrigin(origins = "http://localhost:3000") // 允许React应用访问@GetMapping("/pollution/current/city")public JSONObject getCurrentPollutionDataByCityStateCountry(...) {    // ...}

错误处理: 在实际应用中,catch块中的错误处理应更健壮,例如向用户显示友好的错误消息,而不仅仅是打印到控制台。加载状态: 在发送请求时,可以添加一个isLoading的状态,并在请求期间显示“加载中…”的提示,提高用户体验。代码风格: 对于更复杂的应用,建议将API请求逻辑封装到单独的服务模块中,而不是直接放在组件内部。函数式组件与Hooks: 虽然本教程使用了类组件,但React官方推荐使用函数式组件和Hooks(如useState和useEffect)来管理状态和副作用,这通常能让代码更简洁、更易于理解和测试。

通过本教程,您应该已经掌握了如何使用React与Spring Boot进行前后端数据交互的基本流程,特别是如何正确处理异步请求和JSON数据,从而构建一个功能完善的动态数据查询应用。

以上就是React与Spring集成:构建动态数据查询与展示应用的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1104988.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 18:09:31
下一篇 2025年12月2日 18:09:52

相关推荐

  • CSS mask属性无法获取图片:为什么我的图片不见了?

    CSS mask属性无法获取图片 在使用CSS mask属性时,可能会遇到无法获取指定照片的情况。这个问题通常表现为: 网络面板中没有请求图片:尽管CSS代码中指定了图片地址,但网络面板中却找不到图片的请求记录。 问题原因: 此问题的可能原因是浏览器的兼容性问题。某些较旧版本的浏览器可能不支持CSS…

    2025年12月24日
    900
  • 如何用dom2img解决网页打印样式不显示的问题?

    用dom2img解决网页打印样式不显示的问题 想将网页以所见即打印的的效果呈现,需要采取一些措施,特别是在使用了bootstrap等大量采用外部css样式的框架时。 问题根源 在常规打印操作中,浏览器通常会忽略css样式等非必要的页面元素,导致打印出的结果与网页显示效果不一致。这是因为打印机制只识别…

    2025年12月24日
    800
  • 如何用 CSS 模拟不影响其他元素的链接移入效果?

    如何模拟 css 中链接的移入效果 在 css 中,模拟移入到指定链接的效果尤为复杂,因为链接的移入效果不影响其他元素。要实现这种效果,最简单的方法是利用放大,例如使用 scale 或 transform 元素的 scale 属性。下面提供两种方法: scale 属性: .goods-item:ho…

    2025年12月24日
    700
  • Uniapp 中如何不拉伸不裁剪地展示图片?

    灵活展示图片:如何不拉伸不裁剪 在界面设计中,常常需要以原尺寸展示用户上传的图片。本文将介绍一种在 uniapp 框架中实现该功能的简单方法。 对于不同尺寸的图片,可以采用以下处理方式: 极端宽高比:撑满屏幕宽度或高度,再等比缩放居中。非极端宽高比:居中显示,若能撑满则撑满。 然而,如果需要不拉伸不…

    2025年12月24日
    400
  • PC端H5项目如何实现适配:流式布局、响应式设计和两套样式?

    PC端的适配方案及PC与H5兼顾的实现方案探讨 在开发H5项目时,常用的屏幕适配方案是postcss-pxtorem或postcss-px-to-viewport,通常基于iPhone 6标准作为设计稿。但对于PC端网项目,处理不同屏幕大小需要其他方案。 PC端屏幕适配方案 PC端屏幕适配一般采用流…

    2025年12月24日
    300
  • CSS 元素设置 10em 和 transition 后为何没有放大效果?

    CSS 元素设置 10em 和 transition 后为何无放大效果? 你尝试设置了一个 .box 类,其中包含字体大小为 10em 和过渡持续时间为 2 秒的文本。当你载入到页面时,它没有像 YouTube 视频中那样产生放大效果。 原因可能在于你将 CSS 直接写在页面中 在你的代码示例中,C…

    2025年12月24日
    400
  • 如何实现类似横向U型步骤条的组件?

    横向U型步骤条寻求替代品 希望找到类似横向U型步骤条的组件或 CSS 实现。 潜在解决方案 根据给出的参考图片,类似的组件有: 图片所示组件:图片提供了组件的外观,但没有提供具体的实现方式。参考链接:提供的链接指向了 SegmentFault 上的另一个问题,其中可能包含相关的讨论或解决方案建议。 …

    2025年12月24日
    800
  • 如何让小说网站控制台显示乱码,同时网页内容正常显示?

    如何在不影响用户界面的情况下实现控制台乱码? 当在小说网站上下载小说时,大家可能会遇到一个问题:网站上的文本在网页内正常显示,但是在控制台中却是乱码。如何实现此类操作,从而在不影响用户界面(UI)的情况下保持控制台乱码呢? 答案在于使用自定义字体。网站可以通过在服务器端配置自定义字体,并通过在客户端…

    2025年12月24日
    800
  • 如何优化CSS Grid布局中子元素排列和宽度问题?

    css grid布局中的优化问题 在使用css grid布局时可能会遇到以下问题: 问题1:无法控制box1中li的布局 box1设置了grid-template-columns: repeat(auto-fill, 20%),这意味着容器将自动填充尽可能多的20%宽度的列。当li数量大于5时,它们…

    2025年12月24日
    800
  • SASS 中的 Mixins

    mixin 是 css 预处理器提供的工具,虽然它们不是可以被理解的函数,但它们的主要用途是重用代码。 不止一次,我们需要创建多个类来执行相同的操作,但更改单个值,例如字体大小的多个类。 .fs-10 { font-size: 10px;}.fs-20 { font-size: 20px;}.fs-…

    2025年12月24日
    000
  • 如何在地图上轻松创建气泡信息框?

    地图上气泡信息框的巧妙生成 地图上气泡信息框是一种常用的交互功能,它简便易用,能够为用户提供额外信息。本文将探讨如何借助地图库的功能轻松创建这一功能。 利用地图库的原生功能 大多数地图库,如高德地图,都提供了现成的信息窗体和右键菜单功能。这些功能可以通过以下途径实现: 高德地图 JS API 参考文…

    2025年12月24日
    400
  • 如何使用 scroll-behavior 属性实现元素scrollLeft变化时的平滑动画?

    如何实现元素scrollleft变化时的平滑动画效果? 在许多网页应用中,滚动容器的水平滚动条(scrollleft)需要频繁使用。为了让滚动动作更加自然,你希望给scrollleft的变化添加动画效果。 解决方案:scroll-behavior 属性 要实现scrollleft变化时的平滑动画效果…

    2025年12月24日
    000
  • CSS mask 属性无法加载图片:浏览器问题还是代码错误?

    CSS mask 属性请求图片失败 在使用 CSS mask 属性时,您遇到了一个问题,即图片没有被请求获取。这可能是由于以下原因: 浏览器问题:某些浏览器可能在处理 mask 属性时存在 bug。尝试更新到浏览器的最新版本。代码示例中的其他信息:您提供的代码示例中还包含其他 HTML 和 CSS …

    2025年12月24日
    000
  • 如何为滚动元素添加平滑过渡,使滚动条滑动时更自然流畅?

    给滚动元素平滑过渡 如何在滚动条属性(scrollleft)发生改变时为元素添加平滑的过渡效果? 解决方案:scroll-behavior 属性 为滚动容器设置 scroll-behavior 属性可以实现平滑滚动。 html 代码: click the button to slide right!…

    2025年12月24日
    500
  • 如何用 CSS 实现链接移入效果?

    css 中实现链接移入效果的技巧 在 css 中模拟链接的移入效果可能并不容易,因为它们不会影响周围元素。但是,有几个方法可以实现类似的效果: 1. 缩放 最简单的方法是使用 scale 属性,它会放大元素。以下是一个示例: 立即学习“前端免费学习笔记(深入)”; .goods-item:hover…

    2025年12月24日
    000
  • 网页使用本地字体:为什么 CSS 代码中明明指定了“荆南麦圆体”,页面却仍然显示“微软雅黑”?

    网页中使用本地字体 本文将解答如何将本地安装字体应用到网页中,避免使用 src 属性直接引入字体文件。 问题: 想要在网页上使用已安装的“荆南麦圆体”字体,但 css 代码中将其置于第一位的“font-family”属性,页面仍显示“微软雅黑”字体。 立即学习“前端免费学习笔记(深入)”; 答案: …

    2025年12月24日
    000
  • 如何选择元素个数不固定的指定类名子元素?

    灵活选择元素个数不固定的指定类名子元素 在网页布局中,有时需要选择特定类名的子元素,但这些元素的数量并不固定。例如,下面这段 html 代码中,activebar 和 item 元素的数量均不固定: *n *n 如果需要选择第一个 item元素,可以使用 css 选择器 :nth-child()。该…

    2025年12月24日
    200
  • 如何用 CSS 实现类似卡券的缺口效果?

    类似卡券的布局如何实现 想要实现类似卡券的布局,可以使用遮罩(mask)来实现缺口效果。 示例代码: .card { -webkit-mask: radial-gradient(circle at 20px, #0000 20px, red 0) -20px;} 效果: 立即学习“前端免费学习笔记(…

    2025年12月24日
    000
  • 使用 SVG 如何实现自定义宽度、间距和半径的虚线边框?

    使用 svg 实现自定义虚线边框 如何实现一个具有自定义宽度、间距和半径的虚线边框是一个常见的前端开发问题。传统的解决方案通常涉及使用 border-image 引入切片图片,但是这种方法存在引入外部资源、性能低下的缺点。 为了避免上述问题,可以使用 svg(可缩放矢量图形)来创建纯代码实现。一种方…

    2025年12月24日
    100
  • 如何用纯代码实现自定义宽度和间距的虚线边框?

    自定义宽度和间距的虚线边框 提问: 如何创建一个自定义宽度和间距的虚线边框,如下图所示: 元素宽度:8px元素高度:1px间距:2px圆角:4px 解答: 传统的解决方案通常涉及使用 border-image 引入切片的图片来实现。但是,这需要引入外部资源。本解答将提供一种纯代码的方法,使用 svg…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信