Рэндэр і фіксацыя
React павінен адрэндэрыць вашы кампаненты перш чым яны будуць выведзены на экран. Калі вы ведаеце этапы гэтага працэсу, вам будзе прасцей зразумець, як выконваецца ваш код, і растлумачыць яго паводзіны.
You will learn
- Што азначае рэндэрынг у React
- Калі і чаму React рэндэрыць кампанент
- Этапы адлюстравання кампанента на экране
- Чаму рэндэрынг не заўсёды прыводзіць да абнаўлення DOM
Уявіце, што вашы кампаненты — гэта кухары на кухні, якія збіраюць смачныя стравы з інгрэдыентаў. У такім выпадку React — гэта афіцыянт, які прымае запыты кліентаў, а потым прыносіць ім іх стравы. Гэты працэс запыту і падачы карыстальніцкага інтэрфейсу складаецца з трох этапаў:
- Ініцыяцыя рэндэрынгу (перадача заказа госця на кухню)
- Рэндэрынг кампанента (гатаванне заказу на кухні)
- Фіксацыя у DOM (падача стравы на стол)
Illustrated by Rachel Lee Nabors
Этап 1: Ініцыяцыя рэндэрынгу
Рэндэр кампанента адбываецца па дзвюх прычынах:
- Гэта яго першапачатковы рэндэр.
- Яго стан (або стан яго бацькоўскіх кампанентаў) быў абноўлены.
Першапачатковы рэндэр
Калі ваша праграма запускаецца, неабходна запусціць першапачатковы рэндэрынг. Фрэймворкі і пясочніцы часам хаваюць гэты код, але першапачатковы рэндэр робіцца шляхам выкліку функцыі createRoot
з мэтавым DOM-вузлом, а затым выклікам яго метаду render
з вашым кампанентам:
import Image from './Image.js'; import { createRoot } from 'react-dom/client'; const root = createRoot(document.getElementById('root')) root.render(<Image />);
Паспрабуйце закаментаваць выклік root.render()
і ўбачыце, як кампанент знікне!
Паўторны рэндэр пры абнаўленні стану
Пасля таго як кампанент быў першапачаткова адрэндэраны, вы можаце ініцыяваць наступныя рэндэры, абнаўляючы яго стан з дапамогай функцыі set
. Абнаўленне стану кампанента аўтаматычна ставіць яго ў чаргу на рэндэр. (Гэта падобна на наведвальніка рэстарана, які пасля першапачатковага заказу, дазаказвае сабе чай, дэсерт і разнастайныя рэчы, у залежнасці ад стану смагі ці голаду.)
Illustrated by Rachel Lee Nabors
Этап 2: React рэндэрыць вашы кампаненты
Пасля запуску рэндэру React выклікае вашы кампаненты, каб вызначыць, што паказаць на экране. «Рэндэрынг» — гэта калі React выклікае вашы кампаненты.
- Пры першапачатковым рэндэры React выкліча каранёвы кампанент.
- Пры наступных рэндэрах React будзе выклікаць функцыю кампанента, абнаўленне стану якога выклікала рэндэр.
Гэта рэкурсіўны працэс: калі абноўлены кампанент вяртае нейкі іншы кампанент, React адрэндэрыць гэты кампанент наступным, і калі гэты кампанент таксама вяртае што-небудзь, ён адрэндэрыць ужо гэты кампанент наступным, і гэтак далей. Працэс будзе працягвацца датуль, пакуль не застанецца ўкладзеных кампанентаў і React не будзе дакладна ведаць, што павінна быць адлюстравана на экране.
У наступным прыкладзе React выклікае Gallery()
і Image()
некалькі разоў:
export default function Gallery() { return ( <section> <h1>Inspiring Sculptures</h1> <Image /> <Image /> <Image /> </section> ); } function Image() { return ( <img src="https://i.imgur.com/ZF6s192.jpg" alt="'Родавы Флораліс' Эдуарда Каталана: гіганцкая металічная скульптура кветкі з люстэркавымі пялёсткамі" /> ); }
- Пры першапачатковым рэндэры React створыць DOM-вузлы для
<section>
,<h1>
і трох<img>
тэгаў. - Падчас паўторнага рэндэру React падлічыць, якія з іх уласцівасцей, калі такія маюцца, змяніліся з моманту папярэдняга рэндэру. Ён нічога не будзе рабіць з гэтай інфармацыяй да наступнага кроку, фазы фіксацыі.
Deep Dive
Прадвызначаныя паводзіны, пры якіх адлюстроўваюцца ўсе кампаненты, укладзеныя ў абноўлены кампанент, не з’яўляюцца аптымальнымі з пункта гледжання прадукцыйнасці, калі абноўлены кампанент знаходзіцца вельмі высока ў дрэве. Калі вы сутыкнуліся з праблемай прадукцыйнасці, то ёсць некалькі спосабаў яе вырашэння, апісаных у раздзеле Прадукцыйнасць. Не аптымізуйце раней часу!
Этап 3: React фіксуе змены ў DOM
Пасля рэндэрынгу (выкліку) вашых кампанентаў React змяняе DOM.
- Пры першапачатковым рэндэры React выкарыстоўвае функцыю DOM API
appendChild()
, каб вывесці на экран усе створаныя ім DOM-вузлы. - Пры паўторным рэндэры React прыменіць мінімальна неабходныя аперацыі (якія вылічаюцца падчас рэндэрынгу!), каб DOM адпавядаў апошняму вываду рэндэрынгу.
React змяняе DOM-вузлы толькі калі ёсць розніца паміж рэндэрамі. Напрыклад, вось кампанент, які рэндэрыцца з рознымі пропсамі, якія перадаюцца ад бацькоўскага кампанента кожную секунду. Звярніце ўвагу, што вы можаце дадаць тэкст у <input>
, абнаўляючы яго значэнне
, і што пры паўторным рэндэры кампанента тэкст не знікае:
export default function Clock({ time }) { return ( <> <h1>{time}</h1> <input /> </> ); }
Гэта працуе, таму што падчас апошняга кроку React абнаўляе толькі змесціва <h1>
новым значэннем time
. Ён бачыць, што <input>
з’яўляецца ў JSX у тым жа месцы, што і ў мінулы раз, таму React не чапае <input>
ці яго значэнне
!
Эпілог: Браўзерная адмалёўка
Пасля таго як рэндэр завершаны і React абнавіў DOM, браўзер перамалёўвае экран. Хоць гэты працэс і вядомы як «браўзерны рэндэрынг», мы будзем называць яго «маляваннем», каб пазбегнуць блытаніны ў дакументацыі.
Illustrated by Rachel Lee Nabors