搜尋
首頁web前端js教程從元件呼叫 SvelteKit 表單操作(或提交表單)

Calling a SvelteKit form action (or submitting a form) from a component

處理來自 SvelteKit 元件的表單提交

從 SvelteKit 元件提交表單以由伺服器端表單操作處理比您想像的要簡單。您不需要將表單放在頁面內。它可以存在於任何元件中,並且仍然與 SvelteKit 的伺服器端功能互動。

這篇文章將引導您完成從元件提交表單、使用 +page.server.js 中的預設表單操作處理表單,以及設定 +page.svelte 來綁定表單。

專案結構
我的-sveltekit-專案/
├── src/
│ ├── 組件/
│ │ └── FormTestComponent.svelte
│ ├── 路線/
│ │ ├── +page.svelte
│ │ └── 檢定/
│ │ └── +page.server.js
├── 靜態/
├── package.json
├── svelte.config.js
├── vite.config.js
└── tsconfig.json


1. 建立FormTestComponent並新增表單

首先,讓我們建立一個包含簡單表單的 FormTestComponent:

<!-- src/lib/components/FormTestComponent.svelte -->
<script>
  export let form;
</script>

  • FormInput 元件是此處用於表單的自訂輸入欄位。
  • {form} 是 form={form} 的簡寫,它綁定從頁面傳遞到此元件的表單物件。

此時,我們已經有了一個可以在元件內使用的基本表單,但我們尚未將其連接到伺服器端表單處理。


2. 設定 +page.svelte 進行表單綁定

現在,建立一個 +page.svelte 檔案來使用 FormTestComponent 並綁定其 form 屬性。

<!-- routes/+page.svelte -->
<script>
  import FormTestComponent from "$lib/components/FormTestComponent.svelte";
  export let form; // This comes from the page’s server-side form response
</script>

<formtestcomponent></formtestcomponent>

要點:

  • export let form;:表單物件來自伺服器上的表單操作回應,並向下傳遞給 FormTestComponent。這會將表單回應資料綁定到元件中的表單道具。
  • 反應性:當表單在伺服器上提交和更新時,表單物件將在客戶端反映這些更改,使所有內容保持同步。

3. 增強FormTestComponent中的表單提交

為了有效地處理表單提交,SvelteKit 提供了 use:enhance 指令,它允許您透過漸進式增強功能來增強表單,例如在不重新載入整個頁面的情況下處理提交。

以下是如何在 FormTestComponent 中增強表單提交:

<!-- src/lib/components/FormTestComponent.svelte -->
<script>
  import { enhance } from "$app/forms";
  import FormInput from "$components/forms/FormInput.svelte";
  import { page } from "$app/stores";

  let loading = false;
  export let form;
  $: console.log(form); // Log form response for debugging
</script>

要點:

  • use:enhance:此指令增強了表單以處理提交而無需完全重新載入。它還可以輕鬆處理客戶端的錯誤或部分錶單更新。
  • on:submit|preventDefault:這會阻止瀏覽器的預設表單提交行為(頁面重新載入),從而允許 SvelteKit 處理它。
  • action="/test":表單指向 /test 路由,我們很快就會建立它。如果我們使用命名操作(例如註冊),則 URL 將類似於 /test?/signup。

4. 建立伺服器端操作

要在伺服器上處理表單,請在 /test 處使用 +page.server.js(如果您喜歡 TypeScript,則使用 +page.server.ts)建立目錄。

以下是 +page.server.js 中表單操作的範例:

// - /routes/test/+page.server.js
/** @type {import('./$types').Actions} */
export const actions = {
    default: async ({ request }) => {
        const data = await request.formData();
        const formEntries = Object.fromEntries(data.entries()); // Convert form data to an object
        console.log(formEntries); // Log form data on the server
        return {
            success: true,
            message: "Yay!!"
        };
    }
};

要點:

  • request.formData():此方法從請求中擷取提交的表單資料。
  • Object.fromEntries(data.entries()):這會將表單資料轉換為更可用的物件格式,其中每個表單欄位名稱成為鍵,其值是對應的值。

這是伺服器處理表單的地方。在本例中,我們將記錄表單資料並傳回成功訊息。在現實場景中,您可能會執行驗證並處理任何錯誤。


5.查看表單回應

提交表單後,您將看到終端機(伺服器端)和瀏覽器控制台(客戶端)中記錄的表單資料。這要歸功於元件中的console.log(form)和+page.server.js中的console.log(formEntries),它們分別記錄表單回應和表單。


結論

現在您已經在 SvelteKit 元件內成功建立了一個表單,該元件將資料提交到伺服器端表單作業。您不需要使用完整的表單頁面,並且您已經利用了 SvelteKit 的 use:enhance 來無縫處理提交,而無需重新加載頁面。

您可以透過新增自訂驗證、處理錯誤,甚至執行更複雜的操作(例如檔案上傳)來擴充此功能。


駭客快樂!

以上是從元件呼叫 SvelteKit 表單操作(或提交表單)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
Python vs. JavaScript:開發人員的比較分析Python vs. JavaScript:開發人員的比較分析May 09, 2025 am 12:22 AM

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

Python vs. JavaScript:選擇合適的工具Python vs. JavaScript:選擇合適的工具May 08, 2025 am 12:10 AM

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript:了解每個的優勢Python和JavaScript:了解每個的優勢May 06, 2025 am 12:15 AM

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

JavaScript的核心:它是在C還是C上構建的?JavaScript的核心:它是在C還是C上構建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

Python vs. JavaScript:您應該學到哪種語言?Python vs. JavaScript:您應該學到哪種語言?May 03, 2025 am 12:10 AM

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架:為現代網絡開發提供動力JavaScript框架:為現代網絡開發提供動力May 02, 2025 am 12:04 AM

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

JavaScript,C和瀏覽器之間的關係JavaScript,C和瀏覽器之間的關係May 01, 2025 am 12:06 AM

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!