How to re-render 사용자 지정 후크한 후 처음 렌더링

0

질문

나는 주문 걸이라는 이름 useIsUserSubscribed 는지 확인하는 특정 사용자가 구독 신청을 했습니다. 그것은 경우 true 를 반환합니다 사용자 가입 및 거짓는 경우 사용자가 가입되어 있지 않은...

import { useState, useEffect } from "react";
import { useSelector } from "react-redux";
import { checkSubscription } from "../services";

// this hook checks if the current user is subscribed to a particular user(publisherId)
function useIsUserSubscribed(publisherId) {
  const [userIsSubscribed, setUserIsSubscribed] = useState(null);
  const currentUserId = useSelector((state) => state.auth.user?.id);

  useEffect(() => {
    if (!currentUserId || !publisherId) return;

    async function fetchCheckSubscriptionData() {
      try {
        const res = await checkSubscription(publisherId);
        setUserIsSubscribed(true);
      } catch (err) {
        setUserIsSubscribed(false);
      }
    }

    fetchCheckSubscriptionData();
  }, [publisherId, currentUserId]);

  return userIsSubscribed;
}

export default useIsUserSubscribed;

...나는 버튼을 사용하여 이 후크는 텍스트 렌더링하는 조건에 따라 부울에서 돌아 useIsUserSubscribed...

import React, { useEffect, useState } from "react";
import { add, remove } from "../../services";
import useIsUserSubscribed from "../../hooks/useIsUserSubscribed";

const SubscribeUnsubscribeBtn = ({profilePageUserId}) => {

  const userIsSubscribed = useIsUserSubscribed(profilePageUserId);
  
  const onClick = async () => {
    if (userIsSubscribed) {
       // this is an API Call to the backend
      await removeSubscription(profilePageUserId);

    } else {
      // this is an API Call to the backend
      await addSubscription(profilePageUserId);
    }
    // HOW CAN I RERENDER THE HOOK HERE!!!!?
  }

  return (
    <button type="button" className="sub-edit-unsub-btn bsc-button" onClick={onClick}>
          {userIsSubscribed ? 'Subscribed' : 'Unsubscribed'}
    </button>
  );
} 

후에 onClick I would like to rerender 내 useIsUserSubscribed 걸이는 버튼을 텍스트켰습니다. 할 수 있습니까?

3

최고의 응답

2

당신이 사용할 수 없습니다 useEffect 에 걸이 그 목적을 위해 이것을 시도하십시오:

hook:

function useIsUserSubscribed() {
  const currentUserId = useSelector((state) => state.auth.user?.id);


  const checkUser = useCallback(async (publisherId, setUserIsSubscribed) => {
    if (!currentUserId || !publisherId) return;
      try {
        const res = await checkSubscription(publisherId);
        setUserIsSubscribed(true);
      } catch (err) {
        setUserIsSubscribed(false);
      }
    
  }, [currentUserId]);

  return {checkUser};
}

export default useIsUserSubscribed;

구성 요소:

const SubscribeUnsubscribeBtn = ({profilePageUserId}) => {
    const [userIsSubscribed,setUserIsSubscribed]=useState(false);
    const { checkUser } = useIsUserSubscribed();

     useEffect(()=>{
        checkUser(profilePageUserId,setUserIsSubscribed)
     },[checkUser,profilePageUserId]);
  
  const onClick = async () => {
    if (userIsSubscribed) {
       // this is an API Call to the backend
      await removeSubscription(profilePageUserId);

    } else {
      // this is an API Call to the backend
      await addSubscription(profilePageUserId);
    }
    // HOW CAN I RERENDER THE HOOK HERE!!!!?
    checkUser(profilePageUserId,setUserIsSubscribed)
  }

  return (
    <button type="button" className="sub-edit-unsub-btn bsc-button" onClick={onClick}>
          {userIsSubscribed ? 'Subscribed' : 'Unsubscribed'}
    </button>
  );
} 

할 수도 있습니다 추가 로딩 상태에 걸이와 반환로도 확인할 수 있는 경우 프로세스가 이미지

2021-11-24 03:03:13

내가 하려는 다시 이 논리는 다른 부분에서는 경우 응용 프로그램. 무엇이 더 좋은 방법이 재사용할 수 있는지 최상의 방법?
Simone Anthony

@SimoneAnthony 아무것도 잘못 걸이를 가진 사용할 수 있습니다 하지만 제가 알게 사용할 돌아 오는 사용할 수 있도록 돌아-썽 작업무
Mohammad
2

추가 dependece 에 useIsUserSubscribed 의 useEffect.

hook:

function useIsUserSubscribed(publisherId) {
    const [userIsSubscribed, setUserIsSubscribed] = useState(null);
    const currentUserId = useSelector((state) => state.auth.user?.id);
    // add refresh dependece
    const refresh = useSelector((state) => state.auth.refresh);

    useEffect(() => {
        ...
    }, [publisherId, currentUserId, refresh]);
    ...
}

구성 요소:

const onClick = async () => {
    ...
    // HOW CAN I RERENDER THE HOOK HERE!!!!?
    // when click, you can dispatch a refresh flag.
    dispatch(refreshSubState([]))
}

노출 forceUpdate metheod.

hook:

function useIsUserSubscribed(publisherId) {
    const [update, setUpdate] = useState({});
    const forceUpdate = () => {
        setUpdate({});
    }  

    return {userIsSubscribed, forceUpdate};
}

구성 요소:

const {userIsSubscribed, forceUpdate} = useIsUserSubscribed(profilePageUserId);

const onClick = async () => {
    ...
    forceUpdate();
}
2021-11-24 02:56:11
0

여기에서 다른 솔루션을 사용자에 의해@bitspook

SubscribeUnsubscribeBtn 에 종속되어 있습니다 useIsUserSubscribed하지만, useIsUserSubscribed 에 의존하지 않에서 아무것도 SubscribeUnsubscribeBtn. 대 useIsUserSubscribed 는 현지 상태가 됩니다. 당신은 몇 가지를 선택 여기:

  1. 이동 상태에 관한 whetehr 사용자가 가입되어나지 않는 한,최대 수준을 사용하기 때문에 돌아 오는,아마도 돌아오.
  2. 통신 useIsUserSubscribed 하는 데 필요 변경 내부 상태에 있습니다.

1)

  const [userIsSubscribed, setUserIsSubscribed] = useState(null);

이동 상태를 돌아 오는 저장하고 사용 useSelector.

2),의 배열을 반환 값과에서 콜백 걸이 대신 값으로 설정합니다. 그것은 당신을 허용할 것입니다 의사 소통에서 구성 요소로 다시합니다.

useIsUserSubscribed,

  return [userIsSubscribed, setUserIsSubscribed];

다음 onClick할 수 있습 call setUserIsSubscribed(false)변경,후크의 내부 상태,그리고 다시 렌더링의 구성 요소입니다.

2021-11-24 03:37:35

다른 언어로

이 페이지는 다른 언어로되어 있습니다

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................