news 2026/2/9 11:39:15

React 表单与事件 本章节我们将讨论如何在 React 中使用表单。

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
React 表单与事件 本章节我们将讨论如何在 React 中使用表单。

React 表单与事件 本章节我们将讨论如何在 React 中使用表单。

HTML 表单元素与 React 中的其他 DOM 元素有所不同,因为表单元素生来就保留一些内部状态。

在 HTML 当中,像 , , 和 这类表单元素会维持自身状态,并根据用户输入进行更新。但在React中,可变的状态通常保存在组件的状态属性中,并且只能用 setState() 方法进行更新。

一个简单的实例 在实例中我们设置了输入框 input 值 value = {this.state.data}。在输入框值发生变化时我们可以更新 state。我们可以使用 onChange 事件来监听 input 的变化,并修改 state。

React 实例 class HelloMessage extends React.Component { constructor(props) { super(props); this.state = {value: 'Hello Runoob!'}; this.handleChange = this.handleChange.bind(this); }

handleChange(event) { this.setState({value: event.target.value}); } render() { var value = this.state.value; return

{value}

; } } const root = ReactDOM.createRoot(document.getElementById("root")); root.render( );

尝试一下 ? 上面的代码将渲染出一个值为 Hello Runoob! 的 input 元素,并通过 onChange 事件响应更新用户输入的值。

实例 2 在以下实例中我们将为大家演示如何在子组件上使用表单。 onChange 方法将触发 state 的更新并将更新的值传递到子组件的输入框的 value 上来重新渲染界面。

你需要在父组件通过创建事件句柄 (handleChange) ,并作为 prop (updateStateProp) 传递到你的子组件上。

React 实例 class Content extends React.Component { render() { return (

{this.props.myDataProp}

); } }

class HelloMessage extends React.Component { constructor(props) { super(props); this.state = { value: 'Hello Runoob!' }; this.handleChange = this.handleChange.bind(this); }

handleChange(event) { this.setState({ value: event.target.value }); }

render() { var value = this.state.value; return (

); } }

const root = ReactDOM.createRoot(document.getElementById('root')); root.render();

尝试一下 ? Select 下拉菜单 在 React 中,不使用 selected 属性,而在根 select 标签上用 value 属性来表示选中项。

React 实例 class FlavorForm extends React.Component { constructor(props) { super(props); this.state = {value: 'coconut'};

kotlin

体验AI代码助手

代码解读

复制代码

this.handleChange = this.handleChange.bind(this); this.handleSubmit = this.handleSubmit.bind(this);

}

handleChange(event) { this.setState({value: event.target.value}); }

handleSubmit(event) { alert('Your favorite flavor is: ' + this.state.value); event.preventDefault(); }

render() { return (

选择您最喜欢的网站 Google Runoob Taobao Facebook ); } }

const root = ReactDOM.createRoot(document.getElementById("root")); root.render( );

尝试一下 ? 多个表单 当你有处理多个 input 元素时,你可以通过给每个元素添加一个 name 属性,来让处理函数根据 event.target.name 的值来选择做什么。

React 实例 class Reservation extends React.Component { constructor(props) { super(props); this.state = { isGoing: true, numberOfGuests: 2 };

kotlin

体验AI代码助手

代码解读

复制代码

this.handleInputChange = this.handleInputChange.bind(this);

}

handleInputChange(event) { const target = event.target; const value = target.type === 'checkbox' ? target.checked : target.value; const name = target.name;

csharp

体验AI代码助手

代码解读

复制代码

this.setState({ [name]: value });

}

render() { return (

是否离开:
访客数: ); } }

尝试一下 ? React 事件 以下实例演示通过 onClick 事件来修改数据:

React 实例 class HelloMessage extends React.Component { constructor(props) { super(props); this.state = {value: 'Hello Runoob!'}; this.handleChange = this.handleChange.bind(this); }

handleChange(event) { this.setState({value: '菜鸟教程'}) } render() { var value = this.state.value; return

点我

{value}

; } } const root = ReactDOM.createRoot(document.getElementById("root")); root.render( );

尝试一下 ? 当你需要从子组件中更新父组件的 state 时,你需要在父组件通过创建事件句柄 (handleChange) ,并作为 prop (updateStateProp) 传递到你的子组件上。实例如下:

React 实例 class Content extends React.Component { render() { return

点我

{this.props.myDataProp}

} } class HelloMessage extends React.Component { constructor(props) { super(props); this.state = {value: 'Hello Runoob!'}; this.handleChange = this.handleChange.bind(this); } handleChange(event) { this.setState({value: '菜鸟教程'}) } render() { var value = this.state.value; return; } } const root = ReactDOM.createRoot(document.getElementById("root")); root.render( );

尝试一下 ? React AJAXReact Refs

1 篇笔记 写笔记 杨笑

117***1030@qq.com

51 父组件和子组件都用表单:

class HelloMessageChild extends React.Component { render(){ return

子组件显示:{this.props.myDataProp}

; } } class HelloMessage extends React.Component { constructor(props) { super(props); this.state = {value: '父组件',value1:"子组件"}; this.handleChange = this.handleChange.bind(this); this.handleChange1 = this.handleChange1.bind(this); }

juejin.cn/post/7592040819817922601
juejin.cn/post/7592059801885032491
juejin.cn/post/7592058764120129555

handleChange(event) { this.setState({value: event.target.value}); } handleChange1(event) { this.setState({value1: event.target.value}); } render() { var value = this.state.value; var value1 = this.state.value1; return

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/5 0:10:37

多模态识别探索:CLIP中文环境快速搭建

多模态识别探索:CLIP中文环境快速搭建 作为一名研究生,想要研究CLIP模型在中文图文匹配任务中的表现,却苦于实验室服务器资源紧张?别担心,本文将手把手教你如何快速搭建一个CLIP中文实验环境,让你轻松开展多…

作者头像 李华
网站建设 2026/2/7 2:43:38

24小时上线:用预置镜像快速打造智能物品识别小程序

24小时上线:用预置镜像快速打造智能物品识别小程序 为什么选择预置镜像快速开发 最近我接到一个紧急需求,要为零售客户开发一个能识别商品的演示版小程序。作为一个小程序开发者,我对AI模型部署完全没有经验,但客户要求在24小时内…

作者头像 李华
网站建设 2026/2/7 5:32:41

使用ms-swift进行InternVL3.5高分辨率图像训练

使用 ms-swift 进行 InternVL3.5 高分辨率图像训练 在视觉大模型日益深入专业领域的今天,一张 224224 的缩略图早已无法满足实际需求。无论是医学影像中的微小病灶识别、遥感图像里的地物边界解析,还是设计图纸上的密集标注提取,都对模型的高…

作者头像 李华
网站建设 2026/2/2 16:38:54

边缘计算+云端识别:混合部署的最佳实践

边缘计算云端识别:混合部署的最佳实践 在物联网(IoT)场景中,图像识别任务往往需要在边缘设备和云端之间灵活分配计算资源。作为解决方案架构师,你可能面临这样的挑战:如何根据实时需求、网络条件和计算资源…

作者头像 李华
网站建设 2026/2/5 12:22:22

基于STM32CubeMX的时钟树配置深度剖析与优化策略

深入理解STM32时钟系统:从CubeMX配置到实战优化你有没有遇到过这样的情况?代码逻辑明明没问题,但ADC采样不准、串口通信乱码,甚至低功耗模式进不去——最后发现“罪魁祸首”竟然是时钟配置出了问题?在STM32开发中&…

作者头像 李华
网站建设 2026/2/7 17:38:28

Keil4下载及安装全解析:新手必备的认知指南

Keil4 安装实战指南:从零搭建嵌入式开发环境 你是不是也曾在搜索“Keil4下载”的时候,被一堆带病毒链接、破解补丁满天飞的网页搞得心力交瘁?明明只想安安心心学个单片机,结果第一步就被卡在安装上——驱动报错、编译失败、注册码…

作者头像 李华