基于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-02React Fragment 和空標簽(<></>)用法及區(qū)別詳解
本文詳細介紹了React中的Fragment和空標簽的使用,包括它們的區(qū)別、使用場景、性能考慮以及最佳實踐,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2025-01-01React?程序設(shè)計簡單的輕量級自動完成搜索框應(yīng)用
這篇文章主要為大家介紹了React?程序設(shè)計簡單的輕量級自動完成搜索框應(yīng)用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10React.memo函數(shù)中的參數(shù)示例詳解
這篇文章主要為大家介紹了React.memo函數(shù)中的參數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09