全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

基于React实现表单数据的添加和删除详解

前言

最近在学习React,做了一个简单的Demo,用以自勉及和有需要的朋友们参考学习。

实现功能

在输入框中输入数据后,点击保存按钮,数据将会逐一显示在输入框下方,点击保存后显示的任何一条数据,该数据即可被删除。

实现思路

在开始实现之前,我们需要理清我们的思路,这样才能更好地去完成预定功能。

  1. 点击保存按钮时,输入框中的数据读取,可通过onChange绑定事件,获得输入框数据:e.target.value
  2. 自定义一个事件,输入数据后,点击保存按钮时,数据的存储操作交由该事件完成
  3. 当不断点击保存按钮时,数据应该是多个的,可选用数组来存储数据
  4. 数组中,数组的索引是唯一表示一个数据的方式,数据的操作可通过索引进行

实现过程

class ReactDemo extends React.Component{
 render(){
 return(
  <div>
  <input />
  <button>点击保存</button>
  </div>
 )
 }
}
ReactDOM.render(<ReactDemo />,document.getElementById('app'))

这是本次Demo的雏形,接下来我们将会在这上面一点一点地做修改,进行功能的完善。

此时,表单为非受控组件,也就是普通的组件,在输入框中输入任何数据,在输入框内均会显示。

React组件提供了this.state以及this.setState,利用它们,我们可以十分方便地管理、更新组件的状态。

 constructor() {
 super()
 this.state = {
  val: '',
  arr: []
 }
 }

this.state通常在构造函数内部进行初始化,其值为对象,本例中,val用于保存输入框中的值,初始值为空字符串;arr是个数据,用于存储多个数据。

 handleData(e) {
 this.setState({
  val: e.target.value
 })
 }

这里,this.setState会将val的值更新为e.target.value,当组件状态值(这里为val)发生改变,组件就会自动调用render()重新渲染UI 。

 onButtonClick(e) {
  var val = this.state.val
  this.setState({
  arr: [val, ...this.state.arr]
  })
 }

展开运算符(…)是ES6的语法,它允许一个表达式在某处展开,利用这一特性,可将数组元素逐一展开:...this.state.arr,让val总是成作为数组的第一个元素,组成新数组[val, ...this.state.arr]后,赋给arr。

 onDelete(index, e) {
 this.setState({
  arr: this.state.arr.filter((elem, i) => index !== i)
 })
 }

通过数组的索引对数据进行删除操作, [].filter()接受一个方法作为它的参数,并返回匹配条件(index !== i)的元素组成的新数组。

 {arr1.map((i,index) =>(
 <div onClick={this.onDelete.bind(this,index)}>{i}</div>
 ))}

这种JSX的语法是由facebook官方提出的一种十分简明的写法,个人觉得好用到爆。[].map()对数组元素依次进行函数的调用,并返回函数调用结果组成的新数组。bind(this,index)的第二个参数index为原函数onDelete(index,e)省略掉的第一个参数。

好了,大功告成,让我们一起来看下效果吧…

添加效果

删除后效果

总结

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# react  # 提交表单数据  # 获取表单数据  # 添加删除元素  # React使用Mobx6.x共享状态问题  # react 表单数据形式配置化设计  # React 实现表单组件的示例代码  # react实现动态增减表单项的示例代码  # React中处理表单数据实现方式  # 好了  # 输入框  # 第一个  # 多个  # 将会  # 可通过  # 框中  # 这是  # 框中输入  # 这一  # 就会  # 是个  # 在这  # 是由  # 我们可以  # 朋友们  # 第二个  # 大功告成  # 自定义  # 这篇文章 


相关文章: 深圳网站制作平台,深圳市做网站好的公司有哪些?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  ppt制作免费网站有哪些,ppt模板免费下载网站?  如何选择域名并搭建高效网站?  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  高防服务器租用指南:配置选择与快速部署攻略  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  如何通过老薛主机一键快速建站?  如何通过建站之星自助学习解决操作问题?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  平台云上自助建站如何快速打造专业网站?  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  简历在线制作网站免费,免费下载个人简历的网站是哪些?  建站之星导航如何优化提升用户体验?  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  如何快速完成中国万网建站详细流程?  如何快速生成高效建站系统源代码?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  大连 网站制作,大连天途有线官网?  建站10G流量真的够用吗?如何应对访问高峰?  免费视频制作网站,更新又快又好的免费电影网站?  建站VPS配置与SEO优化指南:关键词排名提升策略  建站主机空间推荐 高性价比配置与快速部署方案解析  如何用狗爹虚拟主机快速搭建网站?  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  制作网站的模板软件,网站怎么建设?  制作农业网站的软件,比较好的农业网站推荐一下?  如何在云主机上快速搭建多站点网站?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  图册素材网站设计制作软件,图册的导出方式有几种?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  如何注册花生壳免费域名并搭建个人网站?  免费网站制作appp,免费制作app哪个平台好?  如何通过cPanel快速搭建网站?  如何快速重置建站主机并恢复默认配置?  山东网站制作公司有哪些,山东大源集团官网?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  建站主机系统SEO优化与智能配置核心关键词操作指南  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  微信小程序制作网站有哪些,微信小程序需要做网站吗?  如何快速搭建高效可靠的建站解决方案?  实惠建站价格推荐:2025年高性价比自助建站套餐解析  广东专业制作网站有哪些,广东省能源集团有限公司官网?  Python如何创建带属性的XML节点  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  ,在苏州找工作,上哪个网站比较好?  建站之星后台密码遗忘如何找回?  TestNG的testng.xml配置文件怎么写  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  如何选择适合PHP云建站的开源框架? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。