{"id":14745,"date":"2024-02-13T16:06:30","date_gmt":"2024-02-13T12:36:30","guid":{"rendered":"https:\/\/www.itpiran.net\/blog\/?p=14745"},"modified":"2024-02-13T16:06:30","modified_gmt":"2024-02-13T12:36:30","slug":"real-time-apps-with-go-and-reactjs-basic-reactjs-ui","status":"publish","type":"post","link":"https:\/\/www.itpiran.net\/blog\/en\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/","title":{"rendered":"Creating a Basic User Interface with ReactJS"},"content":{"rendered":"<h2 id=\"%d9%85%d9%82%d8%af%d9%85%d9%87\">\u0645\u0642\u062f\u0645\u0647<\/h2>\n<p>\u0645\u0627 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0686\u062a \u0633\u0627\u062f\u0647 \u0628\u0627 ReactJS \u0628\u0631 \u0627\u0633\u0627\u0633 \u0633\u0631\u0648\u0631\u06cc \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645\u060c \u062e\u0648\u0627\u0647\u06cc\u0645 \u0633\u0627\u062e\u062a. \u0645\u0627 \u0628\u0627 \u0633\u0627\u062e\u062a \u0627\u062c\u0632\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0634\u0631\u0648\u0639 \u0645\u06cc \u06a9\u0646\u06cc\u0645\u060c \u06a9\u0647 \u0633\u067e\u0633 \u0628\u0647 \u062d\u0627\u0644\u062a \u0645\u062a\u0635\u0644 \u0645\u06cc \u0634\u0648\u0646\u062f. \u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0622\u062e\u0631 \u0645\u0627 \u062f\u0631 \u0633\u0631\u0648\u0631 \u0631\u0648\u06cc\u062f\u0627\u062f \u0645\u0634\u062a\u0631\u06a9 \u0645\u06cc \u0634\u0648\u06cc\u0645.<\/p>\n<h5 id=\"%d9%be%db%8c%d8%b4-%d9%86%db%8c%d8%a7%d8%b2%d9%87%d8%a7\">\u067e\u06cc\u0634 \u0646\u06cc\u0627\u0632\u0647\u0627<\/h5>\n<ul>\n<li>\u062f\u0627\u0646\u0634 \u067e\u0627\u06cc\u0647 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648 ReactJS (\u0645\u0646 \u0633\u0639\u06cc \u0645\u06cc \u06a9\u0646\u0645 \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0631\u0627 \u0633\u0627\u062f\u0647 \u0646\u06af\u0647 \u062f\u0627\u0631\u0645)<\/li>\n<li>npm v6<\/li>\n<li>npx v6<\/li>\n<li>node v12<\/li>\n<\/ul>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-1-%d8%b1%d8%a7%d9%87-%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c-%d9%be%d8%b1%d9%88%da%98%d9%87\">\u0645\u0631\u062d\u0644\u0647 1: \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u067e\u0631\u0648\u0698\u0647<\/h2>\n<p>\u062f\u0631 \u067e\u0648\u0634\u0647 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f npx create-react-app &#8211;use-npm simple-chat-app \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f \u0648 \u0645\u0646\u062a\u0638\u0631 \u0628\u0645\u0627\u0646\u06cc\u062f \u062a\u0627 \u0646\u0635\u0628 \u062a\u0645\u0627\u0645 \u0634\u0648\u062f. \u0627\u06cc\u0646 \u0647\u0645\u0647 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u06cc\u06a9 \u062a\u062c\u0631\u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u0648 \u0633\u0627\u062e\u062a \u0633\u0627\u062f\u0647 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u067e\u0648\u0634\u0647 src \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<ul>\n<li>App.js (should already exist)<\/li>\n<li>ChatLineHolder.js<\/li>\n<li>ChatLine.js<\/li>\n<li>ChatInput.js<\/li>\n<\/ul>\n<p>npm run start \u0631\u0627 \u0627\u0632 \u067e\u0648\u0634\u0647 \u067e\u0631\u0648\u0698\u0647 \u062f\u0631 \u06a9\u0646\u0633\u0648\u0644 \u062e\u0648\u062f \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f. \u0627\u06cc\u0646 \u06cc\u06a9 \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 \u0631\u0627 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0634\u0645\u0627 \u0628\u0627\u0632 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0627\u0632 \u0642\u0628\u0644 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 App.js \u062f\u0631 \u067e\u0648\u0634\u0647 src \u0634\u0645\u0627 \u0648\u062c\u0648\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f. \u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0647\u0631 \u0686\u06cc\u0632\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0627\u0632 \u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f \u062d\u0630\u0641 \u06a9\u0646\u06cc\u062f \u0648 \u0641\u0642\u0637 \u06cc\u06a9 &lt;div&gt; \u0631\u0627 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u06cc\u062f.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>const App = () =&gt; {\r\nreturn &lt;div className='chat-app'&gt;&lt;\/div&gt;\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0645\u0627 \u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u0627\u062c\u0632\u0627\u06cc \u062e\u0648\u062f \u0627\u0632 \u067e\u0627\u06cc\u06cc\u0646 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0634\u0631\u0648\u0639 \u0645\u06cc \u06a9\u0646\u06cc\u0645<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-2-%d9%85%d8%a4%d9%84%d9%81%d9%87-chatline\">\u0645\u0631\u062d\u0644\u0647 2: \u0645\u0624\u0644\u0641\u0647 &lt;ChatLine&gt;<\/h2>\n<p>\u062f\u0631 ChatLine.js \u0645\u0627 \u06cc\u06a9 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u062f\u0648 \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u0631\u062f:<\/p>\n<ul>\n<li><code>name<\/code>: string<\/li>\n<li><code>message<\/code>: string<\/li>\n<\/ul>\n<p>\u0627\u06cc\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0639\u062f\u0627\u064b \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062f\u0627\u062f\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f \u0627\u0632 \u0633\u0631\u0648\u0631 \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u06cc\u06a9 &lt;li&gt; \u0633\u0627\u062f\u0647 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f \u0648 \u0646\u0627\u0645 \u0648 \u067e\u06cc\u0627\u0645 \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>import React from 'react'\r\nconst ChatLine = ({ name, message }) =&gt; {\r\nreturn (\r\n&lt;li&gt;\r\n{name}: {message}\r\n&lt;\/li&gt;\r\n)\r\n}\r\nexport default<\/code><\/pre>\n<\/div>\n<p>\u062a\u0648\u062c\u0647: ReactJS \u0628\u0647 \u0637\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0627\u0632 \u062a\u0632\u0631\u06cc\u0642 html \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0645\u06cc \u06a9\u0646\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u0646\u06af\u0631\u0627\u0646\u06cc \u062f\u0631 \u0645\u0648\u0631\u062f \u0622\u0646 \u0646\u06cc\u0633\u062a.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-3-%d9%85%d8%a4%d9%84%d9%81%d9%87-chatholder\">\u0645\u0631\u062d\u0644\u0647 3: \u0645\u0624\u0644\u0641\u0647 &lt;ChatHolder&gt;<\/h2>\n<p>\u062f\u0631 ChatHolder.js \u0645\u0627 \u06cc\u06a9 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u062a\u0646\u0647\u0627 \u06cc\u06a9 \u067e\u0627\u06cc\u0647 \u0631\u0627 \u0645\u06cc\u200c\u06af\u06cc\u0631\u062f:<\/p>\n<p>\u062e\u0637\u0648\u0637: \u0622\u0631\u0627\u06cc\u0647&lt;{ \u0646\u0627\u0645: \u0631\u0634\u062a\u0647\u060c \u067e\u06cc\u0627\u0645: \u0631\u0634\u062a\u0647 }&gt;<\/p>\n<p>\u0627\u06af\u0631 <code>lines<\/code> \u062e\u0627\u0644\u06cc \u0628\u0627\u0634\u062f\u060c \u06cc\u06a9 \u0627\u0639\u0644\u0627\u0646 \u0633\u0627\u062f\u0647 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u06cc\u0645.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>if (lines.length === 0) {\r\nreturn &lt;div&gt;Chat history is empty&lt;\/div&gt;\r\n}<\/code><\/pre>\n<\/div>\n<p>\u062e\u0637\u0648\u0637 \u0622\u0631\u0627\u06cc\u0647 \u0627\u06cc \u0627\u0632 \u0627\u0634\u06cc\u0627\u0621 \u0627\u0633\u062a. \u0647\u0631 \u0634\u06cc \u062f\u0627\u0631\u0627\u06cc \u0646\u0627\u0645 \u0648 \u067e\u06cc\u0627\u0645 \u0648\u06cc\u0698\u06af\u06cc \u0627\u0633\u062a. \u0645\u0627 \u0631\u0648\u06cc \u062a\u0645\u0627\u0645 \u0645\u0648\u0627\u0631\u062f \u0645\u0648\u062c\u0648\u062f \u062f\u0631 \u0622\u0631\u0627\u06cc\u0647 \u0646\u06af\u0627\u0634\u062a \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0628\u0627 \u0627\u0631\u0633\u0627\u0644 \u0646\u0627\u0645 \u0648 \u0631\u0634\u062a\u0647 \u0628\u0647 \u0645\u0648\u0644\u0641\u0647 &lt;ChatLine&gt; \u0686\u0646\u062f\u06cc\u0646 \u06af\u0631\u0647 ChatLine \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>const chatLines = lines.map(\r\n(line, index) =&gt; (\r\n&lt;ChatLine key={index} name={line.name} message={line.message} \/&gt;\r\n)\r\n)<\/code><\/pre>\n<\/div>\n<p>\u0633\u067e\u0633 \u0646\u062a\u06cc\u062c\u0647 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 &lt;ul&gt; \u0631\u0646\u062f\u0631 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0648 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u062a\u0645\u0627\u0645 \u0634\u062f\u0647 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0645\u0627 \u0628\u0627\u0642\u06cc \u0645\u06cc \u06af\u0630\u0627\u0631\u06cc\u0645:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>import React from 'react'\r\nimport ChatLine from '.\/ChatLine'\r\nconst ChatLineHolder = ({ lines }) =&gt; {\r\nif (lines.length === 0) {\r\nreturn &lt;div&gt;Chat history is empty&lt;\/div&gt;\r\n}\r\nconst chatLines = lines.map(\r\n(line, index) =&gt; (\r\n&lt;ChatLine key={index} message={line.message} name={line.name} \/&gt;\r\n)\r\n)\r\nreturn (\r\n&lt;ul&gt;\r\n{chatLines}\r\n&lt;\/ul&gt;\r\n)\r\n}\r\nexport default ChatLineHolder<\/code><\/pre>\n<\/div>\n<p>\u062a\u0648\u062c\u0647: \u0634\u0645\u0627 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0627\u0632 \u06cc\u06a9 \u0634\u0646\u0627\u0633\u0647 \u0645\u0646\u062d\u0635\u0631 \u0628\u0647 \u0641\u0631\u062f \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06a9\u0644\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f. \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f\u060c \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0627 \u062e\u06cc\u0627\u0644 \u0631\u0627\u062d\u062a \u0627\u0632 \u0627\u06cc\u0646\u062f\u06a9\u0633 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645\u060c \u0632\u06cc\u0631\u0627 \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u06cc\u0646 \u0634\u0627\u062e\u0635 \u0648 \u0634\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u0646\u0645\u06cc \u06a9\u0646\u062f. \u062f\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0646\u06cc\u0627\u06cc \u0648\u0627\u0642\u0639\u06cc\u060c \u0627\u06cc\u0646 \u0627\u0645\u0631 \u0628\u0633\u06cc\u0627\u0631 \u0646\u0627\u0627\u0645\u06cc\u062f \u0627\u0633\u062a.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-4-%d9%85%d8%a4%d9%84%d9%81%d9%87-chatinput\">\u0645\u0631\u062d\u0644\u0647 4: \u0645\u0624\u0644\u0641\u0647 &lt;ChatInput&gt;<\/h2>\n<p>\u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0645\u062a\u0648\u062c\u0647 \u0634\u062f\u0647 \u0628\u0627\u0634\u06cc\u062f\u060c \u0647\u0646\u0648\u0632 \u0631\u0627\u0647\u06cc \u0628\u0631\u0627\u06cc \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0646 \u067e\u06cc\u0627\u0645 \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f. &lt;ChatInput \/&gt; \u0648\u0631\u0648\u062f\u06cc \u0645\u062a\u0646 \u0631\u0627 \u06a9\u0646\u062a\u0631\u0644 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0627\u0632 \u06cc\u06a9 \u0639\u0645\u0644\u06a9\u0631\u062f \u067e\u0627\u0633\u062e \u0628\u0647 \u062a\u0645\u0627\u0633 \u062f\u0631 \u0627\u0631\u0633\u0627\u0644 \u0628\u0631\u0627\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06cc\u06a9 \u067e\u06cc\u0627\u0645 \u0686\u062a \u062c\u062f\u06cc\u062f \u0628\u0627 \u06a9\u0644\u06cc\u06a9 \u0631\u0648\u06cc \u062f\u06a9\u0645\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f. \u0628\u0647 \u06cc\u06a9 \u062a\u06a9\u06cc\u0647 \u06af\u0627\u0647 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u062f:<\/p>\n<ul>\n<li>onSend: (\u067e\u06cc\u0627\u0645: \u0631\u0634\u062a\u0647) =&gt; void<\/li>\n<\/ul>\n<p>\u0645\u0624\u0644\u0641\u0647 \u0648\u0631\u0648\u062f\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u062f\u0631 \u062d\u0627\u0644\u062a \u062e\u0648\u062f\u0634 \u0646\u06af\u0647 \u0645\u06cc \u062f\u0627\u0631\u062f \u0648 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0647\u0627 \u0631\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>const [value, setValue] = useState('')\r\nconst onChange = (event) =&gt; {\r\nsetValue(event.target.value)\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0628\u0627 \u06a9\u0644\u06cc\u06a9 \u0631\u0648\u06cc \u062f\u06a9\u0645\u0647 \u0627\u0631\u0633\u0627\u0644\u060c \u062a\u0627\u0628\u0639 onSend \u0628\u0627 \u0648\u0636\u0639\u06cc\u062a \u0641\u0639\u0644\u06cc \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f. \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0646\u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0627\u0631\u0628\u0631 \u0645\u062c\u0628\u0648\u0631 \u0628\u0627\u0634\u062f \u0641\u06cc\u0644\u062f \u0648\u0631\u0648\u062f\u06cc \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u062f\u0633\u062a\u06cc \u067e\u0627\u06a9 \u06a9\u0646\u062f\u060c \u067e\u0633 \u0627\u0632 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc onSend \u0648\u0636\u0639\u06cc\u062a \u0631\u0627 \u0628\u0627\u0632\u0646\u0634\u0627\u0646\u06cc \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>const onClickSend = () =&gt; {\r\nonSend(value)\r\nsetValue('')\r\n}\r\n<\/code><\/pre>\n<\/div>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0645\u0648\u0644\u0641\u0647 \u0646\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>import React, { useState } from 'react'\r\nconst ChatInput = ({ onSend }) =&gt; {\r\nconst [value, setValue] = useState('')\r\nconst onChange = (event) =&gt; {\r\nsetValue(event.target.value)\r\n}\r\nconst onClickSend = () =&gt; {\r\nsetValue('')\r\nonSend(value)\r\n}\r\nreturn (\r\n&lt;div&gt;\r\n&lt;input type='text' value={value} onChange={onChange} \/&gt;\r\n&lt;button onClick={onClickSend}&gt;send&lt;\/button&gt;\r\n&lt;\/div&gt;\r\n)\r\n}\r\nexport default ChatInput<\/code><\/pre>\n<\/div>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-5-%d9%85%d8%a4%d9%84%d9%81%d9%87-app\">\u0645\u0631\u062d\u0644\u0647 5: \u0645\u0624\u0644\u0641\u0647 &lt;App&gt;<\/h2>\n<h5 id=\"%d8%ad%d8%a7%d9%84%d8%aa\">\u062d\u0627\u0644\u062a<\/h5>\n<p>\u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a\u200c\u0647\u0627\u06cc \u0645\u0627 \u0647\u06cc\u0686 \u062f\u0627\u062f\u0647\u200c\u0627\u06cc \u0631\u0627 \u0627\u0632 \u062e\u0648\u062f \u0646\u06af\u0647\u062f\u0627\u0631\u06cc \u0646\u0645\u06cc\u200c\u06a9\u0646\u0646\u062f\u060c \u0627\u0632 &lt;App&gt; \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u0648\u0644\u0641\u0647 \u0627\u0635\u0644\u06cc \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062d\u0627\u0644\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645. \u0645\u0627 3 \u0646\u0648\u0639 \u062d\u0627\u0644\u062a \u062f\u0627\u0631\u06cc\u0645:<\/p>\n<ul>\n<li>name: \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u06a9\u0647 \u062f\u0631 \u062d\u0627\u0644 \u0686\u062a \u06a9\u0631\u062f\u0646 \u0627\u0633\u062a<\/li>\n<li>chatLines: \u0622\u0631\u0627\u06cc\u0647 \u0627\u06cc \u06a9\u0647 \u062a\u0627\u0631\u06cc\u062e\u0686\u0647 \u0686\u062a \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f<\/li>\n<li>eventLister: \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u0627\u0632 \u0633\u0631\u0648\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f. (\u062a\u0648\u062c\u0647: \u062a\u0635\u0645\u06cc\u0645 \u06af\u0631\u0641\u062a\u0645 \u0634\u0646\u0648\u0646\u062f\u0647 \u0631\u0627 \u062f\u0631 \u0642\u0633\u0645\u062a \u0642\u0631\u0627\u0631 \u062f\u0647\u0645.<\/li>\n<\/ul>\n<p>\u0628\u0647 \u062e\u0627\u0637\u0631 \u0633\u0627\u062f\u06af\u06cc \u0628\u06cc\u0627\u0646 \u06a9\u0646\u06cc\u062f \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0646\u06cc\u0627\u06cc \u0648\u0627\u0642\u0639\u06cc \u0631\u0648\u06cc\u06a9\u0631\u062f \u0645\u062a\u0641\u0627\u0648\u062a\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f)<\/p>\n<p>\u0645\u0627 \u0627\u0632 \u0642\u0644\u0627\u0628 \u0647\u0627\u06cc \u062d\u0627\u0644\u062a \u0628\u0631\u0627\u06cc \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u062d\u0627\u0644\u062a \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code> const [chatLines, setChatLines] = useState([])\r\nconst [eventListener, setEventListener] = useState(null)\r\nconst [name] = useState(generateRandomName())<\/code><\/pre>\n<\/div>\n<h2 id=\"%d8%aa%d8%b3%d8%aa-%d8%b1%d9%86%d8%af%d8%b1-%d8%a7%d8%ac%d8%b2%d8%a7\">\u062a\u0633\u062a \u0631\u0646\u062f\u0631 \u0627\u062c\u0632\u0627<\/h2>\n<p>\u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u0645\u0627 \u0641\u0642\u0637 \u0646\u0627\u0645 \u062e\u0648\u062f \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u06cc\u0645 \u0648 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a &lt;ChatLineHolder&gt; \u0631\u0627 \u0628\u0627 \u0622\u06cc\u062a\u0645 \u0647\u0627\u06cc \u062b\u0627\u0628\u062a \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u06cc\u0645. \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 chatLines \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u062e\u0627\u0644\u06cc \u0627\u0633\u062a\u060c \u0627\u0639\u0644\u0627\u0646 \u0645\u0627 \u0628\u0627\u06cc\u062f \u0627\u0631\u0627\u0626\u0647 \u0634\u0648\u062f. \u0645\u0627 \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u0641\u0644\u0634 \u062e\u0627\u0644\u06cc \u0631\u0627 \u0628\u0647 &lt;ChatInput&gt; \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0627\u062c\u0631\u0627 \u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f \u062f\u0646\u0628\u0627\u0644 \u062e\u0648\u0627\u0647\u062f \u0634\u062f.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>return (\r\n&lt;div className='chat-app'&gt;\r\n&lt;h2&gt;Chatting as {name}&lt;\/h2&gt;\r\n&lt;ChatLineHolder lines={chatLines} \/&gt;\r\n&lt;ChatInput onSend={() =&gt; {}} \/&gt;\r\n&lt;\/div&gt;\r\n)<\/code><\/pre>\n<\/div>\n<p>\u0627\u06af\u0631 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0622\u06cc\u0627 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0634\u0645\u0627 \u0628\u0627 \u0628\u0631\u062e\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u06a9\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06cc\u0627 \u062e\u06cc\u0631\u060c \u06a9\u0627\u0641\u06cc \u0627\u0633\u062a \u0686\u0646\u062f \u0645\u0648\u0631\u062f \u0631\u0627 \u0628\u0647 chatLines \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>const [chatLines, setChatLines] = useState([{ name: 'Thomas', 'message': 'Hi' }])\r\n<\/code><\/pre>\n<\/div>\n<h2 id=\"%d8%a7%d9%81%d8%b2%d9%88%d8%af%d9%86-%d8%aa%d8%b9%d8%a7%d9%85%d9%84\">\u0627\u0641\u0632\u0648\u062f\u0646 \u062a\u0639\u0627\u0645\u0644<\/h2>\n<p>\u0627\u0632 \u0642\u0628\u0644 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0645\u062a\u0646\u06cc \u0631\u0627 \u062f\u0631 \u0642\u0633\u0645\u062a \u0648\u0631\u0648\u062f\u06cc \u0686\u062a \u062e\u0648\u062f \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u0645\u060c \u0627\u0645\u0627 \u0628\u0627 \u0641\u0634\u0627\u0631 \u062f\u0627\u062f\u0646 send \u06a9\u0627\u0631\u06cc \u0627\u0646\u062c\u0627\u0645 \u0646\u0645\u06cc\u200c\u062f\u0647\u06cc\u0645. \u0627\u06cc\u0646 \u0628\u0647 \u0627\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u062a\u0627\u0628\u0639\u06cc \u0631\u0627 \u0628\u0647 &lt;ChatInput&gt; \u0627\u0631\u0633\u0627\u0644 \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0645\u0637\u0644\u0642\u0627\u064b \u0647\u06cc\u0686 \u06a9\u0627\u0631\u06cc \u0627\u0646\u062c\u0627\u0645 \u0646\u0645\u06cc \u062f\u0647\u062f. \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0627 \u0628\u0647 \u06cc\u06a9 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0628\u0631\u0627\u06cc \u0622\u0646 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645.<\/p>\n<p>\u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u0627 \u0647\u0646\u0648\u0632 \u0628\u0647 \u0633\u0631\u0648\u0631 \u062e\u0648\u062f \u0645\u062a\u0635\u0644 \u0646\u06cc\u0633\u062a\u06cc\u0645\u060c onSend \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u06af\u0648\u0646\u0647 \u0627\u06cc \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0645\u0633\u062a\u0642\u06cc\u0645\u0627\u064b \u0648\u0636\u0639\u06cc\u062a \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u0645\u06cc \u06a9\u0646\u062f. \u0628\u0631\u0627\u06cc \u0622\u0646 \u0645\u0627 \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u06a9\u0645\u06a9\u06cc \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 addChatLine: (chatLine) =&gt; void. \u0645\u0627 \u0628\u0639\u062f\u0627\u064b \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u067e\u06cc\u0627\u0645 \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>const addChatLine = (chatLine) =&gt; {\r\nsetChatLines(chatLines =&gt; {\r\nreturn [...chatLines, chatLine]\r\n})\r\n\/\/ If you don't have a lot of experience with ReactJS, just think of this as:\r\n\/\/ setChatLines([...chatLines, chatLine])\r\n}<\/code><\/pre>\n<\/div>\n<p>onSend \u06cc\u06a9 \u0634\u06cc \u062e\u0637 \u0686\u062a \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f \u0648 addChatLine \u0631\u0627 \u0641\u0631\u0627 \u0645\u06cc \u062e\u0648\u0627\u0646\u062f<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>const onSend = (message) =&gt; {\r\nconst chatLine = { name, message }\r\naddChatLine(chatLine)\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0641\u0631\u0627\u0645\u0648\u0634 \u0646\u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0627\u0631\u0633\u0627\u0644 \u0631\u0627 \u0628\u0647 &lt;ChatInput&gt; \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u06cc\u062f.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>return (\r\n&lt;div className='chat-app'&gt;\r\n&lt;h2&gt;Chatting as {name}&lt;\/h2&gt;\r\n&lt;ChatLineHolder lines={chatLines} \/&gt;\r\n&lt;ChatInput onSend={onSend} \/&gt;\r\n&lt;\/div&gt;\r\n)<\/code><\/pre>\n<\/div>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0628\u0627\u06cc\u062f \u0628\u062a\u0648\u0627\u0646\u06cc\u062f \u0645\u062a\u0646 \u0631\u0627 \u062f\u0631 \u0642\u0633\u0645\u062a \u0648\u0631\u0648\u062f\u06cc \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u062f\u060c \u0631\u0648\u06cc \u0627\u0631\u0633\u0627\u0644 \u06a9\u0644\u06cc\u06a9 \u06a9\u0646\u06cc\u062f \u0648 \u0641\u0648\u0631\u0627\u064b \u067e\u06cc\u0627\u0645 \u062e\u0648\u062f \u0631\u0627 \u0628\u0628\u06cc\u0646\u06cc\u062f.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-6-%d8%a7%d8%aa%d8%b5%d8%a7%d9%84-%d8%a8%d9%87-%d8%b3%d8%b1%d9%88%d8%b1\">\u0645\u0631\u062d\u0644\u0647 6: \u0627\u062a\u0635\u0627\u0644 \u0628\u0647 \u0633\u0631\u0648\u0631<\/h2>\n<p>\u0686\u062a \u06a9\u0631\u062f\u0646 \u0628\u0627 \u062e\u0648\u062f\u062a\u0627\u0646 \u0628\u0633\u06cc\u0627\u0631 \u06a9\u0633\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0627\u0633\u062a. \u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0633\u0631\u0648\u0631 \u0645\u062a\u0635\u0644 \u06a9\u0646\u06cc\u0645. \u0627\u06cc\u0646 \u062f\u0631 2 \u0642\u0633\u0645\u062a \u0627\u062a\u0641\u0627\u0642 \u0645\u06cc \u0627\u0641\u062a\u062f:<\/p>\n<ul>\n<li>\u0627\u0631\u0633\u0627\u0644 \u067e\u06cc\u0627\u0645 \u0628\u0647 \u0633\u0631\u0648\u0631<\/li>\n<li>\u0645\u0634\u062a\u0631\u06a9 \u0634\u062f\u0646 \u062f\u0631 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631<\/li>\n<\/ul>\n<h5 id=\"%d8%a7%d8%b1%d8%b3%d8%a7%d9%84-%d9%be%db%8c%d8%a7%d9%85-%d8%a8%d9%87-%d8%b3%d8%b1%d9%88%d8%b1\">\u0627\u0631\u0633\u0627\u0644 \u067e\u06cc\u0627\u0645 \u0628\u0647 \u0633\u0631\u0648\u0631<\/h5>\n<p>\u0628\u0627\u06cc\u062f \u062a\u0627\u0628\u0639 onSend \u0631\u0627 \u06a9\u0647 \u0646\u0648\u0634\u062a\u06cc\u0645 \u0627\u0635\u0644\u0627\u062d \u06a9\u0646\u06cc\u0645. \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u06a9\u0644 \u0628\u062f\u0646 \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u062a\u0645\u0627\u0633 \u0648\u0627\u06a9\u0634\u06cc \u0633\u0627\u062f\u0647 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0646\u06cc\u0645\u060c \u06a9\u0647 \u0646\u0627\u0645 \u0648 \u067e\u06cc\u0627\u0645 \u0645\u0627 \u0631\u0627 \u062f\u0631 \u0628\u062f\u0646 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f. \u0645\u0647\u0645 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 addChatLine \u062a\u0645\u0627\u0633 \u0646\u06af\u06cc\u0631\u06cc\u062f \u0632\u06cc\u0631\u0627 \u0628\u0639\u062f\u0627\u064b \u0628\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u0631\u0648\u06cc\u062f\u0627\u062f \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u062f.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>const onSend = async (message) =&gt; {\r\nfetch('http:\/\/localhost:4000\/say',\r\n{\r\nheaders: {\r\n'Content-Type': 'application\/x-www-form-urlencoded',\r\n},\r\nmethod: 'post',\r\nmode: 'no-cors',\r\nbody: `name=${name}&amp;message=${message}`\r\n})\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0627\u06af\u0631 \u0627\u06a9\u0646\u0648\u0646 \u0631\u0648\u06cc \u062f\u06a9\u0645\u0647 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0644\u06cc\u06a9 \u06a9\u0646\u06cc\u062f\u060c \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0628\u0647 \u0633\u0631\u0648\u0631 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f \u0627\u0645\u0627 \u0648\u0636\u0639\u06cc\u062a \u0634\u0645\u0627 \u0647\u0646\u0648\u0632 \u0628\u0647 \u0631\u0648\u0632 \u0646\u0645\u06cc \u0634\u0648\u062f! \u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u06cc \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0648\u0636\u0648\u0639 \u0631\u0633\u06cc\u062f\u06af\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<h5 id=\"%d8%af%d8%b1-%d8%b1%d9%88%db%8c%d8%af%d8%a7%d8%af%d9%87%d8%a7%db%8c-%d8%a7%d8%b1%d8%b3%d8%a7%d9%84-%d8%b4%d8%af%d9%87-%d8%aa%d9%88%d8%b3%d8%b7-%d8%b3%d8%b1%d9%88%d8%b1-%d9%85%d8%b4%d8%aa%d8%b1%da%a9\">\u062f\u0631 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631 \u0645\u0634\u062a\u0631\u06a9 \u0634\u0648\u06cc\u062f<\/h5>\n<p>\u0642\u0628\u0644 \u0627\u0632 \u0634\u0631\u0648\u0639 \u0628\u0647 \u06af\u0648\u0634 \u062f\u0627\u062f\u0646 \u0628\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u060c \u0628\u0627\u06cc\u062f \u062a\u0627\u0628\u0639\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645 \u06a9\u0647 \u0686\u0646\u06cc\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u067e\u06cc\u0627\u0645\u06cc \u0631\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0646\u062f. \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u0627 \u0628\u0639\u062f\u0627\u064b \u0628\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc\u06cc \u0627\u0632 \u0646\u0648\u0639 \u067e\u06cc\u0627\u0645 \u0645\u062a\u0635\u0644 \u062e\u0648\u0627\u0647\u06cc\u0645 \u0634\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646 \u0631\u0627 \u0645\u0637\u0627\u0628\u0642 \u0628\u0627 \u0622\u0646 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645. \u062a\u0645\u0627\u0645 \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 event.data \u0631\u0627 \u0645\u06cc \u06af\u06cc\u0631\u062f\u060c \u0622\u0646 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u0634\u06cc \u062a\u062c\u0632\u06cc\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0648 addChatLine \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>const onMessage = (event) =&gt; {\r\nconst chatLine = JSON.parse(event.data)\r\naddChatLine(chatLine)\r\n}\r\n<\/code><\/pre>\n<\/div>\n<p>\u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631\u060c \u06cc\u06a9 \u0634\u06cc \u0627\u0632 \u06a9\u0644\u0627\u0633 EventSource \u0628\u0627 \u0622\u062f\u0631\u0633 \u0645\u062d\u0644\u06cc \u062e\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0633\u067e\u0633 \u06cc\u06a9 \u0631\u0648\u06cc\u062f\u0627\u062f \u0634\u0646\u0648\u0646\u062f\u0647 \u0628\u0631\u0627\u06cc \u0646\u0648\u0639 \u067e\u06cc\u0627\u0645 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0633\u067e\u0633 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u0642\u0644\u0627\u0628 useEffect \u0645\u06cc\u200c\u067e\u06cc\u0686\u06cc\u0645 (\u0627\u06cc\u0646 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0648\u0642\u062a\u06cc \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a &lt;App&gt; \u0633\u0648\u0627\u0631 \u0645\u06cc\u200c\u0634\u0648\u062f\u060c \u0645\u0646\u0628\u0639 \u0631\u0648\u06cc\u062f\u0627\u062f \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f \u0648 \u067e\u0633 \u0627\u0632 \u0646\u0635\u0628 \u0622\u0646 \u0628\u0633\u062a\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f).<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>useEffect(() =&gt; {\r\nlet source = new EventSource('http:\/\/localhost:4000\/listen')\r\nsource.addEventListener('message', onMessage)\r\nsetEventSource(source)\r\nreturn () =&gt; { source.close() }\r\n}, [])<\/code><\/pre>\n<\/div>\n<p>\u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a &lt;App&gt; \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0627\u0633\u062a:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>import React, { useEffect, useState } from 'react'\r\nimport ChatLineHolder from '.\/ChatLineHolder'\r\nimport ChatInput from '.\/ChatInput'\r\nconst App = () =&gt; {\r\nconst [chatLines, setChatLines] = useState([])\r\nconst [eventSource, setEventSource] = useState(null)\r\nconst [name] = useState(generateRandomName())\r\nconst addChatLine = (chatLine) =&gt; {\r\nsetChatLines(chatLines =&gt; [...chatLines, chatLine])\r\n}\r\nconst onMessage = (event) =&gt; {\r\nconst chatLine = JSON.parse(event.data)\r\naddChatLine(chatLine)\r\n}\r\nuseEffect(() =&gt; {\r\nlet source = new EventSource(\"http:\/\/localhost:4000\/listen\")\r\nsource.addEventListener('message', onMessage)\r\nsetEventSource(source)\r\nreturn () =&gt; { source.close() }\r\n}, [])\r\nconst onSend = (message) =&gt; {\r\nfetch(\r\n`http:\/\/localhost:4000\/say`,\r\n{\r\nheaders: {\r\n\"Content-Type\": \"application\/x-www-form-urlencoded\",\r\n},\r\nmethod: \"post\",\r\nmode: 'no-cors',\r\nbody: `name=${name}&amp;message=${message}`,\r\n})\r\n}\r\nreturn (\r\n&lt;div className='chat-app'&gt;\r\n&lt;h2&gt;Chatting as {name}&lt;\/h2&gt;\r\n&lt;ChatLineHolder lines={chatLines} \/&gt;\r\n&lt;ChatInput onSend={onSend} \/&gt;\r\n&lt;\/div&gt;\r\n)\r\n}\r\nexport default App<\/code><\/pre>\n<\/div>\n<h2 id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\">\u0646\u062a\u06cc\u062c\u0647<\/h2>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0635\u0641\u062d\u0647 \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u062f\u0648 \u062a\u0628 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f \u0648 \u0628\u0627 \u062f\u0648 \u0622\u0644\u062a\u0631 \u0627\u06cc\u06af\u0648 \u0686\u062a \u06a9\u0646\u06cc\u062f! \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0645\u0624\u0644\u0641\u0647 App \u0631\u0627 \u062f\u0648 \u0628\u0627\u0631 (\u0628\u0627 \u062a\u063a\u06cc\u06cc\u0631 index.js) \u0633\u0648\u0627\u0631 \u06a9\u0646\u06cc\u062f\u060c \u0632\u06cc\u0631\u0627 \u0647\u0631 \u0646\u0645\u0648\u0646\u0647 \u0648\u0636\u0639\u06cc\u062a \u062e\u0627\u0635 \u062e\u0648\u062f \u0631\u0627 \u062f\u0627\u0631\u062f.<\/p>\n","protected":false},"excerpt":{"rendered":"Introduction We will build a simple chat application with ReactJS based on the server we have already implemented\u2026","protected":false},"author":1,"featured_media":14746,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_yoast_wpseo_focuskw":"\u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc React.js","_yoast_wpseo_title":"","_yoast_wpseo_metadesc":"","_yoast_wpseo_canonical":"","_yoast_wpseo_opengraph-description":"","_yoast_wpseo_opengraph-image":"","_yoast_wpseo_twitter-description":"","_yoast_wpseo_twitter-image":"","_yoast_wpseo_focuskeywords":"","_yoast_wpseo_primary_category":"193","footnotes":""},"categories":[193,363],"tags":[400],"class_list":{"0":"post-14745","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-tutorials","8":"category-programming","9":"tag-react-js"},"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.3 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u067e\u0627\u06cc\u0647 \u0628\u0627 ReactJS - \u0628\u0644\u0627\u06af ITPiran<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.itpiran.net\/blog\/en\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u067e\u0627\u06cc\u0647 \u0628\u0627 ReactJS - \u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"og:description\" content=\"\u0645\u0642\u062f\u0645\u0647 \u0645\u0627 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0686\u062a \u0633\u0627\u062f\u0647 \u0628\u0627 ReactJS \u0628\u0631 \u0627\u0633\u0627\u0633 \u0633\u0631\u0648\u0631\u06cc \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645\u060c \u062e\u0648\u0627\u0647\u06cc\u0645&hellip;\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.itpiran.net\/blog\/en\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/\" \/>\n<meta property=\"og:site_name\" content=\"\u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"article:published_time\" content=\"2024-02-13T12:36:30+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.itpiran.net\/2024\/02\/13160535\/React2.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"1793\" \/>\n\t<meta property=\"og:image:height\" content=\"1110\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/\"},\"author\":{\"name\":\"admin\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\"},\"headline\":\"\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u067e\u0627\u06cc\u0647 \u0628\u0627 ReactJS\",\"datePublished\":\"2024-02-13T12:36:30+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/\"},\"wordCount\":118,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/02\\\/13160535\\\/React2.jpg\",\"keywords\":[\"React.js\"],\"articleSection\":[\"\u0622\u0645\u0648\u0632\u0634\u06cc\",\"\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/\",\"name\":\"\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u067e\u0627\u06cc\u0647 \u0628\u0627 ReactJS - \u0628\u0644\u0627\u06af ITPiran\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/02\\\/13160535\\\/React2.jpg\",\"datePublished\":\"2024-02-13T12:36:30+00:00\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/#primaryimage\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/02\\\/13160535\\\/React2.jpg\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/02\\\/13160535\\\/React2.jpg\",\"width\":1793,\"height\":1110},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u0622\u0645\u0648\u0632\u0634\u06cc\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/category\\\/tutorials\\\/\"},{\"@type\":\"ListItem\",\"position\":3,\"name\":\"\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u067e\u0627\u06cc\u0647 \u0628\u0627 ReactJS\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"name\":\"\u0628\u0644\u0627\u06af ITPiran\",\"description\":\"\u0627\u062e\u0628\u0627\u0631 \u0648 \u0645\u0642\u0627\u0644\u0627\u062a \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\",\"name\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"alternateName\":\"ITPIran Blog\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"width\":512,\"height\":512,\"caption\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\",\"name\":\"admin\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/en\\\/author\\\/admin\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Creating a Basic User Interface with ReactJS - ITPiran Blog","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.itpiran.net\/blog\/en\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/","og_locale":"en_US","og_type":"article","og_title":"\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u067e\u0627\u06cc\u0647 \u0628\u0627 ReactJS - \u0628\u0644\u0627\u06af ITPiran","og_description":"\u0645\u0642\u062f\u0645\u0647 \u0645\u0627 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0686\u062a \u0633\u0627\u062f\u0647 \u0628\u0627 ReactJS \u0628\u0631 \u0627\u0633\u0627\u0633 \u0633\u0631\u0648\u0631\u06cc \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645\u060c \u062e\u0648\u0627\u0647\u06cc\u0645&hellip;","og_url":"https:\/\/www.itpiran.net\/blog\/en\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/","og_site_name":"\u0628\u0644\u0627\u06af ITPiran","article_published_time":"2024-02-13T12:36:30+00:00","og_image":[{"width":1793,"height":1110,"url":"https:\/\/cdn.itpiran.net\/2024\/02\/13160535\/React2.jpg","type":"image\/jpeg"}],"author":"admin","twitter_card":"summary_large_image","twitter_misc":{"Written by":"admin","Est. reading time":"3 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/#article","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/"},"author":{"name":"admin","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81"},"headline":"\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u067e\u0627\u06cc\u0647 \u0628\u0627 ReactJS","datePublished":"2024-02-13T12:36:30+00:00","mainEntityOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/"},"wordCount":118,"commentCount":0,"publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/02\/13160535\/React2.jpg","keywords":["React.js"],"articleSection":["\u0622\u0645\u0648\u0632\u0634\u06cc","\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/","url":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/","name":"Creating a Basic User Interface with ReactJS - ITPiran Blog","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/#primaryimage"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/02\/13160535\/React2.jpg","datePublished":"2024-02-13T12:36:30+00:00","breadcrumb":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/#primaryimage","url":"https:\/\/cdn.itpiran.net\/2024\/02\/13160535\/React2.jpg","contentUrl":"https:\/\/cdn.itpiran.net\/2024\/02\/13160535\/React2.jpg","width":1793,"height":1110},{"@type":"BreadcrumbList","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/real-time-apps-with-go-and-reactjs-basic-reactjs-ui\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.itpiran.net\/blog\/"},{"@type":"ListItem","position":2,"name":"\u0622\u0645\u0648\u0632\u0634\u06cc","item":"https:\/\/www.itpiran.net\/blog\/category\/tutorials\/"},{"@type":"ListItem","position":3,"name":"\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u067e\u0627\u06cc\u0647 \u0628\u0627 ReactJS"}]},{"@type":"WebSite","@id":"https:\/\/www.itpiran.net\/blog\/#website","url":"https:\/\/www.itpiran.net\/blog\/","name":"ITPiran Blog","description":"Iranian Sustainable Trade News and Articles","publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.itpiran.net\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/www.itpiran.net\/blog\/#organization","name":"Sustainable Iranian Business Blog","alternateName":"ITPIran Blog","url":"https:\/\/www.itpiran.net\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","contentUrl":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","width":512,"height":512,"caption":"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81","name":"admin","url":"https:\/\/www.itpiran.net\/blog\/en\/author\/admin\/"}]}},"_links":{"self":[{"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/posts\/14745","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/comments?post=14745"}],"version-history":[{"count":1,"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/posts\/14745\/revisions"}],"predecessor-version":[{"id":14747,"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/posts\/14745\/revisions\/14747"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/media\/14746"}],"wp:attachment":[{"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/media?parent=14745"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/categories?post=14745"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/en\/wp-json\/wp\/v2\/tags?post=14745"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}