Rumah > Peranti teknologi > industri IT > Cerahkan laman astro anda dengan kwesforms dan rive

Cerahkan laman astro anda dengan kwesforms dan rive

Joseph Gordon-Levitt
Lepaskan: 2025-02-08 09:07:09
asal
891 orang telah melayarinya

Artikel ini menunjukkan cara mengintegrasikan kwesforms dan rive untuk membuat bentuk dinamik dan interaktif dalam laman web Astro. Acara tersuai mencetuskan animasi rive berdasarkan tindakan bentuk, meningkatkan pengalaman pengguna.

Brighten Up Your Astro Site with KwesForms and Rive

Proses ini melibatkan mengkonfigurasi kwesforms di Astro (menggunakan elemen skrip atau npm), mewujudkan borang dengan atribut pengesahan, dan menubuhkan Rive (melalui konfigurasi Vite Astro dan animasi yang dimuat turun atau adat). Pendengar acara mengenai elemen bentuk mencetuskan perubahan keadaan animasi rive.

Brighten Up Your Astro Site with KwesForms and Rive Contoh kod lengkap dan pratonton langsung tersedia:

? [Pautan Pratonton] (Placeholder untuk Pautan Pratonton)
  • ⚙️ [pautan repositori] (letak untuk pautan repositori)
Bermula:

Persediaan Astro boleh dilakukan melalui pemasangan CLI atau manual. Buat

(dalam

) dan index.astro (dalam src/pages). Sertakan rive-form.astro dalam src/components: rive-form index.astro

// src/pages/index.astro
---
import RiveForm from '../components/rive-form.astro';
---

<RiveForm />
Salin selepas log masuk
KWESforms Integration:

Kwesforms memudahkan pengesahan borang klien dan pelayan. Sertakan skrip kwesforms (menggunakan

untuk mengelakkan pemprosesan astro):

is:inline

Borang menggunakan CSS tailwind dan termasuk
// src/components/rive-form.astro
<🎜>
Salin selepas log masuk

data-kw-rules

persediaan rive:
// src/components/rive-form.astro
<form id="riveForm" class="kwes-form flex flex-col gap-6" action="https://kwesforms.com/api/foreign/forms/abc123" data-kw-no-reload>
  {/* Form fields with data-kw-rules attributes */}
  <button type="submit">Send Message</button>
</form>
Salin selepas log masuk

animasi rive diimport sebagai fail. Konfigurasikan Astro

:

.riv astro.config.mjs Muat turun animasi rive (mis., "Watak log masuk animasi") dan letakkan di direktori

. Inisialisasi Rive dalam
// astro.config.mjs
import { defineConfig } from 'astro/config';

export default defineConfig({
  vite: {
    assetsInclude: ['**/*.riv'],
  },
});
Salin selepas log masuk
:

public rive-form.astro

// src/components/rive-form.astro
<🎜>

<🎜>
Salin selepas log masuk

Pengendalian dan Animasi Acara: Brighten Up Your Astro Site with KwesForms and Rive

Tambah pendengar acara untuk membentuk elemen (menggunakan kwesforms dan peristiwa JavaScript standard). Fungsi A mengakses mesin negara rive:

getTrigger

Pendekatan ini menggabungkan kwesforms dan rive untuk interaksi bentuk yang menarik secara visual. Butiran lanjut dan sokongan boleh didapati di Twitter/X: @PauliesCanlon. Ketahui lebih lanjut mengenai Astro dalam buku Premium Sitepoint, "Membebaskan Kuasa Astro."
// ... inside the <script> tag in rive-form.astro
const getTrigger = (name) => {
  return r.stateMachineInputs('Login Machine').find((input) => input.name === name);
};

// Example event listener
form.addEventListener('kwHasErrors', () => {
  const trigger = getTrigger('trigFail');
  trigger.fire();
});
Salin selepas log masuk

ingat untuk menggantikan pautan letak dengan pautan sebenar ke pratonton dan repositori. Juga, pastikan semua coretan kod diintegrasikan dengan betul ke dalam fail rive-form.astro anda dan bahawa laluan ke animasi rive anda dan sumber lain adalah tepat.

Atas ialah kandungan terperinci Cerahkan laman astro anda dengan kwesforms dan rive. 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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan