iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >react如何改变数组中的某个元素
  • 743
分享到

react如何改变数组中的某个元素

2023-07-04 21:07:32 743人浏览 薄情痞子
摘要

这篇“React如何改变数组中的某个元素”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“react如何改变数组中的某个元素”文

这篇“React如何改变数组中的某个元素”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“react如何改变数组中的某个元素”文章吧。

react改变数组中的某个元素的方法:1、查看父组件App和子组件ToDoList;2、在子组件中循环展示来自父组件的数组ToDoList,并且让两个按钮取到对应的数组元素id;3、通过子组件传过来的id修改对应数组元素的completed值即可。

React 通过 id 更改对应的数组元素:

此处有两个组件,父组件App,子组件ToDoList,通过子组件ToDoList中传过来的id更改父组件App中的数组元素内容。

1 父组件App有一个命名为ToDoList的数组,代码如下:

  this.state = {
       ToDoList:[
         {
           id:1,
           title:'吃饭',
           completed:true
         },
         {
          id:2,
          title:'睡觉',
          completed:false
        },
        {
          id:3,
          title:'学习',
          completed:true
        }
       ]
    }

2 我们在父组件App中给子组件ToDoList传递一个方法,方法名为changeCompleted。同时也把父组件的数组ToDoList传过去。

    <ToDoList
       ToDoList={this.state.ToDoList} 
       changeTitle={this.changeCompleted}
   listDelete={this.listDelete}
       >
       </ToDoList>

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>
                            //根据id改变父组件中ToDoList数组的数组元素的Completed的值
                            <button className='btn1' id={item.id} onClick={this.changeCompleted}>切换状态</button>
                            //根据id删除父组件中ToDoList数组的数组元素
                            <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)
    }
}

子组件的按钮触发父组件的事件changeCompleted并且从子组件带来了按钮对应数组元素的id值,用来更改对应id数组元素中的completed值。

  changeCompleted=(id1)=>{
    // 传过来的id不是数字类型,这里进行强制转换,不然下面的if语句无法判断
    const id2=Number(id1)
    //map遍历的数组元素是对象的话,会修改原数组的值,也就是会修改this.state的值,这之前建议深拷贝原数组再操作,个人浅见。
    //最简单的深拷贝(JSON.stringify() 和jsON.parse())
    //先把对象使用JSON.stringify()转为字符串,再赋值给另外一个变量,然后使用JSON.parse()转回来即可。
    //深拷贝
    const ToDoList1 = JSON.parse( JSON.stringify([...this.state.ToDoList]))
    this.setState({
      //将拷贝的数组展开每一项,对每一项的id和传过来的id2进行对比,如果和传过来的id相同,说明
      //找到了需要修改的哪一项,然后将那一项的completed取反即可。
      ToDoList:ToDoList1.map((item)=>{
        if(item.id===id2){
          item.completed = !item.completed
        }
        //id不同就直接返回原来的值不修改,无论修改与否的的值都在这里返回
        return item
      })
    })
  }

1 这里就成功通过子组件传过来的id修改了对应数组元素的completed值,使其可以在true和false之间切换。

以上就是关于“react如何改变数组中的某个元素”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: react如何改变数组中的某个元素

本文链接: https://www.lsjlt.com/news/347636.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • react如何改变数组中的某个元素
    这篇“react如何改变数组中的某个元素”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“react如何改变数组中的某个元素”文...
    99+
    2023-07-04
  • react怎么改变数组中的某个元素
    本教程操作环境:Windows10系统、react18.0.0版、Dell G3电脑。react怎么改变数组中的某个元素?怎么通过id更改对应的数组元素React 通过 id 更改对应的数组元素:1.此处有两个组件,父组件App,子组件To...
    99+
    2023-05-14
    React
  • ES6如何修改数组中的某个元素
    本篇内容主要讲解“ES6如何修改数组中的某个元素”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ES6如何修改数组中的某个元素”吧! ...
    99+
    2022-10-19
  • es6如何删除数组中的某个元素
    在ES6中,可以使用`Array.prototype.filter()`方法来删除数组中的某个元素。这个方法会创建一个新的数组,其中...
    99+
    2023-10-26
    es6
  • python如何去掉数组中的某个元素
    你可以使用Python中的remove()函数来删除数组中的特定元素。remove()函数将会删除数组中第一个匹配到的元素。下面是一...
    99+
    2023-08-22
    python
  • python如何删除数组中的某个元素
    在Python中,可以使用`del`关键字或者使用列表的`remove()`方法来删除数组中的某个元素。1. 使用`del`关键字:...
    99+
    2023-09-26
    python
  • PHP如何删除数组中的某个元素
    这篇文章主要介绍PHP如何删除数组中的某个元素,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的语法混合了C、Java、Perl以及php自创新的语...
    99+
    2023-06-15
  • php如何改变数组最后一个元素的值
    这篇文章主要介绍php如何改变数组最后一个元素的值,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!改变方法:1、直接给数组最后一个元素重新赋值,语法“$arr[sizeof($arr)-1]=新值;”;2、使用arra...
    99+
    2023-06-29
  • php如何改变数组元素的位置
    这篇文章主要介绍“php如何改变数组元素的位置”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“php如何改变数组元素的位置”文章能帮助大家解决问题。php可以通过对数组元素进行排序来改变数组元素的位置...
    99+
    2023-06-30
  • php数组如何删除某个键值的元素
    本篇内容介绍了“php数组如何删除某个键值的元素”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!使用unset函数最简单的方法是使用PHP的u...
    99+
    2023-07-05
  • jquery怎么移除数组中的某个元素
    使用`jQuery`的`grep`方法可以移除数组中的某个元素。例如,假设有一个数组`arr`,现在想要移除其中的元素`elem`,...
    99+
    2023-08-18
    jquery
  • java怎么删除数组中的某个元素
    在Java中,数组的长度是固定的,无法直接删除元素。但是可以通过创建一个新的数组,并将要删除的元素排除在外来实现删除元素的效果。以下是一个示例代码,演示如何删除数组中的某个元素:```javapublic static int[] re...
    99+
    2023-08-09
    java
  • es6怎么删除数组中的某个元素
    在ES6中,可以使用`Array.prototype.filter()`方法来删除数组中的某个元素。`filter()`方法会创建一...
    99+
    2023-10-09
    es6
  • es6如何检测数组中有没有某个元素
    这篇文章主要介绍“es6如何检测数组中有没有某个元素”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“es6如何检测数组中有没有某个元素”文章能帮助大家解决问题。 ...
    99+
    2022-10-19
  • php怎么改变数组最后一个元素的值
    本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑php改变数组最后一个值方法1:直接给数组最后一个元素($arr[数组长度-1])重新赋值<php $arr=array("red",&quo...
    99+
    2020-04-12
    php 数组
  • 【Python】元组 tuple ② ( 元组常用操作 | 使用下标索引取出元组中的元素 | 查找某个元素对应的下标索引 | 统计某个元素个数 | 统计所有元素个数 )
    文章目录 一、元组常用操作1、使用下标索引取出元组中的元素 - [下标索引]2、查找某个元素对应的下标索引 - index 函数3、统计某个元素的个数 - count 函数4、统计元组中元素的...
    99+
    2023-10-06
    python 开发语言 PyCharm 元组 tuple 原力计划
  • php如何将数组元素都乘以10从而改变这个数组
    本文小编为大家详细介绍“php如何将数组元素都乘以10从而改变这个数组”,内容详细,步骤清晰,细节处理妥当,希望这篇“php如何将数组元素都乘以10从而改变这个数组”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。实...
    99+
    2023-07-02
  • Vue如何用this.$set改变数组里的某个值
    Vue用this.$set改变数组里的某个值 <!DOCTYPE html> <html lang="en"> <head> <...
    99+
    2022-12-19
    Vue this.$set改变数组某个值 vue中this.$set()的用法 vue中this.$set()
  • mongodb怎么更新数组的某个元素
    要更新MongoDB中数组的某个元素,可以使用`$set`操作符和数组索引来更新指定位置的元素。例如,假设有一个名为`users`的...
    99+
    2023-08-24
    mongodb
  • es6数组如何修改每个元素
    这篇“es6数组如何修改每个元素”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“es6数组如...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作