javascript - 如何删除选定的元素 react

标签 javascript reactjs local-storage

我有两个组件 Display.jsx 和 DisplayList.jsx。组件协同工作以显示本地存储中的值。问题出在 DisplayList.JSX handleDelete() 方法循环上。

我不明白为什么它删除第一个元素而不是选定的元素?以及如何解决这个问题?

Github

显示.jsx

import {DisplayList} from './DisplayList';


class Display extends Component {
  constructor(props){
    let data = JSON.parse(localStorage.getItem('data'));
    super(props)
    this.state = {
      data: data,
  }

  // Methods
  this.displayValues = this.displayValues.bind(this);
  }

  displayValues(){

   return this.state.data.map((data1, index) =>
    <DisplayList
      key = {index}
      email = {data1.email}
      password = {data1.password}
      updateList = {this.updateList}
       /> 
    )
  }
  // This is the method that will be called from the child component.
  updateList = (data) => {
    this.setState({
      data
    });
  }
  render() {
    return (
      <ul className="list-group">
        {this.displayValues()}
      </ul>
    )
  }
}

export default Display;

DisplayList.jsx

import React, { Component } from 'react'
import {Button, Modal, Form} from 'react-bootstrap';


export class DisplayList extends Component {

    constructor(props){
        super(props)
        this.state = {
            email: '',
            password: '',
            show: false,
        };

        // Methods
        this.handleDelete = this.handleDelete.bind(this);
        this.onChange = this.onChange.bind(this);
    }

    onChange(event){
        this.setState({
            [event.target.name]: event.target.value
        })
    };   
    handleDelete(){
        const data = JSON.parse(localStorage.getItem('data'));
        for (let index = 0; index < data.length; index++) {
            if(this.props.email === data[index].email &&
                this.props.password === data[index].password){
                  console.log(this.props.email);
                  console.log(data[index]);
                data.splice(data[index], 1);
            }
            console.log('loop count');
        }
        localStorage.setItem('data', JSON.stringify(data));
        this.props.updateList(data);
    }


  render() {
    return (
    <div className = "mt-4">
        <li className="list-group-item text-justify">
            Email: {this.props.email} 
            <br /> 
            Password: {this.props.password}
            <br /> 
            <Button onClick = {this.handleShow} variant = "info mr-4 mt-1">Edit</Button>
            <Button onClick = {this.handleDelete} variant = "danger mt-1">Delete</Button>
        </li>
    </div>
    )
  }
}

最佳答案

而不是:

data.splice(data[index], 1);

尝试重写整个数组:

data = [
    ...data.slice(0, index),
    ...data.slice(index + 1)
];

关于javascript - 如何删除选定的元素 react ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54809828/

相关文章:

reactjs - 使用 Formik 提交后如何保留表单值

javascript - 如何检查本地存储中是否已存在项目/值

javascript - 具有本地主机或 LAN 服务器名称的 IE8/IE9 上的 localStorage 不起作用

javascript - 这符合您对回调的定义吗?

javascript - 过滤器 : invert() all items on the page, 除了一个

javascript - 需要居中整个导航栏,包括子菜单,找不到正确的代码。我的 JavaScript 搞砸了吗?

JavaScript 迭代对象

javascript - 即使在 if 语句中包装后,Flow 仍认为该值为 null

javascript - 如何从本地存储恢复javascript值?

javascript - 跨上下文连接的网络音频 API 音频节点?