React DatePicker 日历显示在表头后面

IT技术 css reactjs html-table datepicker z-index
2021-05-19 11:36:53

我在我的项目中使用了 react datePicker 和 fixed-data-table-2。当我打开日历时,它显示在桌头后面。这是CSS文件的代码:

.ui-datepicker {
   z-index: 9999 !important;
}
.table{
   z-index: -1000  !important;
}

这是 DatePicker 的 React 代码:

 <div className='ui-datepicker'>
           <DatePicker
                 selected={this.state.startDate}
                 selectsStart
                 startDate={this.state.startDate}
                 endDate={this.state.endDate}
                 onChange={this.onFilterStart}
            />
</div>

这是表格的快捷代码:

<div className='table'>
     <Table
            rowHeight={50}
            rowsCount={tableData.getSize()}
            width={1000}
            maxHeight={1800}
            height={700}
            groupHeaderHeight={30}
            headerHeight={50}
            onColumnResizeEndCallback={this.resizeEndCallback}
            isColumnResizing={false}
            >
            <ColumnGroup
                header={<Cell>Basic Info</Cell>}>
                <Column columnKey='menuTranslation'
                        header={ <SortHeaderCell
                                languageChosen={this.state.languageChosen}
                                onSortChange={this.sortChange}
                                sortDir={colSortDirs.foodName}>Food 
              Name</SortHeaderCell>}
                        isResizable={true}
                        width={columnWidths.foodName}
                        cell={<MyTextCell data={tableData}  
              field='menuTranslation' col="menuTranslation"  />}
                />
<div>

这是问题的图像:

图片

3个回答

尝试将 z-index 设置为 on.react-datepicker-popper而不是 datepicker。这是 react-date-picker 在它创建的弹出窗口上使用的 className。

.react-datepicker-popper {
    z-index: 9999 !important;
}

这是因为 Material-UI Paper 组件样式。Paper 组件有一个溢出:隐藏样式,通过删除它可以完美地工作。

import Card from "@material-ui/core/Card";
...
<Card>
<DayPickerInput  id="servdate" name="servdate"  dateFormat="yyyy-mm-dd"/>
</Card>

在样式集 .MuiCard-root{ overflow: visible!important; }

以防万一有人在这里结束并使用 Material-UI Cards,我通过添加z-index: 0 !importantCardHeader 样式来解决它(我注意到它z-index: 3! important默认使用 Chrome 开发工具)。

<CardHeader style={{zIndex: '0 !important'}}>
... 
</CardHeader>