首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React Material UI Autocmplete与列表顶部的React-window rerenders

React Material UI Autocmplete与列表顶部的React-window rerenders
EN

Stack Overflow用户
提问于 2020-06-03 14:04:59
回答 1查看 429关注 0票数 0

我最近开始学习React,需要任何帮助。

我有一个关于Material-ui autocomplete组件的问题。需要一些真正的反应大师来解决这个问题。我遇到的问题是,当我从自动完成下拉列表中选择一个选项时,它会重置到列表的顶部。我使用react-window,因为列表中有超过300个元素。配料过滤器是我正在尝试修复的,其他过滤器工作正常。我已经创建了代码沙箱,用来演示应该发生什么和当前正在发生什么。我已经摆弄了React.memo,但这对它没有任何影响。如果你有什么想法,请告诉我。正确的沙箱来自material-ui站点:autcomplete component

更正:correct sandbox

correct gif

问题:issue sandbox

issue gif

如果您需要任何澄清,请告诉我

EN

回答 1

Stack Overflow用户

发布于 2020-06-03 14:36:12

我不得不在ListboxComponent上使用useCallback,请现在尝试。代码链接:https://codesandbox.io/s/material-demo-33l5y?file=/demo.js:11315-11331

老生常谈:

似乎当我们调用setIngredients时,它正在重新呈现组件,并导致列表跳到顶部,记忆handleIngredients函数似乎可以修复它。

代码语言:javascript
复制
const handleIngredients = React.useMemo((event, value) => {
  setIngredients(value);
}, []);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62166255

复制
相关文章

相似问题

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