首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Zustand:在存储对象中更改参数值

Zustand:在存储对象中更改参数值
EN

Stack Overflow用户
提问于 2021-11-09 12:34:06
回答 1查看 1K关注 0票数 0

我正在尝试创建一个功能,一个状态的分级电影在祖斯坦纳。

状态由一个对象数组组成,例如有两个条目:

代码语言:javascript
复制
  ratedMovies: [
    { imdbID: "tt0076759", userRating: "5" },
    { imdbID: "tt0080684", userRating: "10" },
  ]

下面是管理ratedMovies更改的函数。这是问题所在。我希望它检查具有相同imdbID的对象是否处于ratedMovies状态。如果是这样,则更新它的值,而不是使用相同的imdbID添加另一个对象,而是添加一个新的值。

如果我试图从上面的状态示例中更改其中一部电影的评级(在状态ofc中使用它们),我将得到If控制台检查,应用程序崩溃时会出现错误:TypeError: Cannot create property 'userRating' on number '0'

如果状态是空的,或者我更改了其他电影的评级,我会得到“其他控制台”检查,但是它们仍然没有添加到状态中。

代码语言:javascript
复制
addUserRating: (rating) => {
    console.log("rating object", rating)
    set((state) => {
      if (state.ratedMovies.find((movie) => movie.imdbID === rating.imdbID)) {
        console.log("add rating IF")
        let index = state.ratedMovies.findIndex(
          (movie) => movie.imdbID === rating.imdbID
        )
        index.userRating = rating.userRating
        return [index, ...state.ratedMovies]
      } else {
        console.log("add rating ELSE")
        return [rating, ...state.ratedMovies]
      }
    })
  }

输入上的onChange函数可以对电影进行评级,创建一个与状态数组中相同的对象,并将其传递给管理ratedMovies状态的函数:

代码语言:javascript
复制
  const changeUserMovieRating = (event) => {
    const movieRating = {
      imdbID: modalDetails.imdbID,
      userRating: event.target.value,
    }
    console.log(movieRating)
    addUserRating(movieRating)
  }

其产出如下:

代码语言:javascript
复制
{imdbID: 'tt0120915', userRating: '2'}

我希望我解释清楚了一切,我将非常感谢任何关于如何解决这个问题的建议,谢谢!

EN

回答 1

Stack Overflow用户

发布于 2021-12-06 23:29:00

对不起,我在提出这个问题时的整个徒弟都没有意义,必须彻底地重新做工。

我决定在获取过程中不添加参数,因为在另一个组件中,可以获取相同的数据。因此,我决定将“userRating”的值保留在本地存储中,如果获取的电影曾经被“用户”评级过,则会显示该值。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69898225

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档