Jadual Kandungan
Membina Aplikasi Redwood Anda
Struktur projek
Membuat halaman
Susun atur
Bahasa Definisi Skema Fauna (SDL)
Redwoodjs SDL dan Perkhidmatan
Kebenaran Fauna
Pembenihan FaunAdb
Sel
Penyebaran Vercel
Rumah hujung hadapan web tutorial css Menggunakan tapak Jamstack tanpa pelayan dengan Redwoodjs, Fauna, dan Vercel

Menggunakan tapak Jamstack tanpa pelayan dengan Redwoodjs, Fauna, dan Vercel

Mar 31, 2025 am 09:33 AM

Menggunakan tapak Jamstack tanpa pelayan dengan Redwoodjs, Fauna, dan Vercel

Tutorial ini membimbing anda melalui membina aplikasi serverless jamStack menggunakan Redwoodjs, FaunAdb, dan Vercel. Kami akan memanfaatkan API GraphQL Fauna sebagai backend untuk frontwood redwoodjs, yang digunakan dengan mudah dengan penempatan satu klik Vercel.

Mengharapkan menyelam yang mendalam ke dalam konsep Jamstack dan tanpa pelayan, bersama -sama dengan pengalaman praktikal menggunakan timbunan teknologi yang kuat ini.

Membina Aplikasi Redwood Anda

Redwoodjs adalah rangka kerja untuk aplikasi tanpa pelayan, menggabungkan React (frontend), graphql (data), dan prisma (pertanyaan pangkalan data). Walaupun rangka kerja frontend lain wujud (seperti Bison), Redwoodjs menawarkan ekosistem yang matang dan mantap.

Kami akan memintas templat starter dan membina dari projek redwood asas, memeriksa setiap komponen. Pertama, pasang benang dan jalankan arahan ini:

 Benang Buat Redwood- App ./CSStricks
CD CSSTRICKS
Benang RW Dev
Salin selepas log masuk

Frontend anda berjalan di localhost:8910 , dan backend di localhost:8911 (dengan taman permainan GraphIQL). Halaman pendaratan Redwood harus muncul di localhost:8910 . (Nota: Redwoodjs versi 0.21.0 digunakan dalam contoh ini; rujuk dokumentasi untuk versi terkini dan kesediaan pengeluaran.)

Struktur projek

Redwoodjs mengutamakan konvensyen melalui konfigurasi, menyediakan susun atur projek berstruktur:

 <code>├── api │ ├── prisma │ │ ├── schema.prisma │ │ └── seeds.js │ └── src │ ├── functions │ │ └── graphql.js │ ├── graphql │ ├── lib │ │ └── db.js │ └── services └── web ├── public │ ├── favicon.png │ ├── README.md │ └── robots.txt └── src ├── components ├── layouts ├── pages │ ├── FatalErrorPage │ │ └── FatalErrorPage.js │ └── NotFoundPage │ └── NotFoundPage.js ├── index.css ├── index.html ├── index.js └── Routes.js</code>
Salin selepas log masuk

Projek ini dibahagikan kepada direktori web (Frontend) dan api (backend), yang diuruskan oleh ruang kerja benang. Kami akan menggantikan Prisma dengan FaunAdb, mengeluarkan direktori prisma dan kandungan db.js (tetapi menyimpan fail db.js ).

index.html

Fail index.html mengandungi node dom root (<div id="redwood-app"></div> ) di mana aplikasi React diberikan. Redwoodjs, sementara berorientasikan jamStack, kini tidak melakukan pra-penanaman seperti Next.js atau Gatsby.

index.js

index.js menjadikan komponen aplikasi utama ke dalam elemen dom redwood-app menggunakan ReactDOM.render() . Ia menggunakan RedwoodProvider untuk pengurusan konteks dan FatalErrorBoundary untuk pengendalian ralat.

Routes.js

Routes.js mentakrifkan penghalaan aplikasi menggunakan router Redwood.

Membuat halaman

Mari buat halaman menggunakan Redwood CLI:

 benang rw g halaman rumah /
Benang RW G Page Mengenai
Salin selepas log masuk

Ini menjana fail yang diperlukan untuk HomePage dan AboutPage . Memudahkan halaman ini dengan mengeluarkan pautan navigasi yang tidak perlu.

Susun atur

Buat susun atur yang boleh diguna semula untuk navigasi:

 blog susun atur benang rw g
Salin selepas log masuk

Ubah suai BlogLayout.js untuk memasukkan pautan navigasi ke HomePage dan AboutPage penggunaan<link> komponen. Import BlogLayout ke HomePage dan AboutPage untuk menggabungkan navigasi.

Bahasa Definisi Skema Fauna (SDL)

Buat sdl.gql dengan skema berikut:

 Taipkan pos {
  Tajuk: String!
  Badan: String!
}

Taipkan pertanyaan {
  Catatan: [pos]
}
Salin selepas log masuk

Muat naik skema ini ke contoh FaunAdb anda. Perhatikan bahawa FaunAdb mencipta jenis perantara; Kami akan mengambil kira ini dalam skema RedwoodJS kami.

Redwoodjs SDL dan Perkhidmatan

Buat api/src/graphql/posts.sdl.js mencerminkan skema fauna, termasuk PostPage jenis perantara. Buat api/src/services/posts/posts.js Untuk menanyakan API GraphQL Fauna menggunakan graphql-request . Ingatlah untuk memasang graphql-request dan graphql dalam direktori api .

Kebenaran Fauna

Konfigurasi api/src/lib/db.js untuk memasukkan rahsia FaunADB anda dalam tajuk kebenaran menggunakan pembolehubah persekitaran.

Pembenihan FaunAdb

Gunakan shell fauna untuk menambah beberapa siaran sampel ke pangkalan data anda.

Sel

Menjana BlogPostsCell untuk mengambil dan memaparkan siaran:

 Benang RW Menjana Blogpost Sel
Salin selepas log masuk

Ubah suai BlogPostsCell.js untuk menanyakan posts dan menjadikan tajuk dan badan setiap jawatan. Import BlogPostsCell ke HomePage .

Penyebaran Vercel

Sambungkan projek anda ke Vercel. Ubah suai netlify.toml (jika ada) untuk menetapkan apiProxyPath ke "/api". Tambah rahsia FaunAdb anda kepada pembolehubah persekitaran Vercel. Perintah membina Vercel berfungsi dengan lancar dengan redwoodjs.

Permohonan anda kini selesai! Demo langsung dan repositori GitHub tersedia (pautan akan dimasukkan di sini).

Atas ialah kandungan terperinci Menggunakan tapak Jamstack tanpa pelayan dengan Redwoodjs, Fauna, dan Vercel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1677
14
Tutorial PHP
1280
29
Tutorial C#
1257
24
Perbandingan pembekal bentuk statik Perbandingan pembekal bentuk statik Apr 16, 2025 am 11:20 AM

Mari kita cuba menyusun istilah di sini: "Penyedia Borang Statik." Anda membawa html anda

Berita Platform Mingguan: Atribut Memuat HTML, Spesifikasi ARIA Utama, dan Bergerak Dari IFRAME ke Shadow Dom Berita Platform Mingguan: Atribut Memuat HTML, Spesifikasi ARIA Utama, dan Bergerak Dari IFRAME ke Shadow Dom Apr 17, 2025 am 10:55 AM

Pada minggu ini, berita platform, Chrome memperkenalkan atribut baru untuk memuatkan, spesifikasi aksesibiliti untuk pemaju web, dan gerakan BBC

Bukti konsep untuk menjadikan sass lebih cepat Bukti konsep untuk menjadikan sass lebih cepat Apr 16, 2025 am 10:38 AM

Pada permulaan projek baru, kompilasi SASS berlaku dalam sekejap mata. Ini terasa hebat, terutamanya apabila ia dipasangkan dengan BrowserSync, yang dimuat semula

Beberapa tangan dengan elemen dialog HTML Beberapa tangan dengan elemen dialog HTML Apr 16, 2025 am 11:33 AM

Ini saya melihat elemen HTML untuk kali pertama. Saya telah menyedarinya untuk seketika, tetapi Haven &#039; t mengambilnya untuk putaran lagi. Ia mempunyai cukup keren dan

Kertas kerja Kertas kerja Apr 16, 2025 am 11:24 AM

Beli atau Membina adalah perdebatan klasik dalam teknologi. Membina barang sendiri mungkin berasa lebih murah kerana tidak ada item baris pada bil kad kredit anda, tetapi

Di manakah 'Langgan Podcast' pautan ke? Di manakah 'Langgan Podcast' pautan ke? Apr 16, 2025 pm 12:04 PM

Untuk sementara waktu, iTunes adalah anjing besar dalam podcasting, jadi jika anda mengaitkan "Langgan Podcast" untuk suka:

Cache Cache Pantas Cache Cache Pantas Apr 18, 2025 am 11:23 AM

Anda pasti pasti menetapkan tajuk cache yang jauh pada aset anda seperti CSS dan JavaScript (dan imej dan fon dan apa sahaja yang lain). Yang memberitahu penyemak imbas

Berita Platform Mingguan: Bookmarket Jarak Teks, Menunggu Tahap Teratas, Penunjuk Memuatkan AMP Baru Berita Platform Mingguan: Bookmarket Jarak Teks, Menunggu Tahap Teratas, Penunjuk Memuatkan AMP Baru Apr 17, 2025 am 11:26 AM

Pada minggu ini, roundup, sebuah bookmarklet yang berguna untuk memeriksa tipografi, menggunakan menunggu untuk mengamuk dengan cara modul JavaScript mengimport satu sama lain, ditambah Facebook &#039; s

See all articles