Реагируйте на пользовательский хук, используя только useEffect - PullRequest
0 голосов
/ 19 января 2020

Я создал настраиваемый хук, который использует useEffect для обновления хранилища с избыточностью при изменении определенных значений в хранилище:

import { useRef, useEffect } from 'react'
import { useSelector, useDispatch } from 'react-redux'
import { index } from '../actions'
import { createSelector } from 'reselect'
import { omit } from 'lodash'

const selectPerformanceSearch = createSelector(
  state => omit(state.eventSearch, ['results', 'isFetching']),
  items => items
)

export default function useEventSearch() {
  const state = useSelector(selectEventSearch)
  const dispatch = useDispatch()
  const initialFetch = useRef(true)
  const { tags, near, filters } = state
  const { lng, lat, location } = near

  useEffect(() => {
    if (!initialFetch.current) {
      const data = { tags, lng, lat, filters }
      dispatch(index('/event/search', 'EVENT_SEARCH', data))
    }
  }, [tags, lng, lat, filters, dispatch])

  useEffect(() => {
    if (initialFetch.current && location) {
      initialFetch.current = false
      const data = { lng, lat }
      dispatch(index('/event/closest', 'EVENT_SEARCH', data))
    }
  }, [lng, lat, location, dispatch])
}

Затем у меня есть компонент React, который использует хук следующим образом:

import useEventSearch from '../../hooks/usePerformanceSearch'

const SearchBar = props => {
  // ...code

  usePerformanceSearch()

  /// ...other code
  return ( ... )
}

Все работает так, как я ожидал, но можно ли просто позвонить и использовать перехват, как я сделал?

...