04、数据的添加和删除功能的实现

功能需求
在这里插入图片描述

//Fragment可以看做是一个包裹行的标签
import React, { Component, Fragment}from 'react';
class App extends Component {
//这里是初始的数据,用的constructor构造函数的时候,需要用到super(),主要是为了解决this问题
  constructor () {
    super()
    this.state = {
      proList: [
        'item1',
        'item2',
        'item3'
      ],
      inputValue: ''
    }
  }
  //对页面进行渲染,内部需要return(),因为其为function render () {},函数有返回值需要return
 render () {
   return (
   //上面说过,相当于包裹函数,因为很多标签需要放置在同一个父标签内部,react规则
     <Fragment>
       <ul>
         {
         //显然列表数据
           this.state.proList.map((value,index) => {
             return (
             //点击按钮删除,需要传递index是为了删除那一项
               <li key={index}>{value}<button onClick={this.deleteItem.bind(this,index)}>删除</button></li>
             )
           })
         }
       </ul>
       // onChange事件,书写里面的数据
       <textarea cols="20" rows="10" value={this.state.inputValue} onChange={this.handleInput.bind(this)}></textarea>
       <br />
       //点击按钮,进行数据的提交到上方的渲染列表之中
       <button onClick={this.submite.bind(this)}>发布</button>
     </Fragment>
   )
 }
 此函数就是为了书写textarea标签之中的数据
 handleInput (e) {
   this.setState({
    inputValue: e.target.value
   })
 }
 删除函数,需要进行数据传值
 deleteItem (index) {
  //  为了不修改原始数据
  let proList = [...this.state.proList]
  // 数组的剪切
//  arr.splice(index,index,howmany,item1,.....,itemX)直接修改数组
 // index,从那一项开始,当为负数的时候,默认从末尾开始,index从0开始。
 //howmany,删除多少项
 //后面的是替换的作用
  proList.splice(index, 1)
  // console.log(proList)
  this.setState({
    proList
  })
}
 submite () {
   this.setState({
    //  ES6数组的合并
     proList: [...this.state.proList,this.state.inputValue],
     inputValue: ''
   })
 }
}
export default App;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值