Custom Filter Component in React (Best Practices)

แชร์
ฝัง
  • เผยแพร่เมื่อ 25 ม.ค. 2025

ความคิดเห็น • 46

  • @aghileslounis
    @aghileslounis 6 หลายเดือนก่อน +30

    The approach is pretty good.
    But in this particular case i would do it differently.
    A better way imo would be to use the URL to store the state of the filters and have your filter component completely independent with 0 props. Also you can throw inside of it if it is used on a URL that is not meant to be used with product filter.

    • @leroviten
      @leroviten 6 หลายเดือนก่อน +3

      yup. Same here. Since I've made my custom useSearchParams hook, this has become a trivial thing to use filters anywhere and consume their values wherever needed

    • @aghileslounis
      @aghileslounis 6 หลายเดือนก่อน +1

      @@leroviten I like that

    • @KrelleTG
      @KrelleTG 5 หลายเดือนก่อน

      What is the best approach for doing this?
      Something like this?
      const [searchParams, setSearchParams] = useSearchParams();
      const search = searchParams.get("search") || "";

  • @davronmaxmudov3972
    @davronmaxmudov3972 6 หลายเดือนก่อน +6

    We are learning best practices and becoming a senior developer) Thank you so much 😊

  • @almog1her
    @almog1her 6 หลายเดือนก่อน +4

    Great video!
    The filters are saved in 2 states that update with an extra useState. Instead, I think it would be better to give the filter component both the state and the onChange as props, thus removing the extra state and the extra useEffect.

  • @lexsemenenko
    @lexsemenenko 4 หลายเดือนก่อน

    Such a clean way. Much appreciated.

  • @TechSpot56
    @TechSpot56 6 หลายเดือนก่อน

    Very helpful, keep it up with these type of videos.

  • @tiagomilitao
    @tiagomilitao 6 หลายเดือนก่อน

    You are an incredible teacher! Thank you very much for all the time and effort you put into making these videos!

  • @marioigkiempor6579
    @marioigkiempor6579 6 หลายเดือนก่อน +4

    Very clear video, thank you.
    Could it be better to keep the state variables in the parent (App) component and pass the setters to the filters? That way you are not duplicating the state and you wouldn’t need the useEffect?

    • @princeholic3737
      @princeholic3737 6 หลายเดือนก่อน

      I am doing the same @cosden please answer on this

    • @cosdensolutions
      @cosdensolutions  6 หลายเดือนก่อน +3

      you can, but then you lose the ability to have different filters for the inputs and for the query at the same time. For example if you had a save button that applied the filters to the query on click instead of on change. The filters would still update locally onChange in the filter component, but only update the parent on click.
      Also you could have done it by manually calling the refetch function with the filters onChange without storing them in App. But then you wouldn't have them in the query cache.
      Ultimately it depends on your specific component and what you need. All of the ways I suggested are valid!

    • @sebastianlpoliak
      @sebastianlpoliak 6 หลายเดือนก่อน +1

      I usually do it this way. I'd avoid unnecessary useEffect

  • @mehrdadarman
    @mehrdadarman 3 หลายเดือนก่อน

    Great video and awesome content but for more code refactoring .
    it would be great to change filter properties to only one object instead of seperate each of them to usestate hook we can do this in only one state and it helps us to add another property easily in future 🙂
    Thank so much for your great content keep going like this 🔥

  • @regilearn2138
    @regilearn2138 6 หลายเดือนก่อน +1

    Hi mate, appreciate for the wonderful content, please teach us how to do pagination best practice using an example.

  • @MsVsmaster
    @MsVsmaster 6 หลายเดือนก่อน +1

    I would do differently, using url as state for the filter, and pass them to the query key, in queryFn argument you have access to the query key, making it possible to read the first and second index containing the url state.

    • @cosdensolutions
      @cosdensolutions  6 หลายเดือนก่อน

      Yes that's also a great option

  • @mohdali-yq8gq
    @mohdali-yq8gq 6 หลายเดือนก่อน

    It is a great example of customer filter but we would like to request you to achieve the same filter by using url to store the state of the filters and please post your next video to achieve the same by using url

  • @juanmagomezomil9176
    @juanmagomezomil9176 6 หลายเดือนก่อน +1

    Is it better use queryParams to manage the filters and search??

  • @blacksun6761
    @blacksun6761 6 หลายเดือนก่อน

    Always bangers !!!

  • @KrelleTG
    @KrelleTG 6 หลายเดือนก่อน

    @15:03 - I don't understand how the search from the filter-components gets sent to the App.tsx.
    In my head, we would need to pass the "search" state from App.tsx to the filter--component in order to access it.
    Does the concept youre doing have a name, so i can read into it?

  • @koolam5158
    @koolam5158 6 หลายเดือนก่อน

    sir, that's really good content.
    Could you advise the best practices if there will be many filter parameters like 10 to 15, not like the 3 as this example

  • @24pratikbhagwat68
    @24pratikbhagwat68 6 หลายเดือนก่อน

    hey really great video and btw whats the name of your theme?

  • @ahmedhassan_saver
    @ahmedhassan_saver หลายเดือนก่อน

    I think u should do another vid that enhance this to use search params

  • @sabafarzan
    @sabafarzan 6 หลายเดือนก่อน

    Hi thanks for the best content that you have created please develope a big project from zero ❤

  • @candyman3537
    @candyman3537 5 หลายเดือนก่อน

    I noticed the useQuery is not inside useEffect. Does that mean anything change in the search value, the useQuery will be called?

  • @kalideb-y3y
    @kalideb-y3y 5 หลายเดือนก่อน

    is adding hooks (like useState) in our useDebounce necessary?

  • @sriramvenkatesh
    @sriramvenkatesh 6 หลายเดือนก่อน

    Thankyou sir. Will you give videos on "React Query" in detail which is very rare?

  • @adarshchhokar3818
    @adarshchhokar3818 6 หลายเดือนก่อน

    in your search, what if the category or maxprice is null, then wouldn't setSearch give an error?

  • @rugucloud
    @rugucloud 6 หลายเดือนก่อน

    use reactQuery selet for filtering is good?

  • @abrahamibizugbe477
    @abrahamibizugbe477 6 หลายเดือนก่อน

    Your discord link doesn't work, same with project-react link😢
    Are these links location dependent?

  • @kalideb-y3y
    @kalideb-y3y 5 หลายเดือนก่อน

    why react is still working when there's a typescript error?

  • @regilearn2138
    @regilearn2138 6 หลายเดือนก่อน

    Hi mate, would like to suggest datetime picker and complex form input types from real world.

  • @logconsole-s2f
    @logconsole-s2f 6 หลายเดือนก่อน

    Shouldn't we use useDefferdValue instead of debounce?

    • @cosdensolutions
      @cosdensolutions  6 หลายเดือนก่อน

      not here, because we want to control when the value changes. With useDeferredValue the re-render happens as soon as possible where as we want minimum 500ms

    • @logconsole-s2f
      @logconsole-s2f 6 หลายเดือนก่อน

      @@cosdensolutions
      I see. So it's because you want to suppress frequent re-renders, right? The debounce ensures a minimum delay between updates, which can help reduce unnecessary re-renders and potentially improve performance, especially if the onChange handler triggers expensive operations or API calls. Is that the main reasoning behind using debounce here instead of useDeferredValue?

    • @cosdensolutions
      @cosdensolutions  6 หลายเดือนก่อน

      @@logconsole-s2f yes, but not for those reasons. Frequent re-renders aren't a problem, but when each render causes a new fetch, they are. useDeferredValue will re-render as fast as the processor will allow of the user's machine. So if they have a decent computer, it will happen quickly. Each render will trigger a new fetch request, which we don't want. Using useDebounce will always delay by 500ms after last update, which is preferred when dealing with requests after each render

  • @congminhluu5068
    @congminhluu5068 6 หลายเดือนก่อน +4

    that useEffect is totally unnecessary and can evolve into a mess really quick if we were to scale this up

    • @LEDsellers
      @LEDsellers 5 หลายเดือนก่อน

      Is the alternative useCallback?

  • @Generally2310
    @Generally2310 5 หลายเดือนก่อน

    First this is not close to being senior developer code and I’m not hating at all imagine if I for example where to look at the product page and apply certain filters and then would like to share that with someone else it won’t work because when they their page loads, the page state is lost category max price, and all filters are back to their initial state. A better solution would be to store the filters as URL parameters And use them as the initial state and when user changes them update the parameters so that the state in the application matches with the search parameters and also inside the fetch product function instead of using three if statements, we could just filter the products one time and apply all the filters at the same time any product that matches all the filters will then be returned

  • @matchu-pitchu
    @matchu-pitchu 6 หลายเดือนก่อน +1

    In my opinion, the example does not follow good practice.
    Problem 1: We have three so-called shadow states, i.e. the same filter states twice unnecessarily. Ideally, the logic should always be derived from one single source of truth.
    Problem 2: The useEffect with onChange is an unnecessary side effect that will cause problems in large apps. I would always recommend connecting the handlers (here onChange) directly to the action, i.e. to the input onChange event.

    • @matchu-pitchu
      @matchu-pitchu 6 หลายเดือนก่อน

      When you solve problem 2, you don’t have problem 1 anymore 😄

    • @dinuka
      @dinuka 6 หลายเดือนก่อน

      Agree

  • @Seacrest.
    @Seacrest. 6 หลายเดือนก่อน

    even deps in alphabet order?! maniac