react组件参数(浅析React中的受控组件和非受控组件)
react组件参数
浅析React中的受控组件和非受控组件目录
- 非受控组件
- 受控组件
- 注意
- 结论
表单数据由DOM本身处理。即不受setState()的控制,与传统的HTML表单输入相似,input输入值即显示最新值(使用 ref从DOM获取表单值)
1.非受控组件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <!--准备好一个容器--> <li id="test"></li> <!--引入react核心库--> <script src="../js/react.development.js"></script> <!--引入react-dom,用于支持react操作dom--> <script src="../js/react-dom.development.js"></script> <!--引入babel,用于将jsx转为js--> <script src="../js/babel.min.js"></script> <!--引入prop-types,用于对组件标签属性进行限制--> <script src="../js/prop-types.js"></script> <script type="text/babel"> class Login extends React.Component { myRef1 = React.createRef(); myRef2 = React.createRef(); handleSubmit = (event) => { event.preventDefault() // 阻止表单提交 const username = this.myRef1.current const password = this.myRef2.current alert(`您输入的用户名是:${username.value},您输入的密码是:${password.value}`) } render() { return ( <form onSubmit={this.handleSubmit}> 用户名:<input ref={this.myRef1} type="text"/> 密码:<input ref={this.myRef2} type="text"/> <button>登录</button> </form> ) } } ReactDOM.render(<Login/>,document.getElementById('test')) </script> </body> </html>
在HTML中,标签<input>、<textarea>、<select>的值的改变通常是根据用户输入进行更新。在React中,可变状态通常保存在组件的状态属性中,并且只能使用 setState() 更新,而呈现表单的React组件也控制着在后续用户输入时该表单中发生的情况,以这种由React控制的输入表单元素而改变其值的方式,称为:“受控组件”。
2.受控组件 (受到控制)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <!--准备好一个容器--> <li id="test"></li> <!--引入react核心库--> <script src="../js/react.development.js"></script> <!--引入react-dom,用于支持react操作dom--> <script src="../js/react-dom.development.js"></script> <!--引入babel,用于将jsx转为js--> <script src="../js/babel.min.js"></script> <!--引入prop-types,用于对组件标签属性进行限制--> <script src="../js/prop-types.js"></script> <script type="text/babel"> class Login extends React.Component { // 初始化状态 state = { username: '', password: '' } // 保存用户名到状态中 saveUsername = (e) => { this.setState({username: e.target.value}) } // 保存密码到状态中 savePassword = (e) => { this.setState({password: e.target.value}) } handleSubmit = (e) => { e.preventDefault() // 阻止表单提交 const {username,password} = this.state alert(`您输入的用户名是:${username},您输入的密码是:${password}`) } render() { // onChange是一有变化就改变 return ( <form onSubmit={this.handleSubmit}> 用户名:<input onChange={this.saveUsername} type="text"/> 密码:<input onChange={this.savePassword} type="text"/> <button>登录</button> </form> ) } } ReactDOM.render(<Login/>,document.getElementById('test')) </script> </body> </html>
一般情况,受控组件用的多,因为在非受控组件中会多次使用ref,而官方文档上有些“请勿过度使用ref”,使用次数多了会存在效率上的问题。
结论受控和非受控元素都有其优点,根据具体情况选择。如果表单在UI反馈方面非常简单,则对ref进行控制是完全正确的,即使用非受控组件。
特征
非受控制
受控
一次性检索(例如表单提交)
yes
yes
及时验证
no
yes
有条件的禁用提交按钮
no
yes
执行输入格式
no
yes
一个数据的几个输入
no
yes
动态输入
no
yes
以上就是浅析React中的受控组件和非受控组件的详细内容,更多关于react受控组件和非受控组件的资料请关注开心学习网其它相关文章!
- react常用组件及作用(React中的Context应用场景分析)
- reactnative动态设置值(react native实现监控手势上下拉动效果)
- reactnative示例代码(React Native项目框架搭建的一些心得体会)
- react加载优化(React星星评分组件的实现)
- react动态添加组件属性(react使用antd的上传组件实现文件表单一起提交功能完整代码)
- reacthooks用法(详解React Hooks是如何工作的)
- react常见问题(React编程中需要注意的两个错误)
- vue中的ref(Vue3.0中Ref与Reactive的区别示例详析)
- react循环有几种方法(React forwardRef的使用方法及注意点)
- react的动画实现(React实现动效弹窗组件)
- react教程简介(react入门级详细笔记)
- react组件的参数怎样定义的(详解React中组件之间通信的方式)
- react native常用组件(react native环境安装流程)
- linux虚拟内存实现需要哪六种机制(解析Linux高性能网络IO和Reactor模型)
- react配置上下文路由(React中Portals与错误边界处理实现)
- react和antd管理系统(手把手教你从零开始react+antd搭建项目)
- 精英律师 廖佳敏封印恋情曝光,顾婕马失前蹄 你个老不死的(廖佳敏封印恋情曝光)
- 以家人之名广受好评,剧情生动引起观众共鸣,演员张新成圈粉无数(以家人之名广受好评)
- 三兄妹感情再遇波折,人设接连崩塌 《以家人之名》剧情猜不透(三兄妹感情再遇波折)
- 《小敏家》金波想要复婚 这只是他圈套的第1步,更可恶的在后面(小敏家金波想要复婚)
- 小敏家 剧情离谱一锅乱炖,但他们俩绝对是这部剧的一大 亮点(剧情离谱一锅乱炖)
- 《倚天屠龙记》再遭翻拍,关晓彤主演赵敏,蒋劲夫演张无忌,你怎么看(倚天屠龙记再遭翻拍)
热门推荐
- django响应返回的常用方法(Django异步任务之Celery的基本使用)
- python真的能高效处理excel报表吗(Python数据报表之Excel操作模块用法分析)
- 织梦dedecms开启付费授权(织梦Dedecms设置伪静态详细方法)
- nginx反向代理多个server(Nginx反向代理多个服务器的实现方法)
- Chrome谷歌浏览器开发者工具中Profiles的使用
- linux离线安装nfs服务器(linux搭建FastDFS文件服务器的实现步骤)
- python可视化界面实现管理系统(python面向对象实现名片管理系统文件版)
- laravel模型怎么使用(laravel5.1框架model类查询的实现方法)
- thinkphp5单例原理(Thinkphp5框架简单实现钩子Hook行为的方法示例)
- docker容器的创建启动和停止操作(docker版es、milvus、minio启动命令详解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9