AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 77497849
Accepted
KostyanWest
KostyanWest
Asked: 2023-11-17 04:24:42 +0800 CST2023-11-17 04:24:42 +0800 CST 2023-11-17 04:24:42 +0800 CST

如何更改 MUI 5 中作为 Select 组件一部分的 Popover 组件的位置?

  • 772

我使用一个Select组件(假设是这个)。默认情况下,Popover组件出现在选择字段的正下方,但我想将其放置在右侧。我将在下面描述我尝试实现此行为的方法以及每次都失败的原因。请记住,我是 MUI 的新手。

  1. 改变位置的最正确方法是设置anchorOrigin和transformOrigin道具,但只有当你可以访问这些道具时它才有效。该组件自行Select创建(或更准确地说,是内部的组件)并且不提供 API 来传播 props。PopoverMenuSelect

  2. 该Menu组件有一个传播到 的PopoverClassesprop ,因此我想通过覆盖JS 计算的值和样式来更改位置。但无论我多么努力地试图弄清楚它是如何工作的,我都无法做到。我发现的每个指南都使用了自 MUI v5 以来已弃用的from或from 。MUI v5 中 prop是否已完全弃用?classesPopoverlefttopmakeStyles"@mui/styles"createUseStyles"react-jss"classes

  3. 添加类似 或 之类的样式"& .MuiPopover-root"也Select不起作用Menu,因为PopoverDOM 顶部附近的创建可以用作模式对话框,并且不是Select.

  4. 尽管Menu不会直接将 props 传播到Popover,但它会将 props 传播到MenuList的子级a Popover。使用MenuListProps: {ref=myRef}我可以访问Popoverby的 DOM 元素myRef.current.parentElement。但这还不够,因为我没有好的事件来覆盖值。是在的事件触发Popover后短时间内创建的,因此在事件期间,值是未定义的,之后就太晚了 - 明显是如何跳跃的。onOpenSelectmyRef.currentsetTimeout()Popover

这么简单的动作却太难了。我错过了一些明显的事情吗?

material-ui
  • 1 1 个回答
  • 14 Views

1 个回答

  • Voted
  1. Best Answer
    Vlad Povalii
    2023-11-17T09:01:21+08:002023-11-17T09:01:21+08:00

    使用Select组件,您可以通过属性传播其Popover道具MenuProps。

    它之所以有效,是因为Menu实际上将 props 传播到Popover并可以接受其所有属性,如文档中所述

    例子:

    <Select
      labelId="demo-simple-select-label"
      id="demo-simple-select"
      value={age}
      label="Age"
      onChange={handleChange}
      MenuProps={{
        anchorReference: "anchorPosition",
        anchorPosition: { top: 0, left: 475 }
      }}
    >
      <MenuItem value={10}>Ten</MenuItem>
      <MenuItem value={20}>Twenty</MenuItem>
      <MenuItem value={30}>Thirty</MenuItem>
    </Select>
    
    • 1

相关问题

  • 将值垂直和水平居中 MUI

  • 如何使用 Mui CircularProgress 创建一个可以处理 3 个不同值的数据可视化的循环进度

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    使用 <font color="#xxx"> 突出显示 html 中的代码

    • 2 个回答
  • Marko Smith

    为什么在传递 {} 时重载解析更喜欢 std::nullptr_t 而不是类?

    • 1 个回答
  • Marko Smith

    您可以使用花括号初始化列表作为(默认)模板参数吗?

    • 2 个回答
  • Marko Smith

    为什么列表推导式在内部创建一个函数?

    • 1 个回答
  • Marko Smith

    我正在尝试仅使用海龟随机和数学模块来制作吃豆人游戏

    • 1 个回答
  • Marko Smith

    java.lang.NoSuchMethodError: 'void org.openqa.selenium.remote.http.ClientConfig.<init>(java.net.URI, java.time.Duration, java.time.Duratio

    • 3 个回答
  • Marko Smith

    为什么 'char -> int' 是提升,而 'char -> Short' 是转换(但不是提升)?

    • 4 个回答
  • Marko Smith

    为什么库中不调用全局变量的构造函数?

    • 1 个回答
  • Marko Smith

    std::common_reference_with 在元组上的行为不一致。哪个是对的?

    • 1 个回答
  • Marko Smith

    C++17 中 std::byte 只能按位运算?

    • 1 个回答
  • Martin Hope
    fbrereto 为什么在传递 {} 时重载解析更喜欢 std::nullptr_t 而不是类? 2023-12-21 00:31:04 +0800 CST
  • Martin Hope
    比尔盖子 您可以使用花括号初始化列表作为(默认)模板参数吗? 2023-12-17 10:02:06 +0800 CST
  • Martin Hope
    Amir reza Riahi 为什么列表推导式在内部创建一个函数? 2023-11-16 20:53:19 +0800 CST
  • Martin Hope
    Michael A fmt 格式 %H:%M:%S 不带小数 2023-11-11 01:13:05 +0800 CST
  • Martin Hope
    God I Hate Python C++20 的 std::views::filter 未正确过滤视图 2023-08-27 18:40:35 +0800 CST
  • Martin Hope
    LiDa Cute 为什么 'char -> int' 是提升,而 'char -> Short' 是转换(但不是提升)? 2023-08-24 20:46:59 +0800 CST
  • Martin Hope
    jabaa 为什么库中不调用全局变量的构造函数? 2023-08-18 07:15:20 +0800 CST
  • Martin Hope
    Panagiotis Syskakis std::common_reference_with 在元组上的行为不一致。哪个是对的? 2023-08-17 21:24:06 +0800 CST
  • Martin Hope
    Alex Guteniev 为什么编译器在这里错过矢量化? 2023-08-17 18:58:07 +0800 CST
  • Martin Hope
    wimalopaan C++17 中 std::byte 只能按位运算? 2023-08-17 17:13:58 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve