react-redux做todolist删除时,list值改变了但是不重新渲染

来源:6-12 使用React-redux完成TodoList功能

HeyAubrey

2018-10-15

老师你好,我这里做todolist的删除时,点击li标签以后 list的值打印出来看已经改变了,在reduxdevtools里看值,list也变了,但是li没有重新渲染,‘!!${item}’ 这个没有打印。但是在input框里再次输入,就能渲染出删除后的正确的list内容的li。麻烦老师帮我看下~

<ul>
  {this.props.list.map((item, index) => {
    console.log('!!', item)
    return (
      <li key={index} onClick={this.props.deleteItemClick.bind(this, index)}>
        {item}
      </li>
    )
  })}
</ul>

// mapDispatchToProps中的方法
deleteItemClick(index) {
   console.log(this.props.list)
   const action = getDeleteItemAction(index)
   dispatch(action)
   console.log(this.props.list)
}

// actionCreator中
export const getDeleteItemAction = value => ({ type: DELETE_TODO_ITEM, value })

// reduce中
if (action.type === DELETE_TODO_ITEM) {
   const newState = Object.assign({}, state)
   newState.list.splice(action.value, 1)
   return newState
}

在[1,2,3,‘hello aubrey’] list的情况下连续点击两次2所在的位置的时候的console和reduxdevtools的截图:
图片描述
图片描述
然后在input框中输入1
图片描述

写回答

2回答

慕码人7115446

2019-10-01

reducer中,我用const newState = Object.assign({}, state)或者const newState = {...state}发现不会重新渲染,用深拷贝会重新渲染。

1
1
hellocp7
但是{...state}也是深拷贝啊。。。为什么不会重新渲染呢。。。我也有这个疑问
2020-08-06
共1条回复

itellboy

2018-10-17

<li key={index} onClick={() => this.props.deleteItemClick(index)}>
  {item}
</li>


0
0

React零基础入门到实战,完成企业级项目简书网站开发

主流新技术 React-redux,React-router4,贯穿基础语法

5275 学习 · 2496 问题

查看课程