Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/arrays/12.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何修改数组中对象的属性_Javascript_Arrays_Object_Redux_React Redux - Fatal编程技术网

Javascript 如何修改数组中对象的属性

Javascript 如何修改数组中对象的属性,javascript,arrays,object,redux,react-redux,Javascript,Arrays,Object,Redux,React Redux,首先请注意,这是我的Redux代码中的一个问题 好的,假设我想将“status”的属性从“pending”编辑为“deleted”,再编辑为数组中某个对象的特定属性,那么我如何使用对象来完成此操作。分配以下示例: 示例a:(请注意,对象数组存储在对象本身中) 施工计划={ 任务:[ { id:1, 描述:“这是一项任务”, 状态:“待定” }, { id:2, 描述:“这是第二项任务”, 状态:“待定” } ] }注意我使用的是你第一个问题中的代码 好的,首先在renderList函数中,您需

首先请注意,这是我的Redux代码中的一个问题

好的,假设我想将“status”的属性从“pending”编辑为“deleted”,再编辑为数组中某个对象的特定属性,那么我如何使用对象来完成此操作。分配以下示例:

示例a:(请注意,对象数组存储在对象本身中)

施工计划={
任务:[
{
id:1,
描述:“这是一项任务”,
状态:“待定”
},
{
id:2,
描述:“这是第二项任务”,
状态:“待定”
}
]

}
注意我使用的是你第一个问题中的代码

好的,首先在renderList函数中,您需要包含一个onclick处理程序,以便在任务完成时进行注册:

renderList() {
  return this.props.tasks.tasks.map((task) => {
    if(task.status == "pending"){
        return (
          <li key={task.id}>
            {task.id} {task.description}
            <button type="button">Finish</button>
            <button type="button">Edit</button>
            <button onClick={() => this.props.deleteTask(task.id)} type="button">Delete</button>
            </li>
          );
      }
  else return(
    <div key={task.id}>
      THIS TASK HAS BEEN DONE
    </div>
  );
最后,在reducer-tasks.js中,您应该在调度该操作时(通过单击按钮)更新该特定列表项的“status”属性:

这将更新状态并将所选任务的状态从“挂起”更改为“已删除”,这将触发重新渲染并更改该元素


如果您有任何问题,请告诉我。你想要做的变形通常被称为透镜(实际上是一个更大的变形分组)

您可以使用纯JavaScript实现它,例如:

// Return a new object with the very same structure as plan and an amended list of tasks
return Object.assign({}, plan, {
  tasks: plan.tasks.map(function (task) {
    // Map every existing task to a totally new object with the very same structure and a new status
    return Object.assign({}, task, { status: "deleted" })
  })
})
第二个示例更容易变形,请检查以下代码:

return task2.map(function (task) {
  // Return a totally new object with the very same structure as task and a new status
  return Object.assign({}, task, { status: "deleted" });
})

更重要的是,还有一些库可以完全满足您的需要,例如

很好,谢谢!修正了一个可以清理很多东西的问题。但是我得到了newState.tasks[action.payload]是未定义的。我打印了newState,它确实正确地复制了对象数组。如果打印action.payload,则不确定会发生什么?是的,定义正确,它指向正确的对象,显示id、描述和状态,与action.payload一致。payload应仅等于id,而不是整个对象单击={()=>this.props.deleteTask(task.id-1)}应该只传递id和有效负载:操作中的任务应该只传递id。因此在reducer操作中。有效负载应该只等于与索引对应的数字
// Return a new object with the very same structure as plan and an amended list of tasks
return Object.assign({}, plan, {
  tasks: plan.tasks.map(function (task) {
    // Map every existing task to a totally new object with the very same structure and a new status
    return Object.assign({}, task, { status: "deleted" })
  })
})
return task2.map(function (task) {
  // Return a totally new object with the very same structure as task and a new status
  return Object.assign({}, task, { status: "deleted" });
})