• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

React SVG - zmiana koloru path, kiedy jest ich dużo

0 głosów
499 wizyt
pytanie zadane 6 lipca 2022 w JavaScript przez zerakot Obywatel (1,870 p.)

Witam,
mam svg, które zawiera około 1000 potomków path. Importuję je za pomocą

import { ReactComponent as SvgMap } from './ww.svg';
...
return(
  <SvgMap/>
);


i teraz chciałbym zmienić w jednym z path o odpowiednim ID jego fill kolor. Jak mogę to zrobić?

Jeszcze dodam, że najlepiej gdyby nie wiązało się to z ponownym renderowaniem SVG oraz, że kolor path jest generowany m.in na podstawie ID.

1 odpowiedź

0 głosów
odpowiedź 6 lipca 2022 przez ScriptyChris Mędrzec (190,190 p.)

Na oko - nie znając komponentu SvgMap - możesz mu podpiąć ref i gdy on się wyrenderuje, to querySelectorem wyszukać konkretny path po identyfikatorze i zmienić mu styl fill.

Coś w tym stylu:

import { ReactComponent as SvgMap } from './ww.svg';
...

function YourComponent() {
  const svgMapRef = useRef();

  useEffect(() => {
    if (svgMapRef.current) {
      svgMapRef
        .current
        .querySelector( <tutaj_id_patha> )
        .style
        .fill = <nowa_wartość>;
    }
  }, [svgMapRef.current]);

  return (
    <SvgMap ref={svgMapRef}/>
  );
}

 

komentarz 8 lipca 2022 przez zerakot Obywatel (1,870 p.)
Dlaczego w parametrze useEffect jest ref? Nie wywoła to nieskończonej pętli? Skoro będzie wywoływana zmiana ref przy każdej zmianie ref?
komentarz 8 lipca 2022 przez ScriptyChris Mędrzec (190,190 p.)

svgMapRef.current jest przekazany w parametrze do useEffect, żeby ograniczyć wywoływanie jego callbacka tylko do momentów, gdy svgMapRef.current zmieni wartość. Nieskończonej pętli być nie powinno, bo referencja zmieni wartość raczej tylko raz - z null na element DOM.

komentarz 8 lipca 2022 przez ScriptyChris Mędrzec (190,190 p.)

Chociaż być może lepiej jest użyć useCallback żeby nie było odwrotnej sytuacji, że React nie odświeży komponentu, w którym tworzysz ref.

Podobne pytania

0 głosów
0 odpowiedzi 628 wizyt
pytanie zadane 16 kwietnia 2023 w JavaScript przez AgentTecza Obywatel (1,810 p.)
0 głosów
1 odpowiedź 200 wizyt
pytanie zadane 9 lipca 2019 w JavaScript przez bezendu Nowicjusz (190 p.)
+1 głos
1 odpowiedź 2,553 wizyt
pytanie zadane 16 listopada 2021 w HTML i CSS przez TheDarkSide Użytkownik (930 p.)

93,631 zapytań

142,553 odpowiedzi

323,056 komentarzy

63,139 pasjonatów

Advent of Code 2025

Top 15 użytkowników

  1. 2900p. - dia-Chann
  2. 2870p. - DziarnowskiJ
  3. 2827p. - Łukasz Piwowar
  4. 2783p. - raydeal
  5. 2713p. - rucin93
  6. 2579p. - Łukasz Eckert
  7. 2529p. - Adrian Wieprzkowicz
  8. 2459p. - CC PL
  9. 2184p. - Maurycy W
  10. 2082p. - Michal Drewniak
  11. 1885p. - robwarsz
  12. 1811p. - rafalszastok
  13. 1600p. - Rafał Trójniak
  14. 1588p. - Tomasz Bielak
  15. 1494p. - ssynowiec
Szczegóły i pełne wyniki

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Kursy INF.02 i INF.03
...