首頁 >web前端 >js教程 >透過範例快速學習 useActionState (Next.js

透過範例快速學習 useActionState (Next.js

Barbara Streisand
Barbara Streisand原創
2024-11-29 04:17:11899瀏覽

Learn useActionState quickly with an example (Next.js

使用表單時,useActionState 掛鉤簡化了捕獲表單值並將其作為 FormData 傳遞到伺服器操作的過程。

useActionState 也透過使用伺服器操作傳回的值自動更新狀態變數來管理狀態。這對於渲染輸入欄位驗證錯誤特別有幫助,如下面使用 Zod 的範例所示。

form.tsx:

"use client";

import { useActionState } from "react";
import { signUp } from "../actions";

export default function SignUp() {
  const [state, action] = useActionState(signUp, {});

  return (
    <form action={action}>
      <div>
        <label htmlFor="username">Username:</label>
        <input
          type="text"
         >



<p>actions.ts:<br>
</p>

<pre class="brush:php;toolbar:false">"use server";

import { z } from "zod";

const SignUpSchema = z.object({
  username: z.string(),
  password: z
    .string()
    .min(8, { message: "Be at least 8 characters long" })
    .regex(/[a-zA-Z]/, { message: "Contain at least one letter." })
    .regex(/[0-9]/, { message: "Contain at least one number." })
    .regex(/[^a-zA-Z0-9]/, {
      message: "Contain at least one special character.",
    })
    .trim(),
});

export type SignUpActionState = {
  username?: string;
  password?: string;
  errors?: {
    username?: string[];
    password?: string[];
  };
};

export async function signUp(
  _prevState: SignUpActionState,
  form: FormData
): Promise<SignUpActionState> {
  const username = form.get("username") as string;
  const password = form.get("password") as string;

  const validatedFields = SignUpSchema.safeParse({
    username,
    password,
  });

  if (!validatedFields.success) {
    return {
      username,
      password,
      errors: validatedFields.error.flatten().fieldErrors,
    };
  }

  // process validated form inputs here

  return { username, password };
}

useActionState 也傳回一個 isPending 屬性(範例),指示伺服器操作的 Promise 是否仍在解析。

參考 isPending 暫時停用表單元素,例如提交按鈕,以防止使用者在正在進行的操作完成之前快速連續多次點擊它。

useActionState 與 useFormAction 和 useFormStatus

如果您熟悉 useFormAction 和 useFormStatus,您會發現 useActionState 非常相似。

本質上,它結合了兩個鉤子的功能,並被重新命名以反映伺服器操作不僅僅適用於表單(您還可以將 useActionState 與按鈕和其他元素一起使用。)

請記住,useFormStatus 從 Next.js 15 開始已被棄用,因此您應該繼續匯入 useActionState。

以上是透過範例快速學習 useActionState (Next.js的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn