Rumah >hujung hadapan web >tutorial js >Beyond Next.js: Meneroka Rangka Kerja Komponen Pelayan Reaksi Alternatif
Apabila pada penghujung tahun 2020 pasukan React memperkenalkan konsep "Komponen Pelayan Tindak Balas Saiz Sifar Bundle", ramai orang telah dan masih bergelut untuk memahaminya. Tiada rangka kerja sedia ada menyokong konsep baharu dan prototaip tidak menyediakan asas yang boleh digunakan untuk membina aplikasi dunia sebenar.
Kini, lebih 4 tahun kemudian, versi react yang diperlukan masih dalam versi beta dan tidak dikeluarkan untuk pengeluaran dan satu-satunya rangka kerja besar dan terkenal yang menyokongnya dikendalikan oleh bekas ahli pasukan. Ini adalah situasi yang sangat menyedihkan bagi beberapa pembangun yang telah cuba menawarkan rangka kerja alternatif berdasarkan RSC.
React biasa ialah perpustakaan yang hanya menumpukan pada penyediaan penyelesaian deklaratif pantas untuk membina aplikasi dalam penyemak imbas. Aplikasi dalam penyemak imbas sentiasa memerlukan pelayan untuk mengambil dan menyimpan keadaannya. Berdasarkan fakta ini, sejumlah besar penyelesaian telah dibangunkan dan wujud dalam sistem eko pelanggan tindak balas. Apabila semakin ramai orang mula membuat bahagian belakang mereka dengan Typescript, arah aliran seterusnya di mana kebangkitan RPC dengan antara muka ditaip yang mencipta titik akhir api di latar belakang.
Melihat RSC dengan keperluan ini, ia menjadi jelas dengan cepat bahawa semua ini berada dalam skop untuk RSC kerana ia menyediakan:
Ini membolehkan pembangun aplikasi menggunakan tindak balas untuk mentakrifkan semua komponen menggunakan tindak balas bebas daripadanya yang dipaparkan pada klien atau pada pelayan. Persekitaran bersepadu ini mengurangkan kerumitan apl moden dan menghapuskan lebihan logik perniagaan pendua di bahagian belakang dan bahagian hadapan.
Memandangkan pustaka react adalah rasmi masih beta, tiada satu pun daripada mereka harus dilihat sebagai pengeluaran sedia:
Pada masa ini hanya Next.js agak boleh digunakan untuk pengeluaran. Versi 15 mereka ialah lelaran ke-4 pada RSC yang bermula lewat 2021 dengan Versi 12.
Di luar rangka kerja yang disenaraikan, berikut adalah beberapa lagi repositori dengan cetak biru untuk membina rangka kerja RSC - gunakan rangka kerja tersebut jika anda ingin mengetahui lebih lanjut tentang dalaman:
Jika anda tahu daripada lebih banyak rangka kerja, sila berikan pautan kepada mereka dalam ulasan.
Mentranskripsi dan menghimpun, berdasarkan himpunan hebat sedia ada apl klien reaksi adalah mudah. Terdapat pelbagai pilihan untuk melakukan ini dan salah satu yang paling banyak digunakan ialah dengan menggunakan ViteJs sebagai pelayan pembangunan dan pengikat. Rangka kerja yang menyediakan timbunan bahagian hadapan dan hujung belakang JavaScript masih perlu menyediakan penyelesaian mereka sendiri untuk mengendalikan skrip taip dan penggabungan dalam pembangunan dan untuk pengeluaran.
Dengan RSC, pengikat perlu mengendalikan sekurang-kurangnya tiga saluran paip transkripsi dan berkas:
Sehingga keluaran Vite versi 6 ini memerlukan banyak kod khas untuk menyediakan penyelesaian yang berkesan. Next.js hanya bertukar kepada Turbopack dalam versi 15 untuk membetulkan ketinggalan yang mereka perolehi berdasarkan kerumitan dan penggunaan webpack yang tidak pernah dibina untuk menangani masalah seperti ini.
Ciri baharu Vite 6 ialah banyak pengarang rangka kerja penyasaran dan menyediakan penyelesaian hebat dengan api persekitaran baharu mereka.
Berdasarkan fakta bahawa kini komponen dipaparkan dalam persekitaran yang sama sekali berbeza, setiap perpustakaan tindak balas perlu dibina untuk mengendalikan sekatan setiap persekitaran ini dengan menyediakan kandungan alternatif. Pada masa ini kebanyakan pustaka boleh mengendalikan pemaparan pada pelayan untuk mencipta kandungan SSR, di mana banyak API khusus pelayar tiada. Memaparkan komponen RSC membawa had tambahan dengan perpustakaan pelayan tindak balas yang berbeza yang contohnya tidak menyokong konteks tindak balas dan menyatakan dan memecahkan perpustakaan yang memerlukan ini untuk menyediakan tema kepada semua komponen kanak-kanak. Dan perpustakaan memerlukan pilihan eksport yang betul dalam packages.json dan ESM-Modules untuk perpustakaan dan semua sub perpustakaan yang berkaitan.
Bahagian kedua yang tidak disediakan oleh perpustakaan reaksi untuk RSC ialah penghala. Tanpa penghala yang mengendalikan penghalaan klien dan pelayan, komponen pelayan bertindak balas tidak tahu keadaan mana yang hendak diberikan pada pelayan. Inilah sebab mengapa setiap rangka kerja datang dengan pelaksanaan penghala mereka sendiri dan sehingga api untuk ini menjadi piawai, komponen pelayan dan pelanggan yang dibangunkan untuk satu rangka kerja perlu ditukar untuk berfungsi dengan rangka kerja lain.
butiran lanjut tentang Komponen Pelayan React boleh didapati dalam dokumentasi React rasmi.
Keperluan Pilihan untuk rangka kerja meta:
Berdasarkan fakta, Next.js 15 ialah rangka kerja RSC yang paling utama, kenapa saya perlu melihat rangka kerja alternatif?
Sebab untuk melakukan ini sentiasa berdasarkan matlamat untuk dicapai, tetapi saya akan cuba menyenaraikan beberapa sebab mengapa ia masuk akal untuk melihat pilihan lain:
Sila ingat bahawa artikel ini hanya menumpukan pada alternatif yang menyediakan RSC, tetapi terdapat banyak lagi rangka kerja yang menyediakan ciri yang hampir serupa dengan RSC dan boleh menjadi alternatif yang jauh lebih baik daripada rangka kerja RSC yang disenaraikan dalam artikel ini.
Dibangunkan oleh Daishi Kato:
Waku (wah-ku) atau わく bermaksud “rangka kerja” dalam bahasa Jepun. Sebagai rangka kerja React yang minimum, ia direka untuk mempercepatkan kerja pembangun di syarikat permulaan dan agensi yang membina projek React bersaiz kecil hingga sederhana. Ini termasuk tapak web pemasaran, e-dagang ringan dan aplikasi web.
Kami mengesyorkan rangka kerja lain untuk aplikasi e-dagang atau perusahaan yang berat. Waku ialah alternatif ringan yang membawa pengalaman pembangun yang menyeronokkan ke era komponen pelayan. Ya, mari jadikan pembangunan React menyeronokkan semula!
Memulakan projek baharu dengan Waku adalah mudah dan anda akan mendapat templat permulaan yang disediakan dengan tailwind:
npm create waku@latest
Semua keperluan asas dilindungi kecuali mengembalikan kemas kini kepada komponen sisi klien dalam satu permintaan apabila menggunakan tindakan pelayan yang bermutasi. Pada masa ini, sebarang mutasi pelayan memerlukan penyegaran semula penghala klien dengan router.reload() dalam komponen klien yang membawa kepada permintaan kedua kepada pelayan untuk memuatkan data yang dikemas kini sebagai strim RSC.
Keperluan pilihan berikut masih dalam pembangunan:
Menyokong banyak sasaran penggunaan: Vercel, Netlify, Cloudflare, PartyKit, Deno, AWS Lambda, NodeJS
Berdasarkan kerumitan penggabungan, bersedialah untuk menghadapi masalah dengan banyak perpustakaan pihak ketiga:
https://github.com/dai-shi/waku/issues/423
Dibangunkan oleh Viktor Lázár:
Saya mencipta @lazarv/react-server kerana saya ingin menggunakan Komponen Pelayan React dan Tindakan Pelayan menggunakan Vite ❤️. Untuk kebanyakan apl kecil Next.js adalah terlalu banyak, terlalu berat dan perlahan. Saya ingin mempunyai pengalaman yang sama seperti anda menjalankan fail JavaScript mudah menggunakan node.js. Rangka kerja ini cuba untuk tidak mempunyai pendapat sebanyak mungkin. Anda boleh mencapai apa sahaja yang anda mahukan. Satu-satunya sekatan ialah ia akan menggunakan versi Reactnya sendiri. Anda tidak perlu memasang React dalam projek anda. Semuanya termasuk dalam rangka kerja. Saya harap anda akan seronok menggunakan rangka kerja ini sama seperti saya gemar menciptanya dan menggunakannya untuk membuat dokumentasi ini juga. - lazav
Mempelajari komponen pelayan tindak balas adalah mudah dengan rangka kerja ini! Satu fail dengan komponen pelayan tindak balas yang sah dan menjalankan arahan adalah semua yang anda perlukan:
./App.jsx
export default function App() { return <h1>Hello, World!</h1> }
npx @lazarv/react-server ./App.jsx
Terdapat dokumentasi yang baik tentang cara untuk memulakan dan beberapa contoh projek dalam bahagian tutorial.
Semua keperluan asas dilindungi kecuali mengembalikan kemas kini kepada komponen sisi klien dalam satu permintaan apabila menggunakan tindakan pelayan yang bermutasi.
Memandangkan masa jalan bergantung pada API NodeJS, masa jalan lain cth. (AWS Lambda@Edge, Cloudflare) pada masa ini tidak disokong.
Selain itu ciri berikut wujud:
Sasaran penggunaan: NodeJS, Vercel - Penyesuai dalam Pembangunan: Netlify, Cloudflare, sst
Menyokong di luar kotak Tailwind CSS, TanStack Query, Mantine UI, Material UI.
Disediakan oleh Tom Preston-Werner:
Redwood ialah rangka kerja aplikasi JavaScript tindanan penuh.
Bateri, bahagian belakang, React, konvensyen dan pendapat disertakan.
Masih dalam pembangunan dan hanya berfungsi dengan Node v20 dan Benang 4:
export default function App() { return <h1>Hello, World!</h1> }
Anda kemudiannya perlu mendayakan beberapa ciri percubaan:
npx @lazarv/react-server ./App.jsx
Akhir sekali, bina dan hidangkan:
npx -y create-redwood-app@canary -y ~/rsc_app cd ~/rsc_app
Sebagai sebahagian daripada arahan setup-rsc, apl RSC barebones dicipta untuk anda, menunjukkan pemaparan komponen klien di dalam komponen pelayan
Sasaran penggunaan: Vercel, Netlify, Render, GCP atau AWS melalui Coherence, AWS melalui Flightcontrol, NodeJS
Next.js | WAKU | React-server | RedwoodJS | |
---|---|---|---|---|
DEV-Environment / Bundling | Turbopack | Vite 5 | Vite 6 | Vite |
Rendering | SSR, ISR, SSG, CSR | SSR, SSG, CSR | SSR, SSG, CSR, Micro-Frontends | SSR, SSG, CSR |
Caching Layers | Yes | No | Yes | ?? |
Deployment Target | Vercel, NodeJS | Vercel, Netlify, Cloudflare, Deno, AWS Lambda, PartyKit, NodeJS | Vercel, NodeJS, sst (AWS Lambda) | Vercel, Netlify, AWS, NodeJS |
Community | Very Big | Tiny | Just Starting | Small |
Open Source Financing | Vercel | Donations | Donations | Privately Funded by a Rich Guy |
Rekap Ambilan Utama:
Cuba rangka kerja untuk mencari yang paling sesuai untuk projek anda.
Atas ialah kandungan terperinci Beyond Next.js: Meneroka Rangka Kerja Komponen Pelayan Reaksi Alternatif. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!