gpt4 book ai didi

reactjs - Material UI 上的“keepMounted”属性选择组件未将菜单项安装到 DOM

转载 作者:行者123 更新时间:2023-12-04 16:31:51 25 4
gpt4 key购买 nike

为了 SEO 目的,我试图确保将我的菜单项安装在 DOM 中。我将 MUI Select 组件用于下拉导航并传入 keepMounted Prop ,这些 Prop 最终通过 MenuProps 分布在 Popper 组件上。

我可以看到菜单项 HTML (ul > li) 安装在我的检查器中,但是当我检查源代码或 CURL 时,它们不存在。

const TopicSelect = ({
classes,
width,
selectClassName,
topicData,
selectedValue,
onChange,
}) => {
const isMobile = isWidthDown('xs', width)

return (
<FormControl data-testid="TopicSelect-formControl" variant="filled">
<InputLabel className={classes.label} htmlFor="topic-select-input">
Filter by topic
</InputLabel>
<Select
data-testid="TopicSelect-select"
className={classnames(classes.select, selectClassName)}
onChange={onChange}
value={selectedValue}
autoWidth
native={isWidthDown('xs', width) ? true : false}
input={
<FilledInput
name="topic"
id="topic-select-input"
className={classes.filledInput}
disableUnderline
/>
}
MenuProps={{
style: {
zIndex: 1500,
},
keepMounted: true,
}}
>
{isMobile
? [
<option value="" />,
topicData.map(topic => (
<option
key={`${topic.text}-LearnNav-menuItem`}
value={topic.path}
>
{topic.text}
</option>
)),
]
: [
<MenuItem key="none" value="">
<em>None</em>
</MenuItem>,
topicData.map(topic => (
<MenuItem
key={`${topic.text}-LearnNav-menuItem`}
value={topic.path}
>
{topic.text}
</MenuItem>
)),
]}
</Select>
</FormControl>
)
}

我希望将菜单项 HTML 呈现给 DOM,因为这是 prop 的目的。不确定为什么在 SSR 期间不渲染它们。

有没有人遇到过这个问题?有没有办法确保我忽略的这些项目已安装?

最佳答案

我看到的关于 Menu 上的 keepMounted Prop 的讨论与可访问性有关,而不是 SEO/SSR(尽管我现在看到 上的 Prop 描述>Modal 提到 SEO)。对于可访问性用例,菜单项呈现的轻微延迟(而不是初始呈现的一部分)不会导致任何问题。

延迟是由于 Portal(Menu 使用 PopoverModal 使用 Portal ) triggering the rendering of its children via an effect .

我认为解决此问题的唯一方法是利用 disablePortal prop (除了 keepMounted)在 Menu/Popover/Modal/Portal 上。

        <Select
value={state.age}
onChange={handleChange}
inputProps={{
name: "age",
id: "age-simple"
}}
MenuProps={{ keepMounted: true, disablePortal: true }}
>
<MenuItem value="">
<em>None</em>
</MenuItem>
<MenuItem value={10}>Ten</MenuItem>
<MenuItem value={20}>Twenty</MenuItem>
<MenuItem value={30}>Thirty</MenuItem>
</Select>

Edit Select menu items on initial render

我自己不使用 SSR,也没有在 SSR 环境中测试过这个解决方案,但我相信它应该可以解决问题。

代码资源:

关于reactjs - Material UI 上的“keepMounted”属性选择组件未将菜单项安装到 DOM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58292503/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com