搜索

首页  >  问答  >  正文

FluentUI React v9 Combobox - 无法设置组件宽度

<p>是否有某种方法可以指定 Fluent UI Combobox 组件(@fluentui/react-components)的宽度?</p> <p>对于其他输入元素,可以使用 <code>style={{width: "123px"}}</code> 设置(但不确定这是否是推荐的方式),但这不适用于 Combobox。< /p>
P粉823268006P粉823268006456 天前610

全部回复(1)我来回复

  • P粉392861047

    P粉3928610472023-09-02 09:32:52

    style={{width: "123px"}} 不起作用,因为组合框的根元素的固定 min-width 设置为 250px。

    所以要改变Combobox的宽度,这取决于你想要达到的目的。

    如果你只是想让它更大,你可以简单地增加这个最小宽度:

    <Combobox
        style={{minWidth: '800px'}}
    >
        <Option>A</Option>
        <Option>B</Option>
    </Combobox>

    如果要将其设置为特定宽度,可以取消设置根元素的 min-width,然后设置底层输入元素的宽度(在本例中,Combobox 的最终宽度将大于20px,因为输入填充和下拉按钮):

    <Combobox
        style={{minWidth: 'unset'}}
        input={{style: {width: '20px'}}}
    >
        <Option>A</Option>
        <Option>B</Option>
    </Combobox>

    编辑:除了使用 style-Prop,您还可以使用 css 类(我认为更干净的方式):

    export const ComboboxExample: FunctionComponent = () => {
        const classes = useStyles()
        return (
            <Combobox className={classes.combobox}>
                <Option>A</Option>
                <Option>B</Option>
            </Combobox>
        )
    }
    
    const useStyles = makeStyles({
        combobox: {
            minWidth: 'unset',
            '>.fui-Combobox__input': {
                width: '20px',
            },
        },
    })

    回复
    0
  • 取消回复