基于antd的autocomplete的二次封裝查詢示例
更新時間:2023年08月24日 11:23:50 作者:點墨
這篇文章主要為大家介紹了基于antd的autocomplete的二次封裝查詢示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
正文
基于antd的autocomplete進行二次封裝,用于后端實時查詢數(shù)據(jù)
autocomplete.js
import React, { useEffect, useState } from "react";
import { useDebounceFn } from "ahooks";
import { AutoComplete as AntdAutoComplete } from "antd";
import lodash from "lodash";
import protoTypes from "prop-types";
function EndAutoComplete(props) {
const { value: propValue, onChange: propOnChange, defaultOptionsMap, fetchData, ...otherProps } = props;
const [value, setValue] = useState(propValue);
const [options, setOptions] = useState();
const [optionsMap, setOptionsMap] = useState({});
//初始化value
useEffect(() => {
if (defaultOptionsMap) {
setValue(defaultOptionsMap[propValue]);
}
}, [defaultOptionsMap])
//更新options map
useEffect(() => {
if (lodash.isArray(options)) {
let newOptionMap = {};
options.forEach(item => {
const { value, label } = item;
newOptionMap[label] = value;
})
setOptionsMap(newOptionMap);
}
}, [options])
const _handleSearch = value => {
const promise = fetchData(value);
if (promise && promise.then) {
promise.then(data => {
setOptions(data);
}).catch(e => {
console.error("AutoComplete Fetch Data Error", e)
setOptions([]);
})
}
}
const { run: handleSearch } = useDebounceFn(_handleSearch, { wait: 500 });//防抖
const onSearch = value => {
if (!value.trim()) {
setOptions([]);
return;
}
if (lodash.isFunction(fetchData)) {
handleSearch(value);
}
}
const onChange = (value) => {
if (lodash.isFunction(propOnChange)) {
propOnChange(optionsMap[value] || -999999);
}
setValue(value);
}
const onSelect = (value, option) => {
if (lodash.isFunction(propOnChange)) {
propOnChange(value);
}
setValue(option.label);
}
return (
<AntdAutoComplete
options={options}
onSearch={onSearch}
onSelect={onSelect}
onChange={onChange}
value={value}
{...otherProps}
>
</AntdAutoComplete>
)
}
EndAutoComplete.prototype = {
fetchData: protoTypes.func,//異步獲取數(shù)據(jù)
defaultOptionsMap: protoTypes.object,//用于鍵盤精靈初始化賦值
}
export default EndAutoComplete;以上就是基于antd的autocomplete的二次封裝查詢鍵盤示例的詳細內(nèi)容,更多關(guān)于antd autocomplete的二次封裝的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
手挽手帶你學React之React-router4.x的使用
這篇文章主要介紹了手挽手帶你學React之React-router4.x的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-02-02
React Fragment 和空標簽(<></>)用法及區(qū)別詳解
本文詳細介紹了React中的Fragment和空標簽的使用,包括它們的區(qū)別、使用場景、性能考慮以及最佳實踐,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2025-01-01
React.memo函數(shù)中的參數(shù)示例詳解
這篇文章主要為大家介紹了React.memo函數(shù)中的參數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09

