AutoComplete ReactJS / Redux 不改变搜索值
创始人
2024-09-22 19:30:56
0

在ReactJS / Redux中实现AutoComplete,并且不改变搜索值,可以使用以下解决方法:

首先,创建一个Redux store来存储搜索相关的数据。可以使用redux-thunk中间件来处理异步操作。

在Redux store中,创建以下reducer来处理搜索相关的操作:

// actionTypes.js
export const SET_SEARCH_TERM = 'SET_SEARCH_TERM';
export const SET_SEARCH_RESULTS = 'SET_SEARCH_RESULTS';

// actions.js
import { SET_SEARCH_TERM, SET_SEARCH_RESULTS } from './actionTypes';

export const setSearchTerm = searchTerm => ({
  type: SET_SEARCH_TERM,
  payload: searchTerm
});

export const setSearchResults = results => ({
  type: SET_SEARCH_RESULTS,
  payload: results
});

// reducer.js
import { SET_SEARCH_TERM, SET_SEARCH_RESULTS } from './actionTypes';

const initialState = {
  searchTerm: '',
  searchResults: []
};

const reducer = (state = initialState, action) => {
  switch (action.type) {
    case SET_SEARCH_TERM:
      return {
        ...state,
        searchTerm: action.payload
      };
    case SET_SEARCH_RESULTS:
      return {
        ...state,
        searchResults: action.payload
      };
    default:
      return state;
  }
};

export default reducer;

然后,在React组件中,使用redux-thunk来调用异步操作,并将搜索结果存储到Redux store中:

import React, { useEffect } from 'react';
import { useDispatch, useSelector } from 'react-redux';
import { setSearchTerm, setSearchResults } from './actions';

const AutoComplete = () => {
  const dispatch = useDispatch();
  const searchTerm = useSelector(state => state.searchTerm);
  const searchResults = useSelector(state => state.searchResults);

  const handleSearch = async () => {
    // 进行搜索操作,将结果存储到searchResults中
    const results = await fetchSearchResults(searchTerm);
    dispatch(setSearchResults(results));
  };

  useEffect(() => {
    handleSearch();
  }, [searchTerm]);

  const handleChange = e => {
    dispatch(setSearchTerm(e.target.value));
  };

  return (
    
    {searchResults.map(result => (
  • {result.name}
  • ))}
); }; export default AutoComplete;

在上述代码中,AutoComplete组件中的输入框的值由Redux store中的searchTerm来控制,并且每当searchTerm改变时,会触发handleSearch函数来调用异步操作并更新搜索结果。

这样,无论是用户输入还是调用异步操作,都不会直接改变搜索值,而是通过Redux store来管理和更新搜索值。

相关内容

热门资讯

透视中牌率"微友辅助... 透视中牌率"微友辅助器免费版"开挂(透视)辅助平台(一直是真的有挂的)-哔哩哔哩;亲,有的,ai轻松...
总算了解!德扑之星插件,wep... 大家好,今天小编来为大家解答德扑之星插件这个问题咨询软件客服可以免费测试直接加微信(13670430...
透视黑科技!吉林心悦游戏辅助,... 较多好评“微乐万能挂官网”开挂(透视)辅助教程 了解更多开挂安装加(136704302)微信号是一款...
透视辅助"哈局辅助器... 【福星临门,好运相随】;透视辅助"哈局辅助器"开挂(透视)辅助神器(其实是有挂的)-哔哩哔哩;暗藏猫...
必备辅助推荐!哈局八张模拟器,... 必备辅助推荐!哈局八张模拟器,wepoker辅助器,解说技巧(详细教程)-哔哩哔哩;1、超多福利:超...
每日必备"拱趴大菠萝... 每日必备"拱趴大菠萝攻略"开挂(透视)辅助工具(果然确实是有挂)-哔哩哔哩;拱趴大菠萝攻略是一款益智...
透视脚本!边锋斗地主微信小程序... 【亲,边锋斗地主微信小程序插件 这款游戏可以开挂的,确实是有挂的,很多玩家在这款边锋斗地主微信小程序...
一分钟揭秘"新上游通... 一分钟揭秘"新上游通用卦"开挂(透视)辅助工具(其实确实有挂的)-哔哩哔哩;新上游通用卦软件透视开挂...
透视能赢!天道辅助器使用教程,... 透视能赢!天道辅助器使用教程,wepoker有机器人吗,2026教程(有挂技巧)-哔哩哔哩;打开点击...
热点推荐"开心十三张... 热点推荐"开心十三张技巧"开挂(透视)辅助插件(原来是真的有挂的)-哔哩哔哩;AI辅助机器人普及解说...