react中修改参数值没有重新渲染问题-关于浅拷贝与深拷贝

项目中遇到个问题,有一个数组参数,删除数组中一个元素,并且重新改变state但是页面没有重新渲染,先面用一个简单的todolist重现下问题

如下渲染出来menu,当我点击删除时触发onClose事件,在onClose中直接对listData进行操作,打印出的数据是删除后的,但是页面没有重新渲染

const data=[
  {name:‘小A‘,age:‘10‘,id:‘1‘},
  {name:‘小B‘,age:‘11‘,id:‘2‘},
  {name:‘小C‘,age:‘10‘,id:‘3‘},
  {name:‘小D‘,age:‘11‘,id:‘4‘}
]
function ToDoList(){
  const [listData,setListData] = useState([data]);

  const onClose=(newdata,e)=>{
    e.stopPropagation();
    e.preventDefault();
    const currentIndex = listData.findIndex(item=>item.id===newdata.id);
    listData.splice(currentIndex,1)
    setListData(listData)
  }
  return (
           <Menu selectedKeys={[currentId]}>
      { listData.map((item,index)=>{
          return (
              <Menu.Item key={index}>
                {item.name}
                <Icon type="close" onClick={(e) => onClose(item,e)} />
              </Menu.Item>
              )
        })
      }
    </Menu>
  )
}
export default ToDoList;

问题出在我不应该直接操作listData,因为直接操作listData使它的值直接变化,在通过setListData()修改他的状态,这时候通过setListData()保存的最新状态和listData是相同的,会默认为state并没有发生改变,所有不会重新渲染,所以,我们需要在处理数据之前对listData做一次深拷贝,如下

const onClose=(newdata,e)=>{
    e.stopPropagation();
    e.preventDefault();
    const currentIndex = listData.findIndex(item=>item.id===newdata.id);
    const newArray = _.map(taskbarData,(val) => { return val })
    newArray.splice(currentIndex,1)
    setListData(newArray)
  }

这样的话就可以完美解决了

总结:这里涉及到了深拷贝和浅拷贝的问题,

浅拷贝,就是两个变量都是指向一个地址,改变了一个变量,那另一个变量也随之改变。这就是浅拷贝带来的副作用,两个变量会相互影响到,因为它们指向同一个地址。如下当我改变newArray的值,listData也会随之改变

const newArray = listData

深拷贝,就是互相独立,指向的是不同的地址,一个变量改变了,另一个变量不会被影响到。

const newArray = _.map(taskbarData,(val) => { return val })

原文地址:https://www.cnblogs.com/yunyea/p/11469930.html

时间: 2024-08-01 04:40:54

react中修改参数值没有重新渲染问题-关于浅拷贝与深拷贝的相关文章

React中条件渲染和循环

条件渲染 React 中的条件渲染和 JavaScript 中的一样,使用 JavaScript 运算符 if 或者条件运算符去创建元素来表现当前的状态,然后让 React 根据它们来更新 UI. 具体实现可以看下面的例子 1.在 src -> components 文件夹中,再新建 list.js ,具体代码如下: import React, { Component } from 'react'; class List extends Component { // 状态的初始化一般放在构造器中

React中setState同步更新策略

本文和大家分享的主要是React中setState同步更新相关内容,希望对大家学习React有所帮助. 为了提高性能React将setState设置为批次更新,即是异步操作函数,并不能以顺序控制流的方式设置某些事件,我们也不能依赖于 this.state 来计算未来状态.典型的譬如我们希望在从服务端抓取数据并且渲染到界面之后,再隐藏加载进度条或者外部加载提示: componentDidMount() { fetch('https://example.com') .then((res) => re

Immutable 详解及 React 中实践

本文转自:https://github.com/camsong/blog/issues/3 Shared mutable state is the root of all evil(共享的可变状态是万恶之源) -- Pete Hunt 有人说 Immutable 可以给 React 应用带来数十倍的提升,也有人说 Immutable 的引入是近期 JavaScript 中伟大的发明,因为同期 React 太火,它的光芒被掩盖了.这些至少说明 Immutable 是很有价值的,下面我们来一探究竟.

Android中自定义视图View之---渲染器Shader对象

下面再来看下一个知识点:颜色渲染Shader对象 为什么我要把Shader对象单独拿出来说一下呢?因为这个对象在对于我们处理图形特效的时候是非常有用的 下面来看一下Android中Shader对象 在Android Api中关于颜色渲染的几个重要的类:Shader,BitmapShader,ComposeShader,LinearGradient,RadialGradient,SweepGradient它们之间的关系是: Shader是后面几个类的父类 该类作为基类主要是返回绘制时颜色的横向跨度

React中state和props分别是什么?

[转]https://segmentfault.com/a/1190000011184076 整理一下React中关于state和props的知识点. 在任何应用中,数据都是必不可少的.我们需要直接的改变页面上一块的区域来使得视图的刷新,或者间接地改变其他地方的数据.React的数据是自顶向下单向流动的,即从父组件到子组件中,组件的数据存储在props和state中,这两个属性有啥子区别呢? props React的核心思想就是组件化思想,页面会被切分成一些独立的.可复用的组件. 组件从概念上看

react中需要用到【深度复制】的问题

首先,说一下我所遇到的问题,我所做的项目是用的基于react的antd框架. 一张表格,里面的数据是从后台获取直接渲染,我点击修改按钮,在modal弹框中修改数据,但是没有点击确定,点击取消,发现页面上的数据也被修改了,一刷新页面,数据就还原了. 纠结了很久,网上好像也没有类似的问题,百度了很久才知道原来是要深度复制的原因,所以写的博客记录一下. 1.问题的原因 以前用angular做项目,也遇到过类似问题.由于angular中双向绑定的问题,问题比在react中还明显一些,在modal弹框中输

React中Props 和 State用法

React中Props 和 State用法 1.本质 一句话概括,props 是组件对外的接口,state 是组件对内的接口.组件内可以引用其他组件,组件之间的引用形成了一个树状结构(组件树),如果下层组件需要使用上层组件的数据或方法,上层组件就可以通过下层组件的props属性进行传递,因此props是组件对外的接口.组件除了使用上层组件传递的数据外,自身也可能需要维护管理数据,这就是组件对内的接口state.根据对外接口props 和对内接口state,组件计算出对应界面的UI=>UI = C

react中redux的理解

定义 redux可以看作是flux的进阶版,主要用于react中公共状态(数据)的管理 redux底层原理 redux有一个createStore方法,这个方法用户创建公共存储空间,createStore方法接收一个纯函数作为作为参数,在纯函数中处理数据并返回处理后的数据.当createStore方法执行完成后会返回一个store对象,这个对象内提供一些方法,组件中通过调用store的这些方法去获取或者修改公共存储空间内的数据. 这里说store的几个方法:dispatch用于发送action;

js中函数参数值传递和引用传递

js中函数参数值传递和引用传递:在阅读本章节之前建议参阅一下两章节:1.值类型可以参阅javascript的值类型一章节.2.引用类型可以参阅javascript的引用类型一章节.一.函数传递值类型:代码实例如下: function addNum(num) { num+=10; return num; } var num=10; var result=addNum(num); console.log(num); console.log(result); 以上代码的弹出值分别为:10和20,下面进