{"id":81603,"date":"2024-10-27T03:11:54","date_gmt":"2024-10-26T23:41:54","guid":{"rendered":"https:\/\/nabfollower.com\/blog\/why-astros-new-actions-are-the-upgrade-react-19-devs-have-been-waiting-for-c25\/"},"modified":"2024-10-27T03:11:54","modified_gmt":"2024-10-26T23:41:54","slug":"why-astros-new-actions-are-the-upgrade-react-19-devs-have-been-waiting-for-c25","status":"publish","type":"post","link":"https:\/\/nabfollower.com\/blog\/why-astros-new-actions-are-the-upgrade-react-19-devs-have-been-waiting-for-c25\/","title":{"rendered":"\u0686\u0631\u0627 \u0627\u06a9\u0634\u0646\u200c\u0647\u0627\u06cc \u062c\u062f\u06cc\u062f Astro \u0647\u0645\u0627\u0646 \u0686\u06cc\u0632\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 React 19 \u0645\u0646\u062a\u0638\u0631 \u0622\u0646 \u0628\u0648\u062f\u0646\u062f\u061f"},"content":{"rendered":"<p>Summarize this content to 400 words in Persian Lang<br \/>\n            React 19 \u0686\u0646\u062f\u06cc\u0646 \u0648\u06cc\u0698\u06af\u06cc \u0647\u06cc\u062c\u0627\u0646 \u0627\u0646\u06af\u06cc\u0632 \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u06a9\u0631\u062f\u060c \u0628\u0647 \u0648\u06cc\u0698\u0647 \u062f\u0631 \u062a\u0639\u0627\u0645\u0644 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0628\u0627 Server Actions. \u0647\u062f\u0641 \u0627\u06cc\u0646 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u062a\u0645\u0627\u0633\u200c\u0647\u0627\u06cc \u0633\u0631\u0648\u0631 \u0627\u0633\u062a \u0648 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f \u062a\u0627 \u0628\u062f\u0648\u0646 \u0646\u06cc\u0627\u0632 \u0628\u0647 API \u06af\u0633\u062a\u0631\u062f\u0647\u200c\u062a\u0631\u060c \u0628\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627 \u0631\u0633\u06cc\u062f\u06af\u06cc \u06a9\u0646\u0646\u062f. \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0622\u0646\u0647\u0627 \u0686\u0627\u0644\u0634 \u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u062f\u0627\u0634\u062a\u0646\u062f\u060c \u0628\u0647 \u0648\u06cc\u0698\u0647 \u062f\u0631 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0641\u0631\u0645\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627 \u0648 \u0627\u0634\u06a9\u0627\u0644 \u0632\u062f\u0627\u06cc\u06cc. \u0627\u06a9\u0634\u0646\u200c\u0647\u0627\u06cc \u062c\u062f\u06cc\u062f Astro \u06a9\u0647 \u0628\u0627 Astro 4.15 \u0645\u0639\u0631\u0641\u06cc \u0634\u062f\u0647\u200c\u0627\u0646\u062f\u060c \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u0627\u0645\u06cc\u062f\u0648\u0627\u0631\u06a9\u0646\u0646\u062f\u0647\u200c\u0627\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a\u200c\u0647\u0627\u06cc \u0645\u0634\u0627\u0647\u062f\u0647\u200c\u0634\u062f\u0647 \u062f\u0631 \u0627\u06a9\u0634\u0646\u200c\u0647\u0627\u06cc \u0633\u0631\u0648\u0631 React 19 \u0631\u0627 \u0628\u0631\u0637\u0631\u0641 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<p>  \u0645\u0634\u06a9\u0644\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 React 19 Server Actions<\/p>\n<p>\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0631\u0648\u0631 React \u062a\u0639\u0627\u0645\u0644\u0627\u062a \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0631\u0627 \u0633\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0627\u0645\u0627 \u0628\u0627 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a \u0647\u0627\u06cc \u062e\u0627\u0635\u06cc \u0647\u0645\u0631\u0627\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0631 \u062a\u062c\u0631\u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u062a\u0623\u062b\u06cc\u0631 \u0628\u06af\u0630\u0627\u0631\u062f:<\/p>\n<p>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0645 \u067e\u06cc\u0686\u06cc\u062f\u0647: \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0631\u0648\u0631 \u062f\u0631 React \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0633\u062a\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0645 \u062f\u0627\u0631\u062f FormData \u0627\u0634\u06cc\u0627\u0621 \u0627\u06cc\u0646 \u0627\u0633\u062a\u062e\u0631\u0627\u062c \u062f\u0633\u062a\u06cc \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0628\u0627\u06cc\u062f \u0645\u0642\u0627\u062f\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u0627\u0646\u0648\u0627\u0639 \u062f\u0644\u062e\u0648\u0627\u0647 \u0631\u06cc\u062e\u062a\u0647 \u06cc\u0627 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0646\u0646\u062f \u06a9\u0647 \u0627\u063a\u0644\u0628 \u0645\u0646\u062c\u0631 \u0628\u0647 \u06a9\u062f \u062f\u06cc\u06af \u0628\u062e\u0627\u0631 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>   const formData = new FormData(event.target);<br \/>\n   const name = formData.get(&#8220;name&#8221;);<br \/>\n   const age = Number(formData.get(&#8220;age&#8221;)); \/\/ Converts to a number<br \/>\n   const isActive = formData.get(&#8220;isActive&#8221;) === &#8220;on&#8221;; \/\/ Handles checkbox values<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627\u06cc \u0645\u062d\u062f\u0648\u062f: \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0631\u0648\u0631 \u062f\u0631 React 19 \u0641\u0627\u0642\u062f \u0645\u06a9\u0627\u0646\u06cc\u0632\u0645 \u0647\u0627\u06cc \u062f\u0627\u062e\u0644\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627 \u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0627\u0633\u062a. \u062e\u0637\u0627\u0647\u0627 \u062f\u0631 \u067e\u0627\u0633\u062e \u0633\u0631\u0648\u0631 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u0628\u0647 \u06cc\u06a9 \u06a9\u062f \u0648\u0636\u0639\u06cc\u062a 200 OK \u0645\u06cc\u200c\u0631\u0633\u0646\u062f\u060c \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627\u06cc \u0633\u0645\u062a \u0633\u0631\u0648\u06cc\u0633 \u06af\u06cc\u0631\u0646\u062f\u0647 \u0631\u0627 \u067e\u06cc\u0686\u06cc\u062f\u0647 \u06a9\u0646\u062f \u0648 \u062a\u0634\u062e\u06cc\u0635 \u0645\u0648\u0641\u0642\u06cc\u062a \u0627\u0632 \u0634\u06a9\u0633\u062a \u0631\u0627 \u0686\u0627\u0644\u0634\u200c\u0628\u0631\u0627\u0646\u06af\u06cc\u0632 \u06a9\u0646\u062f.<br \/>\n\u0646\u0627\u0645 \u0647\u0627\u06cc \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646 \u0645\u0628\u0647\u0645: \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0631\u0648\u0631 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0633\u0631\u0648\u0631 \u0633\u0646\u062a\u06cc \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a\u0647 \u0646\u0645\u06cc \u0634\u0648\u0646\u062f\u060c \u0628\u0644\u06a9\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0648\u0627\u062d\u062f\u0647\u0627\u06cc \u0639\u0645\u0644\u06a9\u0631\u062f \u0645\u0627\u0646\u0646\u062f \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a\u0647 \u0645\u06cc \u0634\u0648\u0646\u062f. \u0627\u06cc\u0646 \u0631\u0648\u06cc\u06a9\u0631\u062f \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0628\u0647 \u0646\u0627\u0645\u200c\u0647\u0627\u06cc \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0647\u0634\u200c\u0634\u062f\u0647 \u0645\u0646\u062c\u0631 \u0634\u0648\u062f\u060c \u0648 \u0627\u0634\u06a9\u0627\u0644\u200c\u0632\u062f\u0627\u06cc\u06cc \u0631\u0627 \u0686\u0627\u0644\u0634\u200c\u0628\u0631\u0627\u0646\u06af\u06cc\u0632 \u0645\u06cc\u200c\u06a9\u0646\u062f\u060c \u0632\u06cc\u0631\u0627 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0631\u0627\u06cc \u0646\u06af\u0627\u0634\u062a \u0627\u06cc\u0646 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0647\u0634\u200c\u0634\u062f\u0647 \u0628\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f \u0648\u0627\u0642\u0639\u06cc \u062a\u0644\u0627\u0634 \u06a9\u0646\u0646\u062f.<\/p>\n<p>  Astro&#39;s Actions: A Game-Changer<\/p>\n<p>Astro&#39;s Actions \u0627\u06cc\u0646 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a \u0647\u0627 \u0631\u0627 \u0628\u0631\u0637\u0631\u0641 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0631\u0648\u06cc\u06a9\u0631\u062f\u06cc \u0628\u0647\u0628\u0648\u062f \u06cc\u0627\u0641\u062a\u0647 \u0628\u0631\u0627\u06cc \u062a\u0639\u0627\u0645\u0644 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f. \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0646\u062d\u0648\u0647 \u0627\u0631\u0627\u0626\u0647 \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627\u06cc Astro \u0627\u0632 \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627\u06cc \u0633\u0631\u0648\u0631 React 19 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f:<\/p>\n<p>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0645 \u0633\u0627\u062f\u0647 \u0634\u062f\u0647 \u0628\u0627 \u0627\u06cc\u0645\u0646\u06cc \u0646\u0648\u0639: Astro&#39;s Actions \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f zod \u0628\u0631\u0627\u06cc \u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u0637\u0631\u062d\u0648\u0627\u0631\u0647\u060c \u0627\u0645\u06a9\u0627\u0646 \u062a\u062c\u0632\u06cc\u0647 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0648 \u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0645 \u0627\u06cc\u0645\u0646 \u0631\u0627 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f. \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u062f\u06cc\u06af \u0628\u062e\u0627\u0631 \u0631\u0627 \u06a9\u0627\u0647\u0634 \u0645\u06cc \u062f\u0647\u062f \u0648 \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0648\u0631\u0648\u062f\u06cc \u0647\u0627\u06cc \u0641\u0631\u0645 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0628\u0647 \u0627\u0646\u0648\u0627\u0639 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0635\u062d\u06cc\u062d \u062a\u0628\u062f\u06cc\u0644 \u0645\u06cc \u0634\u0648\u0646\u062f.<\/p>\n<p>   import { defineAction } from &#8216;astro:actions&#8217;;<br \/>\n   import { z } from &#8216;astro:schema&#8217;;<\/p>\n<p>   export const server = {<br \/>\n     getGreeting: defineAction({<br \/>\n       input: z.object({<br \/>\n         name: z.string(),<br \/>\n       }),<br \/>\n       accept: &#8216;form&#8217;, \/\/ Specifies form data handling<br \/>\n       handler: async ({ input }) =&gt; {<br \/>\n         \/\/ this is a typesafe object now !<br \/>\n         const { name } = input;<br \/>\n         return `Hello, ${name}!`;<br \/>\n       }<br \/>\n     })<br \/>\n   };<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0628\u0647\u0628\u0648\u062f \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627: Astro&#39;s Actions \u0645\u0639\u0631\u0641\u06cc \u0645\u06cc \u06a9\u0646\u062f ActionError\u060c \u06a9\u062f\u0647\u0627\u06cc \u0648\u0636\u0639\u06cc\u062a HTTP \u0648 \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u062f\u0642\u06cc\u0642 \u062a\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627 \u0641\u0639\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0634\u0628\u06cc\u0647 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0633\u0631\u0648\u0631 \u0633\u0646\u062a\u06cc \u0627\u0633\u062a. \u0627\u06cc\u0646 \u0642\u0627\u0628\u0644\u06cc\u062a \u06a9\u0646\u062a\u0631\u0644 \u062e\u0637\u0627\u06cc \u06af\u0631\u0627\u0646\u0648\u0644 \u0648 \u0627\u0631\u062a\u0628\u0627\u0637 \u0645\u0634\u062a\u0631\u06cc \u0648 \u0633\u0631\u0648\u0631 \u0648\u0627\u0636\u062d \u062a\u0631 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>   import { defineAction, ActionError } from &#8220;astro:actions&#8221;;<br \/>\n   import { z } from &#8220;astro:schema&#8221;;<\/p>\n<p>   export const server = {<br \/>\n     likePost: defineAction({<br \/>\n       input: z.object({ postId: z.string() }),<br \/>\n       handler: async (input, ctx) =&gt; {<br \/>\n         if (!ctx.cookies.has(&#8216;user-session&#8217;)) {<br \/>\n           throw new ActionError({<br \/>\n             code: &#8220;UNAUTHORIZED&#8221;,<br \/>\n             message: &#8220;User must be logged in.&#8221;,<br \/>\n           });<br \/>\n         }<br \/>\n         \/\/ Process request if authorized<br \/>\n       },<br \/>\n     }),<br \/>\n   };<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0646\u0627\u0645 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0642\u0627\u0628\u0644 \u062e\u0648\u0627\u0646\u062f\u0646: \u0628\u0631\u062e\u0644\u0627\u0641 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0647\u0634\u200c\u0634\u062f\u0647 React\u060c Astro&#39;s Actions \u0627\u0632 \u0646\u0627\u0645\u200c\u0647\u0627\u06cc \u062a\u0639\u0631\u06cc\u0641\u200c\u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0628\u0631\u0627\u06cc \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0627\u0634\u06a9\u0627\u0644\u200c\u0632\u062f\u0627\u06cc\u06cc \u0648 \u0631\u062f\u06cc\u0627\u0628\u06cc \u062a\u0645\u0627\u0633\u200c\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u0642\u0627\u0628\u0644\u200c\u062a\u0648\u062c\u0647\u06cc \u0622\u0633\u0627\u0646\u200c\u062a\u0631 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<p>\u0627\u0641\u0632\u0627\u06cc\u0634 \u062a\u062f\u0631\u06cc\u062c\u06cc \u0648 \u0645\u0646\u0627\u0628\u0639 \u0627\u0636\u0627\u0641\u06cc: Astro \u0628\u0631 \u0628\u0647\u0628\u0648\u062f \u067e\u06cc\u0634\u0631\u0648\u0646\u062f\u0647 \u062a\u0645\u0631\u06a9\u0632 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0628\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062d\u062a\u06cc \u0628\u0627 \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u0628\u0648\u062f\u0646 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u06a9\u0627\u0631 \u06a9\u0646\u062f. \u0627\u06cc\u0646 \u0628\u0627 \u062a\u0639\u0647\u062f Astro \u0628\u0647 \u06cc\u06a9 \u0648\u0628 \u0633\u0628\u06a9 \u062a\u0631 \u0648 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u062a\u0631 \u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0627\u0631\u062f \u0648 \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627\u06cc \u0627\u0635\u0644\u06cc \u0628\u062f\u0648\u0646 \u0627\u062a\u06a9\u0627 \u0628\u0647 \u0627\u062c\u0631\u0627\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u062f\u0633\u062a \u0646\u062e\u0648\u0631\u062f\u0647 \u0628\u0627\u0642\u06cc \u0645\u06cc \u0645\u0627\u0646\u0646\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f Astro&#39;s Actions\u060c \u0627\u0633\u0646\u0627\u062f Astro Actions \u0631\u0627 \u06a9\u0627\u0648\u0634 \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0647 \u0628\u0647 \u062c\u0632\u0626\u06cc\u0627\u062a \u0627\u062f\u063a\u0627\u0645 Actions \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u0645\u06cc \u067e\u0631\u062f\u0627\u0632\u062f.<\/p>\n<div data-article-id=\"1886253\" id=\"article-body\">\n<p>React 19 \u0686\u0646\u062f\u06cc\u0646 \u0648\u06cc\u0698\u06af\u06cc \u0647\u06cc\u062c\u0627\u0646 \u0627\u0646\u06af\u06cc\u0632 \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u06a9\u0631\u062f\u060c \u0628\u0647 \u0648\u06cc\u0698\u0647 \u062f\u0631 \u062a\u0639\u0627\u0645\u0644 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0628\u0627 Server Actions. \u0647\u062f\u0641 \u0627\u06cc\u0646 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u062a\u0645\u0627\u0633\u200c\u0647\u0627\u06cc \u0633\u0631\u0648\u0631 \u0627\u0633\u062a \u0648 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f \u062a\u0627 \u0628\u062f\u0648\u0646 \u0646\u06cc\u0627\u0632 \u0628\u0647 API \u06af\u0633\u062a\u0631\u062f\u0647\u200c\u062a\u0631\u060c \u0628\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627 \u0631\u0633\u06cc\u062f\u06af\u06cc \u06a9\u0646\u0646\u062f. \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0622\u0646\u0647\u0627 \u0686\u0627\u0644\u0634 \u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u062f\u0627\u0634\u062a\u0646\u062f\u060c \u0628\u0647 \u0648\u06cc\u0698\u0647 \u062f\u0631 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0641\u0631\u0645\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627 \u0648 \u0627\u0634\u06a9\u0627\u0644 \u0632\u062f\u0627\u06cc\u06cc. \u0627\u06a9\u0634\u0646\u200c\u0647\u0627\u06cc \u062c\u062f\u06cc\u062f Astro \u06a9\u0647 \u0628\u0627 Astro 4.15 \u0645\u0639\u0631\u0641\u06cc \u0634\u062f\u0647\u200c\u0627\u0646\u062f\u060c \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u0627\u0645\u06cc\u062f\u0648\u0627\u0631\u06a9\u0646\u0646\u062f\u0647\u200c\u0627\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a\u200c\u0647\u0627\u06cc \u0645\u0634\u0627\u0647\u062f\u0647\u200c\u0634\u062f\u0647 \u062f\u0631 \u0627\u06a9\u0634\u0646\u200c\u0647\u0627\u06cc \u0633\u0631\u0648\u0631 React 19 \u0631\u0627 \u0628\u0631\u0637\u0631\u0641 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_84 counter-hierarchy ez-toc-counter-rtl ez-toc-grey ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\">\n<p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0641\u0647\u0631\u0633\u062a \u0645\u0637\u0627\u0644\u0628<\/p>\n<span class=\"ez-toc-title-toggle\"><a href=\"#\" class=\"ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle\" aria-label=\"Toggle Table of Content\"><span class=\"ez-toc-js-icon-con\"><span class=\"\"><span class=\"eztoc-hide\" style=\"display:none;\">Toggle<\/span><span class=\"ez-toc-icon-toggle-span\"><svg style=\"fill: #999;color:#999\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"list-377408\" width=\"20px\" height=\"20px\" viewBox=\"0 0 24 24\" fill=\"none\"><path d=\"M6 6H4v2h2V6zm14 0H8v2h12V6zM4 11h2v2H4v-2zm16 0H8v2h12v-2zM4 16h2v2H4v-2zm16 0H8v2h12v-2z\" fill=\"currentColor\"><\/path><\/svg><svg style=\"fill: #999;color:#999\" class=\"arrow-unsorted-368013\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"10px\" height=\"10px\" viewBox=\"0 0 24 24\" version=\"1.2\" baseProfile=\"tiny\"><path d=\"M18.2 9.3l-6.2-6.3-6.2 6.3c-.2.2-.3.4-.3.7s.1.5.3.7c.2.2.4.3.7.3h11c.3 0 .5-.1.7-.3.2-.2.3-.5.3-.7s-.1-.5-.3-.7zM5.8 14.7l6.2 6.3 6.2-6.3c.2-.2.3-.5.3-.7s-.1-.5-.3-.7c-.2-.2-.4-.3-.7-.3h-11c-.3 0-.5.1-.7.3-.2.2-.3.5-.3.7s.1.5.3.7z\"\/><\/svg><\/span><\/span><\/span><\/a><\/span><\/div>\n<nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/nabfollower.com\/blog\/why-astros-new-actions-are-the-upgrade-react-19-devs-have-been-waiting-for-c25\/#%D9%85%D8%B4%DA%A9%D9%84%D8%A7%D8%AA_%D9%85%D8%B1%D8%A8%D9%88%D8%B7_%D8%A8%D9%87_React_19_Server_Actions\" >\u0645\u0634\u06a9\u0644\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 React 19 Server Actions<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/nabfollower.com\/blog\/why-astros-new-actions-are-the-upgrade-react-19-devs-have-been-waiting-for-c25\/#Astros_Actions_A_Game-Changer\" >Astro&#39;s Actions: A Game-Changer<\/a><\/li><\/ul><\/nav><\/div>\n<h2><span class=\"ez-toc-section\" id=\"%D9%85%D8%B4%DA%A9%D9%84%D8%A7%D8%AA_%D9%85%D8%B1%D8%A8%D9%88%D8%B7_%D8%A8%D9%87_React_19_Server_Actions\"><\/span>\n<p>  \u0645\u0634\u06a9\u0644\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 React 19 Server Actions<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0631\u0648\u0631 React \u062a\u0639\u0627\u0645\u0644\u0627\u062a \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0631\u0627 \u0633\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0627\u0645\u0627 \u0628\u0627 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a \u0647\u0627\u06cc \u062e\u0627\u0635\u06cc \u0647\u0645\u0631\u0627\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0631 \u062a\u062c\u0631\u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u062a\u0623\u062b\u06cc\u0631 \u0628\u06af\u0630\u0627\u0631\u062f:<\/p>\n<ol>\n<li>\n<strong>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0645 \u067e\u06cc\u0686\u06cc\u062f\u0647<\/strong>: \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0631\u0648\u0631 \u062f\u0631 React \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0633\u062a\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0645 \u062f\u0627\u0631\u062f <code>FormData<\/code> \u0627\u0634\u06cc\u0627\u0621 \u0627\u06cc\u0646 \u0627\u0633\u062a\u062e\u0631\u0627\u062c \u062f\u0633\u062a\u06cc \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0628\u0627\u06cc\u062f \u0645\u0642\u0627\u062f\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u0627\u0646\u0648\u0627\u0639 \u062f\u0644\u062e\u0648\u0627\u0647 \u0631\u06cc\u062e\u062a\u0647 \u06cc\u0627 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0646\u0646\u062f \u06a9\u0647 \u0627\u063a\u0644\u0628 \u0645\u0646\u062c\u0631 \u0628\u0647 \u06a9\u062f \u062f\u06cc\u06af \u0628\u062e\u0627\u0631 \u0645\u06cc \u0634\u0648\u062f.\n<\/li>\n<\/ol>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code>   <span class=\"kd\">const<\/span> <span class=\"nx\">formData<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">FormData<\/span><span class=\"p\">(<\/span><span class=\"nx\">event<\/span><span class=\"p\">.<\/span><span class=\"nx\">target<\/span><span class=\"p\">);<\/span>\n   <span class=\"kd\">const<\/span> <span class=\"nx\">name<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">formData<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">name<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\n   <span class=\"kd\">const<\/span> <span class=\"nx\">age<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">Number<\/span><span class=\"p\">(<\/span><span class=\"nx\">formData<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">age<\/span><span class=\"dl\">\"<\/span><span class=\"p\">));<\/span> <span class=\"c1\">\/\/ Converts to a number<\/span>\n   <span class=\"kd\">const<\/span> <span class=\"nx\">isActive<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">formData<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">isActive<\/span><span class=\"dl\">\"<\/span><span class=\"p\">)<\/span> <span class=\"o\">===<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">on<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span> <span class=\"c1\">\/\/ Handles checkbox values<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<ol>\n<li>\n<p><strong>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627\u06cc \u0645\u062d\u062f\u0648\u062f<\/strong>: \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0631\u0648\u0631 \u062f\u0631 React 19 \u0641\u0627\u0642\u062f \u0645\u06a9\u0627\u0646\u06cc\u0632\u0645 \u0647\u0627\u06cc \u062f\u0627\u062e\u0644\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627 \u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0627\u0633\u062a. \u062e\u0637\u0627\u0647\u0627 \u062f\u0631 \u067e\u0627\u0633\u062e \u0633\u0631\u0648\u0631 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u0628\u0647 \u06cc\u06a9 \u06a9\u062f \u0648\u0636\u0639\u06cc\u062a 200 OK \u0645\u06cc\u200c\u0631\u0633\u0646\u062f\u060c \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627\u06cc \u0633\u0645\u062a \u0633\u0631\u0648\u06cc\u0633 \u06af\u06cc\u0631\u0646\u062f\u0647 \u0631\u0627 \u067e\u06cc\u0686\u06cc\u062f\u0647 \u06a9\u0646\u062f \u0648 \u062a\u0634\u062e\u06cc\u0635 \u0645\u0648\u0641\u0642\u06cc\u062a \u0627\u0632 \u0634\u06a9\u0633\u062a \u0631\u0627 \u0686\u0627\u0644\u0634\u200c\u0628\u0631\u0627\u0646\u06af\u06cc\u0632 \u06a9\u0646\u062f.<\/p>\n<\/li>\n<li>\n<p><strong>\u0646\u0627\u0645 \u0647\u0627\u06cc \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646 \u0645\u0628\u0647\u0645<\/strong>: \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0631\u0648\u0631 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0633\u0631\u0648\u0631 \u0633\u0646\u062a\u06cc \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a\u0647 \u0646\u0645\u06cc \u0634\u0648\u0646\u062f\u060c \u0628\u0644\u06a9\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0648\u0627\u062d\u062f\u0647\u0627\u06cc \u0639\u0645\u0644\u06a9\u0631\u062f \u0645\u0627\u0646\u0646\u062f \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a\u0647 \u0645\u06cc \u0634\u0648\u0646\u062f. \u0627\u06cc\u0646 \u0631\u0648\u06cc\u06a9\u0631\u062f \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0628\u0647 \u0646\u0627\u0645\u200c\u0647\u0627\u06cc \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0647\u0634\u200c\u0634\u062f\u0647 \u0645\u0646\u062c\u0631 \u0634\u0648\u062f\u060c \u0648 \u0627\u0634\u06a9\u0627\u0644\u200c\u0632\u062f\u0627\u06cc\u06cc \u0631\u0627 \u0686\u0627\u0644\u0634\u200c\u0628\u0631\u0627\u0646\u06af\u06cc\u0632 \u0645\u06cc\u200c\u06a9\u0646\u062f\u060c \u0632\u06cc\u0631\u0627 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0631\u0627\u06cc \u0646\u06af\u0627\u0634\u062a \u0627\u06cc\u0646 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0647\u0634\u200c\u0634\u062f\u0647 \u0628\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f \u0648\u0627\u0642\u0639\u06cc \u062a\u0644\u0627\u0634 \u06a9\u0646\u0646\u062f.<\/p>\n<\/li>\n<\/ol>\n<p><\/p>\n<h2><span class=\"ez-toc-section\" id=\"Astros_Actions_A_Game-Changer\"><\/span>\n<p>  Astro&#39;s Actions: A Game-Changer<br \/>\n<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>Astro&#39;s Actions \u0627\u06cc\u0646 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a \u0647\u0627 \u0631\u0627 \u0628\u0631\u0637\u0631\u0641 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0631\u0648\u06cc\u06a9\u0631\u062f\u06cc \u0628\u0647\u0628\u0648\u062f \u06cc\u0627\u0641\u062a\u0647 \u0628\u0631\u0627\u06cc \u062a\u0639\u0627\u0645\u0644 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f. \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0646\u062d\u0648\u0647 \u0627\u0631\u0627\u0626\u0647 \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627\u06cc Astro \u0627\u0632 \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627\u06cc \u0633\u0631\u0648\u0631 React 19 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f:<\/p>\n<ol>\n<li>\n<strong>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0645 \u0633\u0627\u062f\u0647 \u0634\u062f\u0647 \u0628\u0627 \u0627\u06cc\u0645\u0646\u06cc \u0646\u0648\u0639<\/strong>: Astro&#39;s Actions \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <code>zod<\/code> \u0628\u0631\u0627\u06cc \u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u0637\u0631\u062d\u0648\u0627\u0631\u0647\u060c \u0627\u0645\u06a9\u0627\u0646 \u062a\u062c\u0632\u06cc\u0647 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0648 \u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0645 \u0627\u06cc\u0645\u0646 \u0631\u0627 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f. \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u062f\u06cc\u06af \u0628\u062e\u0627\u0631 \u0631\u0627 \u06a9\u0627\u0647\u0634 \u0645\u06cc \u062f\u0647\u062f \u0648 \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0648\u0631\u0648\u062f\u06cc \u0647\u0627\u06cc \u0641\u0631\u0645 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0628\u0647 \u0627\u0646\u0648\u0627\u0639 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0635\u062d\u06cc\u062d \u062a\u0628\u062f\u06cc\u0644 \u0645\u06cc \u0634\u0648\u0646\u062f.\n<\/li>\n<\/ol>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code>   <span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">defineAction<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">astro:actions<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\n   <span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">z<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">astro:schema<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\n\n   <span class=\"k\">export<\/span> <span class=\"kd\">const<\/span> <span class=\"nx\">server<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\n     <span class=\"na\">getGreeting<\/span><span class=\"p\">:<\/span> <span class=\"nf\">defineAction<\/span><span class=\"p\">({<\/span>\n       <span class=\"na\">input<\/span><span class=\"p\">:<\/span> <span class=\"nx\">z<\/span><span class=\"p\">.<\/span><span class=\"nf\">object<\/span><span class=\"p\">({<\/span>\n         <span class=\"na\">name<\/span><span class=\"p\">:<\/span> <span class=\"nx\">z<\/span><span class=\"p\">.<\/span><span class=\"nf\">string<\/span><span class=\"p\">(),<\/span>\n       <span class=\"p\">}),<\/span>\n       <span class=\"na\">accept<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">form<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"c1\">\/\/ Specifies form data handling<\/span>\n       <span class=\"na\">handler<\/span><span class=\"p\">:<\/span> <span class=\"k\">async <\/span><span class=\"p\">({<\/span> <span class=\"nx\">input<\/span> <span class=\"p\">})<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\n         <span class=\"c1\">\/\/ this is a typesafe object now !<\/span>\n         <span class=\"kd\">const<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">name<\/span> <span class=\"p\">}<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">input<\/span><span class=\"p\">;<\/span>\n         <span class=\"k\">return<\/span> <span class=\"s2\">`Hello, <\/span><span class=\"p\">${<\/span><span class=\"nx\">name<\/span><span class=\"p\">}<\/span><span class=\"s2\">!`<\/span><span class=\"p\">;<\/span>\n       <span class=\"p\">}<\/span>\n     <span class=\"p\">})<\/span>\n   <span class=\"p\">};<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<ol>\n<li>\n<strong>\u0628\u0647\u0628\u0648\u062f \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627<\/strong>: Astro&#39;s Actions \u0645\u0639\u0631\u0641\u06cc \u0645\u06cc \u06a9\u0646\u062f <code>ActionError<\/code>\u060c \u06a9\u062f\u0647\u0627\u06cc \u0648\u0636\u0639\u06cc\u062a HTTP \u0648 \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u062f\u0642\u06cc\u0642 \u062a\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627 \u0641\u0639\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0634\u0628\u06cc\u0647 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0633\u0631\u0648\u0631 \u0633\u0646\u062a\u06cc \u0627\u0633\u062a. \u0627\u06cc\u0646 \u0642\u0627\u0628\u0644\u06cc\u062a \u06a9\u0646\u062a\u0631\u0644 \u062e\u0637\u0627\u06cc \u06af\u0631\u0627\u0646\u0648\u0644 \u0648 \u0627\u0631\u062a\u0628\u0627\u0637 \u0645\u0634\u062a\u0631\u06cc \u0648 \u0633\u0631\u0648\u0631 \u0648\u0627\u0636\u062d \u062a\u0631 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.\n<\/li>\n<\/ol>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight typescript\"><code>   <span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">defineAction<\/span><span class=\"p\">,<\/span> <span class=\"nx\">ActionError<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">astro:actions<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\n   <span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">z<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">astro:schema<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\n\n   <span class=\"k\">export<\/span> <span class=\"kd\">const<\/span> <span class=\"nx\">server<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\n     <span class=\"na\">likePost<\/span><span class=\"p\">:<\/span> <span class=\"nf\">defineAction<\/span><span class=\"p\">({<\/span>\n       <span class=\"na\">input<\/span><span class=\"p\">:<\/span> <span class=\"nx\">z<\/span><span class=\"p\">.<\/span><span class=\"nf\">object<\/span><span class=\"p\">({<\/span> <span class=\"na\">postId<\/span><span class=\"p\">:<\/span> <span class=\"nx\">z<\/span><span class=\"p\">.<\/span><span class=\"nf\">string<\/span><span class=\"p\">()<\/span> <span class=\"p\">}),<\/span>\n       <span class=\"na\">handler<\/span><span class=\"p\">:<\/span> <span class=\"k\">async <\/span><span class=\"p\">(<\/span><span class=\"nx\">input<\/span><span class=\"p\">,<\/span> <span class=\"nx\">ctx<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\n         <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">ctx<\/span><span class=\"p\">.<\/span><span class=\"nx\">cookies<\/span><span class=\"p\">.<\/span><span class=\"nf\">has<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">user-session<\/span><span class=\"dl\">'<\/span><span class=\"p\">))<\/span> <span class=\"p\">{<\/span>\n           <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">ActionError<\/span><span class=\"p\">({<\/span>\n             <span class=\"na\">code<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">UNAUTHORIZED<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\n             <span class=\"na\">message<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">User must be logged in.<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\n           <span class=\"p\">});<\/span>\n         <span class=\"p\">}<\/span>\n         <span class=\"c1\">\/\/ Process request if authorized<\/span>\n       <span class=\"p\">},<\/span>\n     <span class=\"p\">}),<\/span>\n   <span class=\"p\">};<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<ol>\n<li>\n<strong>\u0646\u0627\u0645 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0642\u0627\u0628\u0644 \u062e\u0648\u0627\u0646\u062f\u0646<\/strong>: \u0628\u0631\u062e\u0644\u0627\u0641 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0647\u0634\u200c\u0634\u062f\u0647 React\u060c Astro&#39;s Actions \u0627\u0632 \u0646\u0627\u0645\u200c\u0647\u0627\u06cc \u062a\u0639\u0631\u06cc\u0641\u200c\u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0628\u0631\u0627\u06cc \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0627\u0634\u06a9\u0627\u0644\u200c\u0632\u062f\u0627\u06cc\u06cc \u0648 \u0631\u062f\u06cc\u0627\u0628\u06cc \u062a\u0645\u0627\u0633\u200c\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u0642\u0627\u0628\u0644\u200c\u062a\u0648\u062c\u0647\u06cc \u0622\u0633\u0627\u0646\u200c\u062a\u0631 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/li>\n<\/ol>\n<p><img decoding=\"async\" src=\"https:\/\/media2.dev.to\/dynamic\/image\/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto\/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fptz72a3647oooku8ccwf.png\" alt=\"\u0646\u0645\u0648\u0646\u0647 \u0646\u0627\u0645\u200c\u0647\u0627\u06cc \u067e\u0627\u06cc\u0627\u0646\u06cc \u0642\u0627\u0628\u0644 \u062e\u0648\u0627\u0646\u062f\u0646 \u0627\u0632 Astro\" loading=\"lazy\" width=\"558\" height=\"198\" title=\"\"><\/p>\n<ol>\n<li>\n<strong>\u0627\u0641\u0632\u0627\u06cc\u0634 \u062a\u062f\u0631\u06cc\u062c\u06cc \u0648 \u0645\u0646\u0627\u0628\u0639 \u0627\u0636\u0627\u0641\u06cc<\/strong>: Astro \u0628\u0631 \u0628\u0647\u0628\u0648\u062f \u067e\u06cc\u0634\u0631\u0648\u0646\u062f\u0647 \u062a\u0645\u0631\u06a9\u0632 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0628\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062d\u062a\u06cc \u0628\u0627 \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u0628\u0648\u062f\u0646 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u06a9\u0627\u0631 \u06a9\u0646\u062f. \u0627\u06cc\u0646 \u0628\u0627 \u062a\u0639\u0647\u062f Astro \u0628\u0647 \u06cc\u06a9 \u0648\u0628 \u0633\u0628\u06a9 \u062a\u0631 \u0648 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u062a\u0631 \u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0627\u0631\u062f \u0648 \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627\u06cc \u0627\u0635\u0644\u06cc \u0628\u062f\u0648\u0646 \u0627\u062a\u06a9\u0627 \u0628\u0647 \u0627\u062c\u0631\u0627\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u062f\u0633\u062a \u0646\u062e\u0648\u0631\u062f\u0647 \u0628\u0627\u0642\u06cc \u0645\u06cc \u0645\u0627\u0646\u0646\u062f.<\/li>\n<\/ol>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f Astro&#39;s Actions\u060c \u0627\u0633\u0646\u0627\u062f Astro Actions \u0631\u0627 \u06a9\u0627\u0648\u0634 \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0647 \u0628\u0647 \u062c\u0632\u0626\u06cc\u0627\u062a \u0627\u062f\u063a\u0627\u0645 Actions \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u0645\u06cc \u067e\u0631\u062f\u0627\u0632\u062f.<\/p>\n<\/p><\/div>\n","protected":false},"excerpt":{"rendered":"<p>Summarize this content to 400 words in Persian Lang React 19 \u0686\u0646\u062f\u06cc\u0646 \u0648\u06cc\u0698\u06af\u06cc \u0647\u06cc\u062c\u0627\u0646 \u0627\u0646\u06af\u06cc\u0632 \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u06a9\u0631\u062f\u060c \u0628\u0647 \u0648\u06cc\u0698\u0647 \u062f\u0631 \u062a\u0639\u0627\u0645\u0644 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0628\u0627 Server Actions. \u0647\u062f\u0641 \u0627\u06cc\u0646 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u062a\u0645\u0627\u0633\u200c\u0647\u0627\u06cc \u0633\u0631\u0648\u0631 \u0627\u0633\u062a \u0648 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f \u062a\u0627 \u0628\u062f\u0648\u0646 \u0646\u06cc\u0627\u0632 \u0628\u0647 API \u06af\u0633\u062a\u0631\u062f\u0647\u200c\u062a\u0631\u060c \u0628\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627 \u0631\u0633\u06cc\u062f\u06af\u06cc \u06a9\u0646\u0646\u062f. \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0622\u0646\u0647\u0627 \u0686\u0627\u0644\u0634 \u0647\u0627\u06cc\u06cc &hellip;<\/p>\n","protected":false},"author":2,"featured_media":81604,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"fifu_image_url":"","fifu_image_alt":"","footnotes":""},"categories":[339],"tags":[],"class_list":["post-81603","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-dev"],"_links":{"self":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/81603","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/comments?post=81603"}],"version-history":[{"count":0,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/81603\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media\/81604"}],"wp:attachment":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media?parent=81603"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/categories?post=81603"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/tags?post=81603"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}