繁体   English   中英

我不知道如何在 React 中使用 map 函数编辑数组项

[英]I can't figure out how to edit array items using a map function in React

所以我几天来一直在尝试解决以下问题:

movies [
{
     id: 1,
     name: 'Alpha',
     rating: 0
},
{
     id: 2,
     name: 'Bravo',
     rating: 0
},
{
     id: 3,
     name: 'Charlie',
     rating: 0
}
]

我已经有一种方法可以在这个数组中添加和删除电影,但我想为每个项目有一个输入部分,其中评级状态将更新为输入的值。 我一直在使用“useReducer”来帮助解决这个问题,但我想我只是不确定语法/有效载荷是什么?

我知道有一种方法可以做 movies.map(movie=> {etc.etc.} 但我似乎无法弄清楚。非常感谢帮助。

编辑:

<div>
{movies.map(movie => (
    <h1>{movie.name}</h1>
    <input placeholder={movie.rating}
    onChange={//I WANT THE MOVIE.RATING TO CHANGE ON INPUT CHANGE//}
    />
))}
</div>

我希望输出看起来像这样,其中 {movie.rating} 对象的状态在输入更改时更新

如果您使用电影作为组件状态,您可以将其传递给您的onChange函数:

const updateRatingOnly = (id,rating) => {
    movies = movies.map(movie => {
      if(movie.id === id){
       return{...movie, rating}
      }
      return movie
    })

   setMovies(movies)

   //or

   this.setState({movies})
}

您可以通过将函数与事件链接来轻松完成此操作。 因此,您的事件处理程序将如下所示:

const handleRatingChange = (movie) => ({target: {value}) => {
  //useReducer logic
  //movie = movie name
  //value = new rating
};
<div>
{movies.map(movie => (
    <h1>{movie.name}</h1>
    <input placeholder={movie.rating}
    onChange={handleRatingChange(movie.name)}
    />
))}
</div>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM