React 中怎么通过 id 删除对应的数组元素
1.此处有两个组件,父组件 App,子组件 ToDoList,通过子组件 ToDoList 中传过来的 id 删除父组件 App 中的数组元素。
1.1 父组件 App 有一个命名为 ToDoList 的数组,代码如下:
this.state = {
ToDoList:[
{
id:1,
title:'吃饭',
completed:true
},
{
id:2,
title:'睡觉',
completed:false
},
{
id:3,
title:'学习',
completed:true
}
]
}
1.2 我们在父组件App中给子组件 ToDoList 传递一个方法,方法名为 listDelete 。同时也把父组件的数组 ToDoList 传过去
<ToDoList
ToDoList={this.state.ToDoList}
changeTitle={this.changeCompleted}
listDelete={this.listDelete}
>
</ToDoList>
1.3 子组件中循环展示来自父组件的数组 ToDoList,并且让两个按钮取到对应的数组元素 id。
import React, { Component } from 'react'
import './ToDoList.css'
export default class ToDoList extends Component {
render() {
return (
<div className='ToDoList'>
<ul>
{
this.props.ToDoList.map((item)=>{
return <li key={item.id}>
{item.title}
<p>{item.completed?'已完成':'未完成'}</p>
<div>
<button className='btn1' id={item.id} onClick={this.changeCompleted}>切换状态</button>
<button className='btn2' id={item.id} onClick={this.listDelete}>删除</button>
</div>
</li>
})
}
</ul>
</div>
)
}
listDelete=(e)=>{
this.props.listDelete(e.target.id)
}
changeCompleted=(e)=>{
this.props.changeCompleted(e.target.id)
}
}
2.子组件的按钮触发父组件的事件 listDelete 并且从子组件带来了按钮对应数组元素的 id 值,用来删除对应的数组元素。
listDelete=(id)=>{
const id2=Number(id)
const ToDoList1 = JSON.parse( JSON.stringify([...this.state.ToDoList]))
this.setState({
ToDoList:ToDoList1.filter(item=>item.id !== id2)
})
}
2.1 这样就可以通过子组件传过来的 id 删除父组件中对应的数组元素。