文檔地址:https://ant.design/components/table-cn/
在antd文檔中有相關介紹可以發現篩選項的配置在表格的列配置(columns)中實現,相關文檔如下

可以發現主要由filterDropdown屬性畫自定義內容,代碼參考:
/**
* 篩選項
*/
const filterList=[
{ text: '1', value: '1',ischecked:true },
{ text: '2', value: '2', ischecked:true },
{ text: '3', value: '3' ,ischecked:true},
];
const [filterCon,setFilterCon] = useState<any>(); // 確定篩選
const [filterIsChecked,setFilterIsChecked] = useState<any>(filterList); // 篩選項
const [filtered,setFiltered] = useState<boolean>(false); // 篩選項是否高亮
const [filterDropdownVisible,setFilterDropdownVisible] = useState<boolean>(false); // 篩選項下拉
/**
* 篩選選中
* @param e
* @param text
*/
const handleChangeCheckbox = (e:any,text:any,index:any) => {
let newfilter:any=[...filterIsChecked];
newfilter[index].ischecked=e.target.checked;
setFilterIsChecked(newfilter);
}
/**
* 篩選重置事件
*/
const handleReset = () => {
let newfilter:any=[...filterIsChecked];
newfilter.forEach((item:any) => {
item.ischecked=true;
});
setFiltered(false);
setFilterIsChecked(newfilter);
setFilterCon([]);
}
/**
* 篩選確定事件
*/
const handleSearch = () => {
setFiltered(true);
let newfilter:any=[...filterIsChecked];
let checked:any = [];
newfilter.forEach((item:any) => {
if(item.ischecked){
checked.push(item.text);
}
});
setFilterCon(checked);
setFilterDropdownVisible(false);
}
//列配置項
{ title:'分類', dataIndex:'indexCategory', filterDropdown:() => ( <div style={{ padding: 8 }}> <div className={styles.filterList}> {filterIsChecked.map((item:any,index:any) => //篩選項循環 <div key={item.value} className={styles.filterItem}> <Checkbox onChange={(e) => handleChangeCheckbox(e,item.text,index)} checked={item.ischecked}>{item.text}</Checkbox> </div> )} </div> <Space> <Button onClick={() => handleReset()} size="small" > 重置 </Button> <Button type="primary" onClick={() => handleSearch()} size="small" > 確定 </Button> </Space> </div> ), filterDropdownVisible:filterDropdownVisible, filterIcon: () => <FilterFilled style={{ color: filtered ? '#1890ff' : undefined }} />, onFilterDropdownVisibleChange:(visible:any) => { //是否顯示篩選框 if(visible){ setFilterDropdownVisible(true); }else{ setFilterDropdownVisible(false); } } },
