• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
    • Questions
    • Teachers
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

99
Views
Reacciona los programas de carga de un elemento en cada elemento en bucle

Tengo una página de reacción donde muestro todos los elementos de preguntas frecuentes en una lista dentro de un bucle de mapa de javascript. Hay dos botones sí o no. Los usuarios pueden votar una respuesta sí o no. Entonces, cada vez que el usuario haga clic en los botones, se mostrará un indicador de carga.

Página de preguntas frecuentes:

 <> { faqs.map((faq) => ( <Faq key={faq.id} faq={faq} /> )) } </>

Componente de preguntas frecuentes:

 interface IProps { faq: IFaq; } const FaqVoteSection: React.FC<IProps> = (props) => { const { faq } = props; const dispatch = useDispatch(); const { faqVoteLoading } = useSelector((state: AppState) => state.user); const [loadingState, setLoadingState] = useState< 'yesvote-loading' | 'novote-loading' | 'not-loading' >('not-loading'); const onVoteSubmit = async (vote: boolean) => { if (faq) { dispatch( faqVoteApiAction({ faq_id: faq.id, vote, }) ); setLoadingState('not-loading'); } }; const onYesVotePress = () => { setLoadingState('yesvote-loading'); onVoteSubmit(true); }; const onNoVotePress = async () => { setLoadingState('novote-loading'); await onVoteSubmit(false); }; return ( <FlexContainer> <SolidButton type={faq.vote === 'yes' ? 'primary' : 'default'} size="small" onClick={onYesVotePress} loading={loadingState === 'yesvote-loading' && faqVoteLoading} > Yes </SolidButton> <Gap /> <SolidButton size="small" type={faq.vote === 'no' ? 'primary' : 'default'} onClick={onNoVotePress} loading={loadingState === 'novote-loading' && faqVoteLoading} > No </SolidButton> </FlexContainer> ); };

Ahora, cuando hago clic en un botón de votación, quiero mostrar la carga solo para ese elemento. Pero la carga muestra todos los elementos de la lista. Creo que es por el bucle del mapa.

ingrese la descripción de la imagen aquí

almost 3 years ago · Juan Pablo Isaza
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error