Rumah  >  Artikel  >  hujung hadapan web  >  Apa itu React Fiber

Apa itu React Fiber

WBOY
WBOYasal
2022-04-19 11:48:193314semak imbas

React Fiber ialah struktur data yang serupa dengan senarai terpaut berganda ReactDom akan menghasilkan nod gentian untuk setiap nod dom berdasarkan jsx, dengan anak menunjuk ke nod anak pertama, adik beradik menunjuk ke nod adik beradik seterusnya, dan kembali menunjuk kepada induk Struktur data nod ialah struktur data gentian.

Apa itu React Fiber

Persekitaran pengendalian tutorial ini: Sistem Windows 10, bertindak balas versi 17.0.1, komputer Dell G3.

Apakah itu React Fiber

Apakah itu serat? Oleh kerana bahasa Inggeris adalah bahasa ibunda pengaturcara asing, mereka sangat khusus tentang penamaan dalam kod. Serat bermaksud serat Semua orang tahu proses dan serat adalah sesuatu yang lebih nipis daripada benang. Oleh kerana JS adalah satu benang, dari perspektif ini, penamaan gentian adalah sangat canggih.

Di atas adalah konsep serat Apakah serat dalam kod? Malah, gentian ialah struktur data yang serupa dengan senarai berganda. Seperti yang ditunjukkan di bawah:

Apa itu React Fiber

reactDom akan menjana nod gentian untuk setiap nod dom berdasarkan jsx .), anak menunjuk ke nod anak pertama, adik beradik menunjuk ke nod adik beradik seterusnya, dan titik kembali ke nod induk. Struktur data sedemikian adalah struktur data gentian, dan sudah tentu data lain disimpan dalam gentian.

Bagaimana gentian berfungsi

Kini setelah kita memahami struktur data gentian, bagaimana gentian memainkan peranan dalam kemas kini gangguan tak segerak dalam bertindak balas?

  Pertama sekali, mari kita lihat mengapa dom maya tindak balas asal (versi sebelum v16) tidak boleh menyokong kemas kini yang boleh diganggu Pertama, kami menganggap bahawa dom maya tidak boleh diganggu (sebenarnya tidak boleh diganggu), seperti kod berikut <.>

// 更新前
 <ul>
    <li>1</li>
    <li>2</li>
    <li>3</li>
 </ul>
 // 更新一
 <ul>
    <li>2</li>
    <li>3</li>
    <li>4</li>
 </ul>
Kami mengemas kini 123 kepada 234 (Kemas kini 1, semasa proses kemas kini, apabila 1->2, 2->3 selesai, ia terganggu, dan 3 tidak menjadi 4. Kemudian hasilnya ialah 233, iaitu Pepijat telah berlaku.

  Penyelesaian untuk react v16 ialah teknologi caching berganda, iaitu, apabila mengemas kini, react menyimpan dua struktur data gentian, seperti yang ditunjukkan di bawah:

Apa itu React Fiber

  Dalam gambar di atas , rootFiber ialah aplikasi tindak balas, footFiberNode ialah nod di mana aplikasi digantung, dan gentian yang ditunjuk oleh arus ialah gentian yang diberikan dalam halaman (iaitu, paparan yang muncul pada skrin kami memanggilnya gentian semasa). . Setiap nod gentian gentian semasa adalah Terdapat satu alternod yang menghala ke nod gentian yang sama dalam pokok lain Kami memanggil gentian kerja DalamProgress ini.

Kami tahu bahawa apabila versi sebelum react v16 dikemas kini, jsx dan pepohon dom maya akan digunakan untuk algoritma diff, dan hasil pengiraan ialah paparan akhir yang perlu dikemas kini. Dalam algoritma pembezaan v16 bertindak balas, gentian jsx dan workInProgress dikira, dan akhirnya paparan akhir diperoleh, dan kemudian penuding semasa dihalakan ke gentian workInProgress untuk menghasilkan paparan baharu. Algoritma diff dengan gentian workInProgress dilakukan dalam ingatan dan tidak akan menjejaskan paparan sedia ada walaupun ia terganggu.

Pembelajaran yang disyorkan: "

tutorial video bertindak balas"

Atas ialah kandungan terperinci Apa itu React Fiber. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn