


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
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>
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
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
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] }
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
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











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

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

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

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

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

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

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

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 ' s
