{"id":2321,"date":"2022-01-26T10:17:24","date_gmt":"2022-01-26T10:17:24","guid":{"rendered":"https:\/\/lvboard.infostore.in.ua\/?p=2321"},"modified":"2022-01-26T10:17:24","modified_gmt":"2022-01-26T10:17:24","slug":"%d0%ba%d0%b0%d0%ba-%d1%80%d0%b0%d0%b1%d0%be%d1%82%d0%b0%d0%b5%d1%82-react-%d0%bf%d0%be%d0%b4%d1%80%d0%be%d0%b1%d0%bd%d0%be%d0%b5-%d1%80%d1%83%d0%ba%d0%be%d0%b2%d0%be%d0%b4%d1%81%d1%82%d0%b2%d0%be","status":"publish","type":"post","link":"https:\/\/lvboard.infostore.in.ua\/?p=2321","title":{"rendered":"\u041a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 React: \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0435 \u0440\u0443\u043a\u043e\u0432\u043e\u0434\u0441\u0442\u0432\u043e"},"content":{"rendered":"\n<p>\u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043f\u043e\u043a\u0430\u0436\u0443 \u0432\u0430\u043c, \u0441 \u0447\u0435\u0433\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f <code>React<\/code>.<\/p>\n\n\n\n<!--more-->\n\n\n\n<p>\u0427\u0442\u043e \u044d\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442? \u042d\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442, \u0447\u0442\u043e \u043c\u044b \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0430\u0435\u043c \u043c\u0438\u043d\u0438-\u0432\u0435\u0440\u0441\u0438\u044e <code>React<\/code>, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0441\u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u043a\u043e\u0434:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>import '..\/style.scss'\nimport MyReact from '.\/my-react'\n\nconst buttonStyles = {\n border: 'none',\n outline: 'none',\n padding: '0.3rem 0.5rem',\n marginLeft: '0.5rem',\n backgroundImage: 'linear-gradient(yellow, orange)',\n borderRadius: '2px',\n boxShadow: '0 1px 2px rgba(0, 0, 0, 0.2)',\n cursor: 'pointer'\n}\n\n\/** @jsx MyReact.createElement *\/\nfunction Counter() {\n const &#91;value, setValue] = MyReact.useState(1)\n const &#91;count, setCount] = MyReact.useState(1)\n\n return (\n   &lt;section&gt;\n     &lt;h1 className='title'&gt;Hello from MyReact!&lt;\/h1&gt;\n     &lt;div className='box'&gt;\n       &lt;input\n         style='width: 80px; padding: 0.15rem 0.5rem;'\n         type='number'\n         value={value}\n         onInput={(e) =&gt; {\n           setValue(Number(e.target.value))\n         }}\n       \/&gt;\n       &lt;button\n         style={buttonStyles}\n         onClick={() =&gt; {\n           setCount((count) =&gt; count + value)\n         }}\n       &gt;\n         Increment\n       &lt;\/button&gt;\n     &lt;\/div&gt;\n     &lt;h2 className='subtitle'&gt;\n       Count: &lt;span className='count-value'&gt;{count}&lt;\/span&gt;\n     &lt;\/h2&gt;\n     &lt;ul className='list'&gt;\n       {&#91;'React', 'from', 'scratch'].map((item) =&gt; (\n         &lt;li&gt;{item}&lt;\/li&gt;\n       ))}\n     &lt;\/ul&gt;\n   &lt;\/section&gt;\n )\n}\n\nMyReact.render(&lt;Counter \/&gt;, document.getElementById('app'))<\/code><\/pre>\n\n\n\n<p>\u041a\u0430\u043a \u0432\u044b \u043c\u043e\u0433\u043b\u0438 \u0434\u043e\u0433\u0430\u0434\u0430\u0442\u044c\u0441\u044f, \u043d\u0430\u0448\u0430 \u0432\u0435\u0440\u0441\u0438\u044f \u0431\u0443\u0434\u0435\u0442 \u043d\u0430\u0437\u044b\u0432\u0430\u0442\u044c\u0441\u044f <code>MyReact<\/code>.<\/p>\n\n\n\n<p><a href=\"https:\/\/github.com\/harryheman\/Blog-Posts\/tree\/master\/react-clone\">\u0418\u0441\u0445\u043e\u0434\u043d\u044b\u0439 \u043a\u043e\u0434 \u043f\u0440\u043e\u0435\u043a\u0442\u0430<\/a>.<\/p>\n\n\n\n<p>\u0421\u043a\u0440\u0438\u043d\u0448\u043e\u0442:<\/p>\n\n\n\n<figure class=\"wp-block-image\"><img src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/ba\/bq\/ue\/babque1vl1xr_ib8fsbn4275fzs.png\" alt=\"\"\/><\/figure>\n\n\n\n<p><strong>\u041f\u0435\u0441\u043e\u0447\u043d\u0438\u0446\u0430:<\/strong> https:\/\/embedd.srv.habr.com\/iframe\/618136d94615593b75e246da<\/p>\n\n\n\n<p>\u041f\u0440\u0438 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0435 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u043f\u0440\u0438\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c\u0441\u044f \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u044b <a href=\"https:\/\/github.com\/facebook\/react\/tree\/main\/packages\/react\"><code>\u0438\u0441\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430 React<\/code><\/a>. \u0412\u043c\u0435\u0441\u0442\u0435 \u0441 \u0442\u0435\u043c, \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u043e\u0442\u043c\u0435\u0442\u0438\u0442\u044c, \u0447\u0442\u043e \u0437\u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0435 2 \u0433\u043e\u0434\u0430 \u0438\u0441\u0445\u043e\u0434\u043d\u044b\u0439 \u043a\u043e\u0434 <code>React<\/code> \u043f\u0440\u0435\u0442\u0435\u0440\u043f\u0435\u043b \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0432\u0435\u0449\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c, \u043f\u043e\u043c\u0435\u0447\u0435\u043d\u044b \u0432 \u043d\u0435\u043c \u043a\u0430\u043a <code>legacy<\/code>. \u041d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u044d\u0442\u043e, \u043e\u0431\u0449\u0438\u0435 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u044b \u0438 \u043f\u043e\u0434\u0445\u043e\u0434\u044b \u043e\u0441\u0442\u0430\u044e\u0442\u0441\u044f \u043f\u0440\u0435\u0436\u043d\u0438\u043c\u0438.<a><\/a><\/p>\n\n\n\n<p>\u041e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u043e\u043c \u0432\u0434\u043e\u0445\u043d\u043e\u0432\u0435\u043d\u0438\u044f \u0434\u043b\u044f \u043c\u0435\u043d\u044f \u043f\u043e\u0441\u043b\u0443\u0436\u0438\u043b\u0430 <a href=\"https:\/\/pomb.us\/build-your-own-react\/\">\u044d\u0442\u0430 \u0437\u0430\u043c\u0435\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u0441\u0442\u0430\u0442\u044c\u044f<\/a>.<\/p>\n\n\n\n<p>\u0412 \u043a\u043e\u043d\u0446\u0435 \u0441\u0442\u0430\u0442\u044c\u0438 \u044f \u043f\u043e\u043a\u0430\u0436\u0443 \u0432\u0430\u043c, \u043a\u0430\u043a \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043f\u0440\u043e\u0435\u043a\u0442, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f <a href=\"https:\/\/learn.javascript.ru\/modules\"><code>ES6-\u043c\u043e\u0434\u0443\u043b\u0438<\/code><\/a> \u0438 <a href=\"https:\/\/learn.javascript.ru\/modules\"><code>SASS<\/code><\/a> \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <a href=\"https:\/\/www.snowpack.dev\/\"><code>Snowpack<\/code><\/a>.<\/p>\n\n\n\n<h2 id=\"vvedenie\">\u0412\u0432\u0435\u0434\u0435\u043d\u0438\u0435<\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code>const element = &lt;h1 title=\"hello\"&gt;Hello from MyReact!&lt;\/h1&gt;\nconst container = document.getElementById(\"root\")\nReactDOM.render(element, container)<\/code><\/pre>\n\n\n\n<p>\u0427\u0442\u043e \u0437\u0434\u0435\u0441\u044c \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442?<\/p>\n\n\n\n<p>\u041d\u0430 \u043f\u0435\u0440\u0432\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0435 \u043c\u044b \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u043c <code>React-\u044d\u043b\u0435\u043c\u0435\u043d\u0442<\/code>. \u041d\u0430 \u0432\u0442\u043e\u0440\u043e\u0439 \u2014 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0441\u0441\u044b\u043b\u043a\u0443 \u043d\u0430 <code>DOM-\u044d\u043b\u0435\u043c\u0435\u043d\u0442<\/code>. \u041d\u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0439 \u2014 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043c <code>React-\u044d\u043b\u0435\u043c\u0435\u043d\u0442<\/code> \u2014 \u043f\u043e\u043c\u0435\u0449\u0430\u0435\u043c \u0435\u0433\u043e \u0432 <code>container<\/code>.<\/p>\n\n\n\n<p>\u0417\u0430\u043c\u0435\u043d\u0438\u043c \u043a\u043e\u0434 \u043d\u0430 <code>React<\/code> \u043e\u0431\u044b\u0447\u043d\u044b\u043c <code>JavaScript<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const element = &lt;h1 title=\"hello\"&gt;Hello from MyReact!&lt;\/h1&gt;<\/code><\/pre>\n\n\n\n<p>\u041d\u0430 \u043f\u0435\u0440\u0432\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0435 \u0443 \u043d\u0430\u0441 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u044d\u043b\u0435\u043c\u0435\u043d\u0442, \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u044b\u0439 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <a href=\"https:\/\/ru.reactjs.org\/docs\/introducing-jsx.html\"><code>JSX<\/code><\/a>.<\/p>\n\n\n\n<p><code>JSX<\/code> \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 <code>JS<\/code> \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0442\u0430\u043a\u0438\u0445 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u043a\u0430\u043a <a href=\"https:\/\/babeljs.io\/\"><code>Babel<\/code><\/a>. \u0422\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f, \u043e\u0431\u044b\u0447\u043d\u043e, \u0432\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u0432 \u0441\u0435\u0431\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435: \u0437\u0430\u043c\u0435\u043d\u0430 \u043a\u043e\u0434\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u0442\u0435\u0433\u043e\u0432 \u043d\u0430 \u0432\u044b\u0437\u043e\u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>createElement<\/code>, \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u043f\u0435\u0440\u0435\u0434\u0430\u044e\u0442\u0441\u044f \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u0442\u0435\u0433\u0430 (<code>type<\/code>), \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 (<code>props<\/code>) \u0438 \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b (<code>children<\/code>). \u041f\u0440\u043e\u0446\u0435\u0441\u0441 \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 <code>JSX<\/code> \u0432 <code>JS<\/code> \u043d\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0442\u0440\u0430\u043d\u0441\u043f\u0438\u043b\u044f\u0446\u0438\u0435\u0439 (transilation).<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const element = React.createElement(\n \"h1\",\n { title: \"hello\" },\n \"Hello from MyReact!\"\n)<\/code><\/pre>\n\n\n\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u044f <code>React.createElement<\/code> \u0441\u043e\u0437\u0434\u0430\u0435\u0442 \u043e\u0431\u044a\u0435\u043a\u0442 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u044b\u0445 \u0435\u0439 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u043e\u0432. \u041d\u0435 \u0441\u0447\u0438\u0442\u0430\u044f \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u0438, \u044d\u0442\u043e \u0432\u0441\u0435, \u0447\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const element = {\n type: \"h1\",\n props: {\n   title: \"hello\",\n   children: \"Hello from MyReact!\"\n }\n}<\/code><\/pre>\n\n\n\n<p>\u0422\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u2014 \u044d\u0442\u043e \u043e\u0431\u044a\u0435\u043a\u0442 \u0441 2 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430\u043c\u0438: <code>type<\/code> \u0438 <code>props<\/code>. \u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435, <a href=\"https:\/\/github.com\/facebook\/react\/blob\/main\/packages\/react\/src\/ReactElement.js#L147\">\u0441\u0432\u043e\u0439\u0441\u0442\u0432 \u0431\u043e\u043b\u044c\u0448\u0435<\/a>, \u043d\u043e \u043d\u0430\u0441 \u043f\u043e\u043a\u0430 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0443\u044e\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u044d\u0442\u0438.<\/p>\n\n\n\n<p><code>type<\/code> \u2014 \u044d\u0442\u043e \u0441\u0442\u0440\u043e\u043a\u0430, \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u044e\u0449\u0430\u044f \u0442\u0438\u043f DOM-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u0441\u043e\u0437\u0434\u0430\u0442\u044c. \u042d\u0442\u043e \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u0442\u0435\u0433\u0430, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043f\u0435\u0440\u0435\u0434\u0430\u0435\u0442\u0441\u044f <code>document.createElement<\/code> \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f HTML-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430. \u042d\u0442\u043e \u0442\u0430\u043a\u0436\u0435 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044f, \u043e \u0447\u0435\u043c \u043c\u044b \u043f\u043e\u0433\u043e\u0432\u043e\u0440\u0438\u043c \u043f\u043e\u0437\u0436\u0435.<\/p>\n\n\n\n<p><code>props<\/code> \u2014 \u044d\u0442\u043e \u043e\u0431\u044a\u0435\u043a\u0442, \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0449\u0438\u0439 \u0432\u0441\u0435 \u043a\u043b\u044e\u0447\u0438 \u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432 <code>JSX<\/code>. \u041e\u043d \u0442\u0430\u043a\u0436\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u043e\u0435 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <code>children<\/code>.<\/p>\n\n\n\n<p>\u0412 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 <code>children<\/code> \u2014 \u044d\u0442\u043e \u0441\u0442\u0440\u043e\u043a\u0430, \u043d\u043e, \u043a\u0430\u043a \u043f\u0440\u0430\u0432\u0438\u043b\u043e, \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c \u044d\u0442\u043e\u0433\u043e \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043c\u0430\u0441\u0441\u0438\u0432 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432. \u0412\u043e\u0442 \u043f\u043e\u0447\u0435\u043c\u0443 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u2014 \u044d\u0442\u043e \u0434\u0435\u0440\u0435\u0432\u044c\u044f (tree) \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>ReactDOM.render(element, container)<\/code><\/pre>\n\n\n\n<p><code>render<\/code> \u2014 \u044d\u0442\u043e \u0442\u043e &#8220;\u043c\u0435\u0441\u0442\u043e&#8221;, \u0433\u0434\u0435 <code>React<\/code> \u0438\u0437\u043c\u0435\u043d\u044f\u0435\u0442 <code>DOM<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const node = document.createElement(element.type)\nnode&#91;\"title\"] = element.props.title<\/code><\/pre>\n\n\n\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u0443\u0437\u0435\u043b (<code>node<\/code>) (\u0432\u043e \u0438\u0437\u0431\u0435\u0436\u0430\u043d\u0438\u0435 \u043f\u0443\u0442\u0430\u043d\u0438\u0446\u044b \u044f \u0431\u0443\u0434\u0443 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u043b\u043e\u0432\u043e &#8220;\u044d\u043b\u0435\u043c\u0435\u043d\u0442&#8221; \u0434\u043b\u044f \u043e\u0431\u043e\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 <code>React<\/code>, \u0430 \u0441\u043b\u043e\u0432\u043e &#8220;\u0443\u0437\u0435\u043b&#8221; \u2014 \u0434\u043b\u044f \u043e\u0431\u043e\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 <code>DOM<\/code>) \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u0442\u0438\u043f\u0430 (<code>type<\/code>) \u2014 \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 <code>h1<\/code>.<\/p>\n\n\n\n<p>\u0417\u0430\u0442\u0435\u043c \u043c\u044b \u043f\u0440\u0438\u0441\u0432\u0430\u0438\u0432\u0430\u0435\u043c \u0443\u0437\u043b\u0443 \u0432\u0441\u0435 \u043f\u0440\u043e\u043f\u044b (<code>props<\/code>). \u0412 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0443 \u043d\u0430\u0441 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a (<code>title<\/code>).<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const text = document.createTextNode(\"\")\ntext&#91;\"nodeValue\"] = element.props.children<\/code><\/pre>\n\n\n\n<p>\u0414\u0430\u043b\u0435\u0435 \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u0443\u0437\u043b\u044b \u0434\u043b\u044f \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432. \u0412 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0443 \u043d\u0430\u0441 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u0438\u043d \u0442\u0430\u043a\u043e\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u2014 \u0441\u0442\u0440\u043e\u043a\u0430. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u0439 \u0443\u0437\u0435\u043b.<\/p>\n\n\n\n<p>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 <code>nodeValue<\/code> \u0432\u043c\u0435\u0441\u0442\u043e <code>innerText<\/code> \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442 \u043d\u0430\u043c \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u0432\u0441\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b. \u041e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435, \u0447\u0442\u043e \u043c\u044b \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c <code>nodeValue<\/code> \u0442\u0430\u043a, \u043a\u0430\u043a \u0435\u0441\u043b\u0438 \u0431\u044b \u0441\u0442\u0440\u043e\u043a\u0430 \u0438\u043c\u0435\u043b\u0430 <code>props: { nodeValue: \"Hello from MyReact!\" }<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>node.append(text)\ncontainer.append(node)<\/code><\/pre>\n\n\n\n<p>\u041d\u0430\u043a\u043e\u043d\u0435\u0446, \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c <code>textNode<\/code> \u0432 <code>h1<\/code>, \u0430 <code>h1<\/code> \u0432 <code>container<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const element = {\n type: \"h1\",\n props: {\n   title: \"hello\",\n   children: \"Hello from MyReact!\"\n }\n}\n\nconst container = document.getElementById(\"root\")\n\nconst node = document.createElement(element.type)\nnode&#91;\"title\"] = element.props.title\n\nconst text = document.createTextNode(\"\")\ntext&#91;\"nodeValue\"] = element.props.children\n\nnode.append(text)\ncontainer.append(node)<\/code><\/pre>\n\n\n\n<p>\u041d\u0430 \u0432\u044b\u0445\u043e\u0434\u0435 \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u044b\u0439 \u043a\u043e\u0434, \u043d\u043e \u0431\u0435\u0437 <code>React<\/code>.<\/p>\n\n\n\n<h2 id=\"funkciya-createelement\">\u0424\u0443\u043d\u043a\u0446\u0438\u044f <code>createElement<\/code><\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code>const element = (\n &lt;section id=\"welcome\"&gt;\n   &lt;h1 title=\"hello\" className=\"title\"&gt;Hello from MyReact!&lt;\/h1&gt;\n   &lt;p style=\"color: green;\"&gt;&lt;span&gt;React&lt;\/span&gt; from scratch&lt;\/p&gt;\n &lt;\/section&gt;\n)\nconst container = document.getElementById(\"root\")\nReactDOM.render(element, container)<\/code><\/pre>\n\n\n\n<p>\u041f\u0440\u0438\u0441\u0442\u0443\u043f\u0438\u043c \u043a \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>createElement<\/code>.<\/p>\n\n\n\n<p>\u0415\u0441\u043b\u0438 \u043c\u044b \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u043c <code>JSX<\/code> \u0432 <code>JS<\/code>, \u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const element = React.createElement(\n \"section\",\n { id: \"welcome\" },\n React.createElement(\n   \"h1\",\n   { title: \"hello\", className: \"title\" },\n   \"Hello from MyReact!\"\n ),\n React.createElement(\n   \"p\",\n   { style: \"color: green;\" },\n   React.createElement(\n     \"span\",\n     null,\n     \"React\"\n   )\n   \" from scratch\"\n )\n)<\/code><\/pre>\n\n\n\n<p>\u041a\u0430\u043a \u043c\u044b \u0432\u044b\u044f\u0441\u043d\u0438\u043b\u0438, \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u2014 \u044d\u0442\u043e \u043e\u0431\u044a\u0435\u043a\u0442 \u0441 <code>type<\/code> \u0438 <code>props<\/code>. \u0421\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e, \u043d\u0430\u0448\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u0434\u043e\u043b\u0436\u043d\u0430 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u0442\u0430\u043a\u0438\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u044b.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function createElement(type, props, ...children) {\n return {\n   type,\n   props: {\n     ...props,\n     children,\n   }\n }\n}<\/code><\/pre>\n\n\n\n<p>\u041c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u044b <code>spread<\/code> \u0434\u043b\u044f <code>props<\/code> \u0438 <a href=\"https:\/\/learn.javascript.ru\/rest-parameters-spread-operator\"><code>rest<\/code><\/a> \u0434\u043b\u044f <code>children<\/code> (\u043f\u043e\u044d\u0442\u043e\u043c\u0443 <code>children<\/code> \u0432\u0441\u0435\u0433\u0434\u0430 \u0431\u0443\u0434\u0435\u0442 \u043c\u0430\u0441\u0441\u0438\u0432\u043e\u043c).<\/p>\n\n\n\n<p><code>createElement(\"section\")<\/code> \u0432\u0435\u0440\u043d\u0435\u0442:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>{\n type: \"section\",\n props: {\n   children: &#91;]\n }\n}<\/code><\/pre>\n\n\n\n<p><code>createElement(\"section\", null, \"hello\")<\/code> \u0432\u0435\u0440\u043d\u0435\u0442:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>{\n type: \"section\",\n props: {\n   children: &#91;\"hello\"]\n }\n}<\/code><\/pre>\n\n\n\n<p><code>createElement(\"section\", { title: \"hello\" }, \"hello\", \"world\")<\/code> \u0432\u0435\u0440\u043d\u0435\u0442:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>{\n type: \"section\",\n props: {\n   title: \"hello\",\n   children: &#91;\n     \"hello\",\n     \"world\"\n   ]\n }\n}<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code\"><code>function createElement(type, props, ...children) {\n return {\n   type,\n   props: {\n     ...props,\n     \/\/ ! - \u0437\u0434\u0435\u0441\u044c \u0438 \u0434\u0430\u043b\u0435\u0435 \u0442\u0430\u043a \u0431\u0443\u0434\u0443\u0442 \u043e\u0442\u043c\u0435\u0447\u0435\u043d\u044b \u0432\u043d\u043e\u0441\u0438\u043c\u044b\u0435 \u0432 \u043a\u043e\u0434 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f\n     children: children.map(child =&gt;\n       typeof child === \"object\"\n         ? child\n         : createTextElement(child)\n     )\n   }\n }\n}\n\nfunction createTextElement(nodeValue) {\n return {\n   type: \"TEXT_ELEMENT\",\n   props: {\n     nodeValue,\n     children: &#91;]\n   }\n }\n}<\/code><\/pre>\n\n\n\n<p>\u041c\u0430\u0441\u0441\u0438\u0432 <code>children<\/code> \u043c\u043e\u0436\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043d\u044b\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f, \u0442\u0430\u043a\u0438\u0435 \u043a\u0430\u043a \u0441\u0442\u0440\u043e\u043a\u0438 \u0438\u043b\u0438 \u0447\u0438\u0441\u043b\u0430. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0434\u043b\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0441 \u0442\u0438\u043f\u043e\u043c, \u043e\u0442\u043b\u0438\u0447\u0430\u044e\u0449\u0438\u043c\u0441\u044f \u043e\u0442 \u043e\u0431\u044a\u0435\u043a\u0442\u0430, \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f, \u0441\u043e\u0437\u0434\u0430\u044e\u0449\u0430\u044f \u043e\u0441\u043e\u0431\u044b\u0439 \u0442\u0438\u043f \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430: <code>TEXT_ELEMENT<\/code>.<\/p>\n\n\n\n<p><code>React<\/code> \u043d\u0435 \u043e\u0431\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u0442 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u044b \u0438 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 \u043f\u0443\u0441\u0442\u044b\u0435 \u043c\u0430\u0441\u0441\u0438\u0432\u044b \u043f\u0440\u0438 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0438\u0438 <code>children<\/code>. \u041c\u044b \u0436\u0435\u0440\u0442\u0432\u0443\u0435\u043c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c\u044e \u0440\u0430\u0434\u0438 \u043f\u0440\u043e\u0441\u0442\u043e\u0442\u044b \u043a\u043e\u0434\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const MyReact = {\n createElement\n}\n\nconst element = MyReact.createElement(\n \"section\",\n { id: \"welcome\" },\n MyReact.createElement(\n   \"h1\",\n   { title: \"hello\", className: \"title\" },\n   \"Hello from MyReact!\"\n ),\n MyReact.createElement(\n   \"p\",\n   { style: \"color: green;\" },\n   MyReact.createElement(\n     \"span\",\n     null,\n     \"React\"\n   )\n   \" from scratch\"\n )\n)<\/code><\/pre>\n\n\n\n<p>\u0417\u0430\u043c\u0435\u043d\u044f\u0435\u043c <code>React<\/code> \u043d\u0430 <code>MyReact<\/code>.<\/p>\n\n\n\n<p>\u0414\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0438\u043c\u0435\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>JSX<\/code>, \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0443\u043a\u0430\u0437\u0430\u0442\u044c <code>Babel<\/code> \u043f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0442\u044c \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 <code>JSX<\/code> \u0432 \u043d\u0430\u0448\u0443 \u0444\u0443\u043d\u043a\u0446\u0438\u044e <code>createElement<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/** @jsx MyReact.createElement *\/\nconst element = (\n &lt;section id=\"welcome\"&gt;\n   &lt;h1 title=\"hello\" className=\"title\"&gt;Hello from MyReact!&lt;\/h1&gt;\n   &lt;p style=\"color: green;\"&gt;&lt;span&gt;React&lt;\/span&gt; from scratch&lt;\/p&gt;\n &lt;\/section&gt;\n)<\/code><\/pre>\n\n\n\n<p>\u041a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0439 <code>\/** @jsx MyReact.createElement *\/<\/code> \u0441\u043e\u043e\u0431\u0449\u0430\u0435\u0442 <code>Babel<\/code> \u043e \u043d\u0430\u0448\u0435\u043c \u0436\u0435\u043b\u0430\u043d\u0438\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e <code>createElement<\/code> \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432.<\/p>\n\n\n\n<h2 id=\"funkciya-render\">\u0424\u0443\u043d\u043a\u0446\u0438\u044f <code>render<\/code><\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code>ReactDOM.render(element, container)<\/code><\/pre>\n\n\n\n<p>\u0414\u0430\u043b\u0435\u0435 \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <a href=\"https:\/\/github.com\/facebook\/react\/blob\/main\/packages\/react-dom\/src\/client\/ReactDOMLegacy.js#L266\"><code>ReactDOM.render<\/code><\/a>.<\/p>\n\n\n\n<p>\u041c\u044b \u043d\u0430\u0447\u043d\u0435\u043c \u0441 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0443\u0437\u043b\u043e\u0432 \u0432 <code>DOM<\/code>, \u0430 \u0438\u0445 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043f\u043e\u0437\u0436\u0435.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function render(element, container) {\n const node = document.createElement(element.type)\n\u200b\n container.append(node)\n}<\/code><\/pre>\n\n\n\n<p>\u0421\u043e\u0437\u0434\u0430\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u0443\u0437\u0435\u043b \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u0442\u0438\u043f\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0435\u0433\u043e \u0432 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function render(element, container) {\n const node = document.createElement(element.type)\n\u200b\n \/\/ !\n element.props.children.forEach(child =&gt;\n   render(child, node)\n )\n\u200b\n container.appendChild(node)\n}<\/code><\/pre>\n\n\n\n<p>\u0417\u0430\u0442\u0435\u043c \u043c\u044b \u0434\u0435\u043b\u0430\u0435\u043c \u0442\u043e\u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u043f\u043e\u0442\u043e\u043c\u043a\u0430 \u0443\u0437\u043b\u0430 \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u043e.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function render(element, container) {\n \/\/ !\n const node =\n   element.type == \"TEXT_ELEMENT\"\n     ? document.createTextNode(\"\")\n     : document.createElement(element.type)\n\u200b\n element.props.children.forEach(child =&gt;\n   render(child, node)\n )\n\u200b\n container.appendChild(node)\n}<\/code><\/pre>\n\n\n\n<p>\u0415\u0441\u043b\u0438 \u0442\u0438\u043f\u043e\u043c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f <code>TEXT_ELEMENT<\/code>, \u0432\u043c\u0435\u0441\u0442\u043e \u043e\u0431\u044b\u0447\u043d\u043e\u0433\u043e \u0443\u0437\u043b\u0430 \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u0439.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function render(element, container) {\n const node =\n   element.type == \"TEXT_ELEMENT\"\n     ? document.createTextNode(\"\")\n     : document.createElement(element.type)\n\n \/\/ !\n const isProperty = key =&gt; key !== \"children\"\n Object.keys(element.props)\n   .filter(isProperty)\n   .forEach(key =&gt; {\n     node&#91;key] = element.props&#91;key]\n   })\n\u200b\n element.props.children.forEach(child =&gt;\n   render(child, node)\n )\n\u200b\n container.appendChild(node)\n}<\/code><\/pre>\n\n\n\n<p>\u0418 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435, \u0447\u0442\u043e \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c, \u044d\u0442\u043e \u043f\u0440\u0438\u0441\u0432\u043e\u0438\u0442\u044c \u0443\u0437\u043b\u0443 \u043f\u0440\u043e\u043f\u044b \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function createElement(type, props, ...children) {\n return {\n   type,\n   props: {\n     ...props,\n     children: children.map(child =&gt;\n       typeof child === \"object\"\n         ? child\n         : createTextElement(child)\n     )\n   }\n }\n}\n\nfunction createTextElement(nodeValue) {\n return {\n   type: \"TEXT_ELEMENT\",\n   props: {\n     nodeValue,\n     children: &#91;],\n   }\n }\n}\n\nfunction render(element, container) {\n const node =\n   element.type == \"TEXT_ELEMENT\"\n     ? document.createTextNode(\"\")\n     : document.createElement(element.type)\n\n const isProperty = key =&gt; key !== \"children\"\n Object.keys(element.props)\n   .filter(isProperty)\n   .forEach(key =&gt; {\n     node&#91;key] = element.props&#91;key]\n   })\n\u200b\n element.props.children.forEach(child =&gt;\n   render(child, node)\n )\n\u200b\n container.appendChild(node)\n}\n\nconst MyReact = {\n createElement,\n render\n}\n\n\/** @jsx MyReact.createElement *\/\nconst element = (\n &lt;section id=\"welcome\"&gt;\n   &lt;h1 title=\"hello\" className=\"title\"&gt;Hello from MyReact!&lt;\/h1&gt;\n   &lt;p style=\"color: green;\"&gt;&lt;span&gt;React&lt;\/span&gt; from scratch&lt;\/p&gt;\n &lt;\/section&gt;\n)\n\nconst container = document.getElementById(\"root\")\nMyReact.render(element, container)<\/code><\/pre>\n\n\n\n<p>\u0421\u0430\u043c\u044b\u043c \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u044d\u0442\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440 (\u0438 \u0434\u0440\u0443\u0433\u0438\u0435):<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;!-- index.html --&gt;\n\n&lt;div id=\"root\"&gt;&lt;\/div&gt;\n\n&lt;script src=\"https:\/\/unpkg.com\/@babel\/standalone\/babel.min.js\"&gt;&lt;\/script&gt;\n&lt;script type=\"text\/babel\"&gt;\n \/\/ MyReact\n&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<h2 id=\"konkurentnyy-rezhim-concurrent-mode\">\u041a\u043e\u043d\u043a\u0443\u0440\u0435\u043d\u0442\u043d\u044b\u0439 \u0440\u0435\u0436\u0438\u043c (Concurrent Mode)<\/h2>\n\n\n\n<p>\u041f\u0435\u0440\u0435\u0434 \u0442\u0435\u043c, \u043a\u0430\u043a \u043c\u044b \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u043c \u0432\u0435\u0441\u0435\u043b\u0438\u0442\u044c\u0441\u044f, \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0440\u0435\u0444\u0430\u043a\u0442\u043e\u0440\u0438\u043d\u0433 \u043a\u043e\u0434\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>element.props.children.forEach(child =&gt;\n render(child, node)\n)<\/code><\/pre>\n\n\n\n<p>\u0412 \u0447\u0435\u043c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u044d\u0442\u043e\u0433\u043e \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u043e\u0433\u043e \u0432\u044b\u0437\u043e\u0432\u0430? (\u041f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u043c, \u0447\u0442\u043e \u0432\u044b \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442\u0435 \u0441\u043e\u0431\u0435\u0441\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u0435 \u0434\u043b\u044f \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430 \u043d\u0430 \u0440\u0430\u0431\u043e\u0442\u0443 \u0432 <code>Facebook<\/code> \ud83d\ude09 )<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>   .  .\n    \\\/\n   (@@)\ng\/\\_)(_\/\\e\ng\/\\(=--=)\/\\e\n   \/\/\\\\\n  _|  |_<\/code><\/pre>\n\n\n\n<p>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043f\u043e\u0441\u043b\u0435 \u043d\u0430\u0447\u0430\u043b\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430, \u043c\u044b \u043d\u0435 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043c\u0441\u044f, \u043f\u043e\u043a\u0430 \u043d\u0435 \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043c \u0432\u0441\u0435 \u0434\u0435\u0440\u0435\u0432\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0446\u0435\u043b\u0438\u043a\u043e\u043c. \u0415\u0441\u043b\u0438 \u0442\u0430\u043a\u043e\u0435 \u0434\u0435\u0440\u0435\u0432\u043e \u0431\u043e\u043b\u044c\u0448\u043e\u0435, \u0435\u0433\u043e \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 \u043c\u043e\u0436\u0435\u0442 \u0437\u0430\u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u043f\u043e\u0442\u043e\u043a \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u044b (main thread) \u043d\u0430 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f. \u0415\u0441\u043b\u0438 \u0443 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430 \u0432 \u044d\u0442\u043e \u0432\u0440\u0435\u043c\u044f \u043f\u043e\u044f\u0432\u044f\u0442\u0441\u044f \u0432\u0430\u0436\u043d\u044b\u0435 \u0437\u0430\u0434\u0430\u0447\u0438, \u0432\u0440\u043e\u0434\u0435 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0432\u0432\u043e\u0434\u0430 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f (\u0438\u043c\u0435\u0435\u0442\u0441\u044f \u0432\u0432\u0438\u0434\u0443 \u0432\u0432\u0435\u0434\u0435\u043d\u043d\u044b\u0445 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u043c \u0434\u0430\u043d\u043d\u044b\u0445 \u043f\u0440\u0438 \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0438 \u043f\u043e\u043b\u0435\u0439 \u0444\u043e\u0440\u043c\u044b, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440) \u0438\u043b\u0438 \u043f\u043b\u0430\u0432\u043d\u043e\u0435 \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0438, \u043e\u043d \u043d\u0435 \u0441\u043c\u043e\u0436\u0435\u0442 \u044d\u0442\u043e\u0433\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0434\u043e \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>let nextUnitOfWork = null\n\u200b\nfunction workLoop(deadline) {\n while (nextUnitOfWork &amp;&amp; deadline.timeRemaining() &gt; 0) {\n   nextUnitOfWork = performUnitOfWork(nextUnitOfWork)\n }\n\n requestIdleCallback(workLoop)\n}\n\u200b\nrequestIdleCallback(workLoop)<\/code><\/pre>\n\n\n\n<p>\u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0440\u0430\u0437\u0434\u0435\u043b\u0438\u0442\u044c \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430 \u043d\u0430 \u0447\u0430\u0441\u0442\u0438. \u041f\u043e\u0441\u043b\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0447\u0430\u0441\u0442\u0438 \u043c\u044b \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0443 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0441\u0432\u043e\u0438 \u0437\u0430\u0434\u0430\u0447\u0438 (\u043f\u0440\u0438 \u043d\u0430\u043b\u0438\u0447\u0438\u0438 \u0442\u0430\u043a\u043e\u0432\u044b\u0445).<\/p>\n\n\n\n<p>\u041c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c <a href=\"https:\/\/developer.mozilla.org\/ru\/docs\/Web\/API\/Window\/requestIdleCallback\"><code>requestIdleCallback<\/code><\/a> \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430. <code>requestIdleCallback<\/code> \u043f\u043e\u0445\u043e\u0436 \u043d\u0430 <code>setTimeout<\/code>, \u043d\u043e \u0432\u043c\u0435\u0441\u0442\u043e \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0437\u0430\u0434\u0430\u0447\u0443 \u0447\u0435\u0440\u0435\u0437 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f, \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u043e\u0431\u0440\u0430\u0442\u043d\u043e\u0433\u043e \u0432\u044b\u0437\u043e\u0432\u0430 (\u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 <code>workLoop<\/code>), \u043a\u043e\u0433\u0434\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u043f\u043e\u0442\u043e\u043a \u0441\u0432\u043e\u0431\u043e\u0434\u0435\u043d \u043e\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0434\u0440\u0443\u0433\u0438\u0445 \u0437\u0430\u0434\u0430\u0447 (\u043f\u0435\u0440\u0438\u043e\u0434 \u043f\u0440\u043e\u0441\u0442\u043e\u044f \u0438\u043b\u0438 \u0440\u0435\u0436\u0438\u043c \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430 \u2014 \u043e\u0442\u0441\u044e\u0434\u0430 <code>idle<\/code>).<\/p>\n\n\n\n<p>\u0412 <code>React<\/code> \u0431\u043e\u043b\u044c\u0448\u0435 \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f <code>requestIdleCallback<\/code>. \u0422\u0435\u043f\u0435\u0440\u044c \u0442\u0430\u043c \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 <a href=\"https:\/\/github.com\/facebook\/react\/tree\/main\/packages\/scheduler\"><code>scheduler<\/code><\/a>. \u041f\u043e \u0432\u0441\u0435\u0439 \u0432\u0438\u0434\u0438\u043c\u043e\u0441\u0442\u0438, \u044d\u0442\u043e \u043e\u0431\u044a\u044f\u0441\u043d\u044f\u0435\u0442\u0441\u044f \u0442\u0435\u043c, \u0447\u0442\u043e <code>requestIdleCallback<\/code> \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u0439 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0435\u0439 \u0438 <a href=\"https:\/\/caniuse.com\/requestidlecallback\">\u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0435 \u0432\u0441\u0435\u043c\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u043c\u0438<\/a>. \u0412 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438, <code>Safari<\/code> \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 <code>requestIdleCallback<\/code> \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435.<\/p>\n\n\n\n<p>\u041f\u043e\u0434\u0441\u0442\u0440\u0430\u0445\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0430 \u0441\u043b\u0443\u0447\u0430\u0439 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0438\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 <code>requestIdleCallback<\/code> \u043c\u043e\u0436\u043d\u043e \u0442\u0430\u043a:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>window.requestIdleCallback =\n window.requestIdleCallback ||\n function (handler) {\n   const start = Date.now()\n\n   return setTimeout(() =&gt; {\n     handler({\n       didTimeout: false,\n       timeRemaining: () =&gt; Math.max(0, 50 - (Date.now() - start))\n     })\n   }, 1)\n }<\/code><\/pre>\n\n\n\n<p>\u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043e <code>requestIdleCallback<\/code> \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0447\u0438\u0442\u0430\u0442\u044c <a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/API\/Background_Tasks_API\">\u0437\u0434\u0435\u0441\u044c<\/a> \u0438 <a href=\"https:\/\/developers.google.com\/web\/updates\/2015\/08\/using-requestidlecallback\">\u0437\u0434\u0435\u0441\u044c<\/a>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function performUnitOfWork(nextUnitOfWork) {\n \/\/ TODO\n}<\/code><\/pre>\n\n\n\n<p>\u0414\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u043d\u0430\u0447\u0430\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0446\u0438\u043a\u043b, \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u043f\u0435\u0440\u0432\u0443\u044e \u0435\u0434\u0438\u043d\u0438\u0446\u0443 \u0440\u0430\u0431\u043e\u0442\u044b. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0430\u043c \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0435\u0449\u0435 \u043e\u0434\u043d\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u2014 <code>performUnitOfWork<\/code>, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442 \u0442\u0435\u043a\u0443\u0449\u0443\u044e \u0435\u0434\u0438\u043d\u0438\u0446\u0443 \u0440\u0430\u0431\u043e\u0442\u044b, \u043d\u043e \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e.<\/p>\n\n\n\n<h2 id=\"volokno-fiber\">\u0412\u043e\u043b\u043e\u043a\u043d\u043e (Fiber)<\/h2>\n\n\n\n<p>\u0414\u043b\u044f \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u0438 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043c\u0435\u0436\u0434\u0443 \u0435\u0434\u0438\u043d\u0438\u0446\u0430\u043c\u0438 \u0440\u0430\u0431\u043e\u0442\u044b \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u0430 \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0430\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0434\u0430\u043d\u043d\u044b\u0445. \u041e\u0434\u043d\u043e\u0439 \u0438\u0437 \u0442\u0430\u043a\u0438\u0445 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f <code>fiber tree<\/code> (\u0443\u0441\u043b\u043e\u0432\u043d\u043e \u043c\u043e\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u043a\u0430\u043a &#8220;\u0434\u0440\u0435\u0432\u0435\u0441\u043d\u043e\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e&#8221;).<\/p>\n\n\n\n<p>\u0423 \u043d\u0430\u0441 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u043e \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0438 \u043a\u0430\u0436\u0434\u043e\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u043e\u0431\u043e\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u0443 \u0440\u0430\u0431\u043e\u0442\u044b.<\/p>\n\n\n\n<p>\u0420\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043d\u0430 \u043f\u0440\u0438\u043c\u0435\u0440\u0435.<\/p>\n\n\n\n<figure class=\"wp-block-image\"><img src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/nz\/c0\/e2\/nzc0e2rr7omhkxuadfm2i23almm.png\" alt=\"\"\/><\/figure>\n\n\n\n<p><br>\u041f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u0447\u0442\u043e \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c \u0442\u0430\u043a\u043e\u0435 \u0434\u0435\u0440\u0435\u0432\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>MyReact.render(\n &lt;section&gt;\n   &lt;h1&gt;\n     &lt;p&gt;&lt;\/p&gt;\n     &lt;a&gt;&lt;\/a&gt;\n   &lt;\/h1&gt;\n   &lt;h2&gt;&lt;\/h2&gt;\n &lt;\/section&gt;,\n container\n)<\/code><\/pre>\n\n\n\n<p>\u0412 \u043c\u0435\u0442\u043e\u0434\u0435 <code>render<\/code> \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e (root fiber) \u0438 \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u0435\u0433\u043e \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 <code>nextUnitOfWork<\/code>. \u041e\u0441\u0442\u0430\u043b\u044c\u043d\u0430\u044f \u0440\u0430\u0431\u043e\u0442\u0430 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f \u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>performUnitOfWork<\/code>. \u0422\u0430\u043c \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 3 \u0432\u0435\u0449\u0438:<\/p>\n\n\n\n<ol><li>\u0414\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0432 <code>DOM<\/code><\/li><li>\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0432\u043e\u043b\u043e\u043a\u043e\u043d \u0434\u043b\u044f \u043f\u043e\u0442\u043e\u043c\u043a\u043e\u0432 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430<\/li><li>\u0412\u044b\u0431\u043e\u0440 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u044b \u0440\u0430\u0431\u043e\u0442\u044b<\/li><\/ol>\n\n\n\n<figure class=\"wp-block-image\"><img src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/9i\/n_\/un\/9in_unu7qyjhug2p8y81pjggram.png\" alt=\"\"\/><\/figure>\n\n\n\n<p>\u041e\u0434\u043d\u043e\u0439 \u0438\u0437 \u0437\u0430\u0434\u0430\u0447 \u044d\u0442\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0443\u043f\u0440\u043e\u0449\u0435\u043d\u0438\u0435 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u044b \u0440\u0430\u0431\u043e\u0442\u044b. \u0412\u043e\u0442 \u043f\u043e\u0447\u0435\u043c\u0443 \u043a\u0430\u0436\u0434\u043e\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u0438\u043c\u0435\u0435\u0442 \u0441\u0441\u044b\u043b\u043a\u0438 \u043d\u0430 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u043f\u043e\u0442\u043e\u043c\u043a\u0430 (<code>child<\/code>), <a href=\"https:\/\/ru.wikipedia.org\/wiki\/%D0%A1%D0%B8%D0%B1%D0%BB%D0%B8%D0%BD%D0%B3%D0%B8\">\u0441\u0438\u0431\u043b\u0438\u043d\u0433\u0430<\/a> (<code>sibling<\/code>) \u0438 \u043f\u0440\u0435\u0434\u043a\u0430 (<code>parent<\/code>).<\/p>\n\n\n\n<p>\u041f\u043e\u0441\u043b\u0435 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0432\u043e\u043b\u043e\u043a\u043d\u0430, \u0435\u0441\u043b\u0438 \u0443 \u043d\u0435\u0433\u043e \u0435\u0441\u0442\u044c <code>child<\/code>, \u043e\u043d \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u0435\u0439 \u0440\u0430\u0431\u043e\u0442\u044b.<\/p>\n\n\n\n<p>\u0412 \u043d\u0430\u0448\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440\u0435 \u043f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043c\u044b \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u043b\u0438 \u0441 <code>section<\/code>, \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u0435\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f <code>h1<\/code>.<\/p>\n\n\n\n<p>\u0415\u0441\u043b\u0438 \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u043d\u0435 \u0438\u043c\u0435\u0435\u0442 <code>child<\/code>, \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u0435\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f <code>sibling<\/code>.<\/p>\n\n\n\n<p>\u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0432\u043e\u043b\u043e\u043a\u043d\u043e <code>p<\/code> \u043d\u0435 \u0438\u043c\u0435\u0435\u0442 <code>child<\/code>, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u0435\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f <code>a<\/code>.<\/p>\n\n\n\n<p>\u041d\u0430\u043a\u043e\u043d\u0435\u0446, \u0435\u0441\u043b\u0438 \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u043d\u0435 \u0438\u043c\u0435\u0435\u0442 \u043d\u0438 <code>child<\/code>, \u043d\u0438 <code>sibling<\/code>, \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u0435\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f <code>sibling<\/code> \u043f\u0440\u0435\u0434\u043a\u0430 \u0432\u043e\u043b\u043e\u043a\u043d\u0430 (<code>parent<\/code>).<\/p>\n\n\n\n<p>\u0415\u0441\u043b\u0438 <code>parent<\/code> \u043d\u0435 \u0438\u043c\u0435\u0435\u0442 <code>sibling<\/code>, \u043c\u044b \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u043c\u0441\u044f \u043a \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c\u0443 <code>parent<\/code> \u0438 \u0442\u0430\u043a \u0434\u043e \u0442\u0435\u0445 \u043f\u043e\u0440, \u043f\u043e\u043a\u0430 \u043d\u0435 \u0434\u043e\u0441\u0442\u0438\u0433\u043d\u0435\u043c \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0433\u043e \u0432\u043e\u043b\u043e\u043a\u043d\u0430. \u0415\u0441\u043b\u0438 \u043c\u044b \u0434\u043e\u0441\u0442\u0438\u0433\u043b\u0438 \u0442\u0430\u043a\u043e\u0433\u043e \u0432\u043e\u043b\u043e\u043a\u043d\u0430, \u0437\u043d\u0430\u0447\u0438\u0442, \u0440\u0430\u0431\u043e\u0442\u0430 \u0434\u043b\u044f \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430 <code>render<\/code> \u0437\u0430\u043a\u043e\u043d\u0447\u0435\u043d\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function createNode(fiber) {\n const node =\n   fiber.type == \"TEXT_ELEMENT\"\n     ? document.createTextNode(\"\")\n     : document.createElement(fiber.type)\n\u200b\n const isProperty = key =&gt; key !== \"children\"\n Object.keys(fiber.props)\n   .filter(isProperty)\n   .forEach(key =&gt; {\n     node&#91;key] = fiber.props&#91;key]\n   })\n\u200b\n return node\n}\n\nfunction render(element, container) {\n \/\/ TODO\n}<\/code><\/pre>\n\n\n\n<p>\u0412\u044b\u043d\u0435\u0441\u0435\u043c \u043a\u043e\u0434 \u043f\u043e \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e \u0443\u0437\u043b\u043e\u0432 \u0438\u0437 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>render<\/code> \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0443\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e, \u043e\u043d \u043f\u0440\u0438\u0433\u043e\u0434\u0438\u0442\u0441\u044f \u043d\u0430\u043c \u043f\u043e\u0437\u0436\u0435.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function render(element, container) {\n nextUnitOfWork = {\n   node: container,\n   props: {\n     children: &#91;element]\n   }\n }\n}<\/code><\/pre>\n\n\n\n<p>\u0412 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>render<\/code> \u043c\u044b \u043f\u0440\u0438\u0441\u0432\u0430\u0438\u0432\u0430\u0435\u043c <code>nextUnitOfWork<\/code> \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0439 \u0443\u0437\u0435\u043b <code>fiber tree<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>nextUnitOfWork = performUnitOfWork(\n nextUnitOfWork\n)<\/code><\/pre>\n\n\n\n<p>\u041a\u043e\u0433\u0434\u0430 \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u0431\u0443\u0434\u0435\u0442 \u0433\u043e\u0442\u043e\u0432, \u043e\u043d \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442 &#8220;\u043a\u043e\u043b\u0431\u0435\u043a&#8221; <code>workLoop<\/code> \u0438 \u043d\u0430\u0447\u043d\u0435\u0442\u0441\u044f \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0433\u043e \u0443\u0437\u043b\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function performUnitOfWork(fiber) {\n if (!fiber.node) {\n   fiber.node = createNode(fiber)\n }\n\u200b\n if (fiber.parent) {\n   fiber.parent.node.append(fiber.node)\n }\n}<\/code><\/pre>\n\n\n\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u0443\u0437\u0435\u043b \u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0435\u0433\u043e \u0432 <code>DOM<\/code>.<\/p>\n\n\n\n<p>\u0423\u0437\u043b\u044b \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u0441\u044f \u0432 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0435 <code>fiber.node<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const elements = fiber.props.children\nlet index = 0\nlet prevSibling = null\n\u200b\nwhile (index &lt; elements.length) {\n const element = elements&#91;index]\n\u200b\n const newFiber = {\n   type: element.type,\n   props: element.props,\n   parent: fiber,\n   node: null\n }\n}<\/code><\/pre>\n\n\n\n<p>\u0417\u0430\u0442\u0435\u043c \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u043f\u043e\u0442\u043e\u043c\u043a\u0430 \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f \u0432\u043e\u043b\u043e\u043a\u043d\u043e.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const elements = fiber.props.children\nlet index = 0\nlet prevSibling = null\n\u200b\nwhile (index &lt; elements.length) {\n const element = elements&#91;index]\n\u200b\n const newFiber = {\n   type: element.type,\n   props: element.props,\n   parent: fiber,\n   node: null,\n }\n\u200b\n \/\/ !\n \/\/ \u043f\u0435\u0440\u0432\u044b\u0439 \u043f\u043e\u0442\u043e\u043c\u043e\u043a?\n if (index === 0) {\n   \/\/ \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e \u043f\u0440\u0435\u0434\u043a\u0430\n   fiber.child = newFiber\n } else {\n   \/\/ \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e \u0442\u0435\u043a\u0443\u0449\u0435\u0433\u043e \u0432\u043e\u043b\u043e\u043a\u043d\u0430\n   prevSibling.sibling = newFiber\n }\n\u200b\n prevSibling = newFiber\n index++\n}<\/code><\/pre>\n\n\n\n<p>\u041d\u043e\u0432\u043e\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0432 <code>fiber tree<\/code> \u043b\u0438\u0431\u043e \u043a\u0430\u043a <code>child<\/code>, \u0435\u0441\u043b\u0438 \u043e\u043d\u043e \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u0435\u0440\u0432\u044b\u043c \u043f\u043e\u0442\u043e\u043c\u043a\u043e\u043c, \u043b\u0438\u0431\u043e \u043a\u0430\u043a <code>sibling<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const elements = fiber.props.children\nlet index = 0\nlet prevSibling = null\n\u200b\nwhile (index &lt; elements.length) {\n const element = elements&#91;index]\n\u200b\n const newFiber = {\n   type: element.type,\n   props: element.props,\n   parent: fiber,\n   node: null,\n }\n\u200b\n if (index === 0) {\n   fiber.child = newFiber\n } else {\n   prevSibling.sibling = newFiber\n }\n\u200b\n prevSibling = newFiber\n index++\n}\n\n\/\/ !\n\/\/ \u0435\u0441\u0442\u044c \u043f\u043e\u0442\u043e\u043c\u043e\u043a?\nif (fiber.child) {\n return fiber.child\n}\n\nlet nextFiber = fiber\nwhile (nextFiber) {\n \/\/ \u0435\u0441\u0442\u044c \u0441\u0438\u0431\u043b\u0438\u043d\u0433?\n if (nextFiber.sibling) {\n   return nextFiber.sibling\n }\n\n \/\/ \u0441\u043f\u0440\u043e\u0441\u0438\u043c \u0443 \u043f\u0440\u0435\u0434\u043a\u0430\n nextFiber = nextFiber.parent\n}<\/code><\/pre>\n\n\n\n<p>\u041d\u0430\u043a\u043e\u043d\u0435\u0446, \u043c\u044b \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u043c \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u0435\u0434\u0438\u043d\u0438\u0446\u0443 \u0440\u0430\u0431\u043e\u0442\u044b. \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043c\u044b \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c \u043f\u043e\u0442\u043e\u043c\u043a\u0430. \u0415\u0441\u043b\u0438 \u043f\u043e\u0442\u043e\u043c\u043e\u043a \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442, \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442\u0441\u044f \u0441\u0438\u0431\u043b\u0438\u043d\u0433. \u0415\u0441\u043b\u0438 \u0441\u0438\u0431\u043b\u0438\u043d\u0433\u0430 \u043d\u0435\u0442, \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u043c\u0441\u044f \u043a \u043f\u0440\u0435\u0434\u043a\u0443 \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c \u0435\u0433\u043e \u0441\u0438\u0431\u043b\u0438\u043d\u0433\u0430 \u0438 \u0442.\u0434.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function performUnitOfWork(fiber) {\n if (!fiber.node) {\n   fiber.node = createNode(fiber)\n }\n\u200b\n if (fiber.parent) {\n   fiber.parent.node.append(fiber.node)\n }\n\n const elements = fiber.props.children\n let index = 0\n let prevSibling = null\n \u200b\n while (index &lt; elements.length) {\n   const element = elements&#91;index]\n \u200b\n   const newFiber = {\n     type: element.type,\n     props: element.props,\n     parent: fiber,\n     node: null,\n   }\n \u200b\n   if (index === 0) {\n     fiber.child = newFiber\n   } else {\n     prevSibling.sibling = newFiber\n   }\n \u200b\n   prevSibling = newFiber\n   index++\n }\n\n if (fiber.child) {\n   return fiber.child\n }\n\n let nextFiber = fiber\n while (nextFiber) {\n   if (nextFiber.sibling) {\n     return nextFiber.sibling\n   }\n\n   nextFiber = nextFiber.parent\n }\n}<\/code><\/pre>\n\n\n\n<p>\u0412\u043e\u0442 \u043a\u0430\u043a \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043d\u0430\u0448\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f <code>performUnitOfWork<\/code>.<\/p>\n\n\n\n<h2 id=\"etapy-renderinga-i-fiksacii-rezultatov-commit\">\u042d\u0442\u0430\u043f\u044b \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430 \u0438 \u0444\u0438\u043a\u0441\u0430\u0446\u0438\u0438 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 (Commit)<\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code>if (fiber.parent) {\n fiber.parent.node.append(fiber.node)\n}<\/code><\/pre>\n\n\n\n<p>\u0412 \u0447\u0435\u043c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u044d\u0442\u043e\u0433\u043e \u0431\u043b\u043e\u043a\u0430 \u043a\u043e\u0434\u0430? (\u0412\u0442\u043e\u0440\u043e\u0439 \u0432\u043e\u043f\u0440\u043e\u0441 \u0438\u0437 100 \ud83d\ude09 )<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>   o   o\n    )-(\n   (O O)\n    \\=\/\n   .-\"-.\n  \/\/\\ \/\\\\\n_\/\/ \/ \\ \\\\_\n=.\/ {,-.} \\.=\n   || ||\n   || ||\n __|| ||__\n`---\" \"---'<\/code><\/pre>\n\n\n\n<p>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u0443\u0437\u0435\u043b \u0432 <code>DOM<\/code> \u043f\u0440\u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0435 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 (\u0432\u043e\u043b\u043e\u043a\u043d\u0430). \u041a\u0430\u043a \u043c\u044b \u043f\u043e\u043c\u043d\u0438\u043c, \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u043c\u043e\u0436\u0435\u0442 \u043f\u0440\u0435\u0440\u044b\u0432\u0430\u0442\u044c \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430 \u0434\u043b\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0441\u0432\u043e\u0438\u0445 \u0437\u0430\u0434\u0430\u0447. \u042d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0441\u043b\u0443\u0447\u0438\u0442\u044c\u0441\u044f \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043c\u044b \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043b\u0438 \u0432\u0441\u0435 \u0434\u0435\u0440\u0435\u0432\u043e. \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u2014 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0432\u0438\u0434\u0438\u0442 \u0447\u0430\u0441\u0442\u0438\u0447\u043d\u044b\u0439 <code>UI<\/code>. \u042d\u0442\u043e \u043d\u0435 \u0435\u0441\u0442\u044c \u0445\u043e\u0440\u043e\u0448\u043e.<\/p>\n\n\n\n<p>\u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0447\u0430\u0441\u0442\u044c, \u043c\u0443\u0442\u0438\u0440\u0443\u044e\u0449\u0443\u044e <code>DOM<\/code>, \u0438\u0437 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>performUnitOfWork<\/code> \u043c\u044b \u0443\u0434\u0430\u043b\u044f\u0435\u043c.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function render(element, container) {\n \/\/ !\n workingRoot = {\n   node: container,\n   props: {\n     children: &#91;element]\n   }\n }\n\n \/\/ !\n nextUnitOfWork = workingRoot\n}\n\u200b\nlet nextUnitOfWork = null\n\/\/ !\nlet workingRoot = null<\/code><\/pre>\n\n\n\n<p>\u0412\u043c\u0435\u0441\u0442\u043e \u044d\u0442\u043e\u0433\u043e, \u043c\u044b \u0441\u043b\u0435\u0434\u0438\u043c \u0437\u0430 \u043a\u043e\u0440\u043d\u0435\u043c <code>fiber tree<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\nfunction workLoop(deadline) {\n \/\/ ...\n\u200b\n if (!nextUnitOfWork &amp;&amp; workingRoot) {\n   requestAnimationFrame(commitRoot)\n }\n\u200b\n \/\/ ...\n}<\/code><\/pre>\n\n\n\n<p>\u041f\u043e\u0441\u043b\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0432\u0441\u0435\u0439 \u0440\u0430\u0431\u043e\u0442\u044b (\u044d\u0442\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u043e \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0438\u044e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u044b \u0440\u0430\u0431\u043e\u0442\u044b) \u043c\u044b \u0444\u0438\u043a\u0441\u0438\u0440\u0443\u0435\u043c (commit) <code>fiber tree<\/code>, \u0442.\u0435. \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0435\u0433\u043e \u0432 <code>DOM<\/code> (\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043c).<\/p>\n\n\n\n<p>\u041e \u0442\u043e\u043c, \u043f\u043e\u0447\u0435\u043c\u0443 \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u0437\u0434\u0435\u0441\u044c <code>requestAnimationFrame<\/code> \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0430\u0445, \u043f\u043e\u0441\u0432\u044f\u0449\u0435\u043d\u043d\u044b\u043c <code>requestIdleCallback<\/code>, \u043f\u043e \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u043d\u043d\u044b\u043c \u0432\u044b\u0448\u0435 \u0441\u0441\u044b\u043b\u043a\u0430\u043c. <a href=\"https:\/\/stackoverflow.com\/questions\/41740082\/scroll-events-requestanimationframe-vs-requestidlecallback-vs-passive-event-lis\"><code>\u041e\u0442\u043b\u0438\u0447\u043d\u043e\u0435 \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u0435 \u0440\u0430\u0437\u043d\u0438\u0446\u044b \u043c\u0435\u0436\u0434\u0443 rAF<\/code> \u0438 <code>rIC<\/code> \u043d\u0430 <code>Stack Overflow<\/code><\/a>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function commitRoot() {\n commitWork(workingRoot.child)\n workingRoot = null\n}\n\u200b\nfunction commitWork(fiber) {\n if (!fiber) {\n   return\n }\n\n const parentNode = fiber.parent.node\n parentNode.append(fiber.node)\n\n commitWork(fiber.child)\n commitWork(fiber.sibling)\n}<\/code><\/pre>\n\n\n\n<p>\u041c\u044b \u0434\u0435\u043b\u0430\u0435\u043c \u044d\u0442\u043e \u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>commitRoot<\/code>. \u0417\u0434\u0435\u0441\u044c \u043c\u044b \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0432\u0441\u0435 \u0443\u0437\u043b\u044b \u0432 <code>DOM<\/code>.<\/p>\n\n\n\n<h2 id=\"soglasovanie-reconcilation\">\u0421\u043e\u0433\u043b\u0430\u0441\u043e\u0432\u0430\u043d\u0438\u0435 (Reconcilation)<\/h2>\n\n\n\n<p>\u0414\u043e \u0441\u0438\u0445 \u043f\u043e\u0440 \u043c\u044b \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u043b\u0438 \u0443\u0437\u043b\u044b \u0432 <code>DOM<\/code>. \u041d\u043e \u0447\u0442\u043e \u043d\u0430\u0441\u0447\u0435\u0442 \u0438\u0445 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0438\u043b\u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f?<\/p>\n\n\n\n<p>\u042d\u0442\u0438\u043c \u043c\u044b \u0441\u0435\u0439\u0447\u0430\u0441 \u0438 \u0437\u0430\u0439\u043c\u0435\u043c\u0441\u044f. \u041d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0442\u044c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b, \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0435\u0439 <code>render<\/code> \u0441 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u043c <code>fiber tree<\/code>, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043c\u044b \u0437\u0430\u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043b\u0438 \u0432 <code>DOM<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function commitRoot() {\n commitWork(workingRoot.child)\n \/\/ !\n currentRoot = workingRoot\n workingRoot = null\n}\n\nfunction render(element, container) {\n workingRoot = {\n   dom: container,\n   props: {\n     children: &#91;element],\n   },\n   \/\/ !\n   alternate: currentRoot,\n }\n nextUnitOfWork = workingRoot\n}\n\nlet nextUnitOfWork = null\n\/\/ !\nlet currentRoot = null\nlet workingRoot = null<\/code><\/pre>\n\n\n\n<p>\u041d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0442\u044c \u0441\u0441\u044b\u043b\u043a\u0443 \u043d\u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435 <code>fiber tree<\/code> \u043f\u043e\u0441\u043b\u0435 \u0444\u0438\u043a\u0441\u0430\u0446\u0438\u0438 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432. \u041d\u0430\u0437\u043e\u0432\u0435\u043c \u0435\u0435 <code>currentRoot<\/code>.<\/p>\n\n\n\n<p>\u041c\u044b \u0442\u0430\u043a\u0436\u0435 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0432\u043e\u043b\u043e\u043a\u043d\u0443 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <code>alternate<\/code>. \u0414\u0430\u043d\u043d\u043e\u0435 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e \u2014 \u044d\u0442\u043e \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u0441\u0442\u0430\u0440\u043e\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e, \u0432\u043e\u043b\u043e\u043a\u043d\u043e, \u0437\u0430\u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0435 \u0432 <code>DOM<\/code> \u043d\u0430 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0439 \u0441\u0442\u0430\u0434\u0438\u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function performUnitOfWork(fiber) {\n \/\/ ...\n\u200b\n const elements = fiber.props.children\n \/\/ !\n reconcileChildren(fiber, elements)\n\u200b\n if (fiber.child) {\n   return fiber.child\n }\n \/\/ ...\n}\n\nfunction reconcileChildren(workingFiber, elements) {\n let index = 0\n let prevSibling = null\n\u200b\n while (index &lt; elements.length) {\n   const element = elements&#91;index]\n\u200b\n   const newFiber = {\n     type: element.type,\n     props: element.props,\n     parent: workingFiber,\n     node: null,\n   }\n\u200b\n   if (index === 0) {\n     workingFiber.child = newFiber\n   } else {\n     prevSibling.sibling = newFiber\n   }\n\u200b\n   prevSibling = newFiber\n   index++\n }\n}<\/code><\/pre>\n\n\n\n<p>\u0418\u0437\u0432\u043b\u0435\u043a\u0430\u0435\u043c \u043a\u043e\u0434 \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043d\u043e\u0432\u044b\u0445 \u0432\u043e\u043b\u043e\u043a\u043e\u043d \u0438\u0437 <code>performUnitOfWork<\/code> \u0432 \u043d\u043e\u0432\u0443\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e <code>reconcileChildren<\/code>.<\/p>\n\n\n\n<p>\u0417\u0434\u0435\u0441\u044c \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0442\u044c \u0441\u0442\u0430\u0440\u044b\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u0430 \u0441 \u043d\u043e\u0432\u044b\u043c\u0438 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function reconcileChildren(workingFiber, elements) {\n let index = 0\n let oldFiber =\n   workingFiber.alternate &amp;&amp; workingFiber.alternate.child\n let prevSibling = null\n\u200b\n while (\n   index &lt; elements.length ||\n   oldFiber !== null\n ) {\n   \/\/ TODO\n }\n}<\/code><\/pre>\n\n\n\n<p>\u041c\u044b \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u043f\u0435\u0440\u0435\u0431\u0438\u0440\u0430\u0435\u043c \u043f\u043e\u0442\u043e\u043c\u043a\u043e\u0432 \u0441\u0442\u0430\u0440\u043e\u0433\u043e \u0432\u043e\u043b\u043e\u043a\u043d\u0430 (<code>workingFiber.alternate<\/code>) \u0438 \u043c\u0430\u0441\u0441\u0438\u0432 \u043d\u043e\u0432\u044b\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0434\u043b\u044f \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f.<\/p>\n\n\n\n<p>\u0415\u0441\u043b\u0438 \u043c\u044b \u043e\u043f\u0443\u0441\u0442\u0438\u043c \u043a\u043e\u0434 \u0434\u043b\u044f \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043f\u043e \u043c\u0430\u0441\u0441\u0438\u0432\u0443 \u0438 \u0441\u0432\u044f\u0437\u043d\u043e\u043c\u0443 \u0441\u043f\u0438\u0441\u043a\u0443, \u0442\u043e \u0443 \u043d\u0430\u0441 \u043e\u0441\u0442\u0430\u043d\u0435\u0442\u0441\u044f 2 \u0432\u0435\u0449\u0438: <code>oldFiber<\/code> \u0438 <code>element<\/code>. <code>element<\/code> \u2014 \u044d\u0442\u043e \u0442\u043e, \u0447\u0442\u043e \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c \u0432 <code>DOM<\/code>, \u0430 <code>oldFiber<\/code> \u2014 \u044d\u0442\u043e \u0442\u043e, \u0447\u0442\u043e \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043b\u043e\u0441\u044c \u0432 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u0440\u0430\u0437.<\/p>\n\n\n\n<p>\u041d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0438\u0445 \u0441\u0440\u0430\u0432\u043d\u0438\u0442\u044c \u0434\u043b\u044f \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0443\u0436\u043d\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u043a <code>DOM<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const element = elements&#91;index]\nlet newFiber = null\n\nconst sameType =\n oldFiber &amp;&amp;\n element &amp;&amp;\n element.type == oldFiber.type\n\u200b\nif (sameType) {\n \/\/ TODO \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u043c \u0443\u0437\u0435\u043b\n}\nif (element &amp;&amp; !sameType) {\n \/\/ TODO \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0443\u0437\u0435\u043b\n}\nif (oldFiber &amp;&amp; !sameType) {\n \/\/ TODO \u0443\u0434\u0430\u043b\u044f\u0435\u043c \u0443\u0437\u0435\u043b\n}\n\nif (oldFiber) {\n oldFiber = oldFiber.sibling\n}<\/code><\/pre>\n\n\n\n<p>\u0414\u043b\u044f \u0438\u0445 \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u0442\u0438\u043f:<\/p>\n\n\n\n<ul><li>\u0435\u0441\u043b\u0438 \u0441\u0442\u0430\u0440\u043e\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u0438 \u043d\u043e\u0432\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u0438\u043c\u0435\u044e\u0442 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b\u0439 \u0442\u0438\u043f, \u043c\u044b \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442 \u0443\u0437\u0435\u043b \u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u043c \u0435\u0433\u043e \u043d\u043e\u0432\u044b\u043c\u0438 \u043f\u0440\u043e\u043f\u0430\u043c\u0438<\/li><li>\u0435\u0441\u043b\u0438 \u0442\u0438\u043f\u044b \u0440\u0430\u0437\u043d\u044b\u0435 \u0438 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442, \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u0443\u0437\u0435\u043b<\/li><li>\u0435\u0441\u043b\u0438 \u0442\u0438\u043f\u044b \u0440\u0430\u0437\u043d\u044b\u0435 \u0438 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u0440\u043e\u0435 \u0432\u043e\u043b\u043e\u043d\u043a\u043e, \u043c\u044b \u0443\u0434\u0430\u043b\u044f\u0435\u043c \u0443\u0437\u0435\u043b<\/li><\/ul>\n\n\n\n<p>\u0417\u0434\u0435\u0441\u044c <code>React<\/code> \u0442\u0430\u043a\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u043a\u043b\u044e\u0447\u0438 (keys) \u0432 \u0446\u0435\u043b\u044f\u0445 \u043b\u0443\u0447\u0448\u0435\u0433\u043e \u0441\u043e\u0433\u043b\u0430\u0441\u043e\u0432\u0430\u043d\u0438\u044f. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043a\u043b\u044e\u0447\u0435\u0439 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u0442\u0441\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u043f\u043e\u0440\u044f\u0434\u043a\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0432 \u0441\u043f\u0438\u0441\u043a\u0435.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>if (sameType) {\n newFiber = {\n   type: oldFiber.type,\n   props: element.props,\n   node: oldFiber.node,\n   parent: workingFiber,\n   alternate: oldFiber,\n   action: \"UPDATE\",\n }\n}<\/code><\/pre>\n\n\n\n<p>\u041a\u043e\u0433\u0434\u0430 \u0441\u0442\u0430\u0440\u043e\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u0438 \u043d\u043e\u0432\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u0438\u043c\u0435\u044e\u0442 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b\u0439 \u0442\u0438\u043f, \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043d\u043e\u0432\u043e\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e, \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u044f \u0443\u0437\u0435\u043b \u0438\u0437 \u0441\u0442\u0430\u0440\u043e\u0433\u043e \u0432\u043e\u043b\u043e\u043a\u043d\u0430 \u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044f \u043f\u0440\u043e\u043f\u044b \u0438\u0437 \u043d\u043e\u0432\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430.<\/p>\n\n\n\n<p>\u041c\u044b \u0442\u0430\u043a\u0436\u0435 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0432 \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u043d\u043e\u0432\u043e\u0435 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <code>action<\/code> (\u0432 <code>React<\/code> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 <code>effectTag<\/code>). \u042d\u0442\u043e \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0430 \u0441\u0442\u0430\u0434\u0438\u0438 \u0444\u0438\u043a\u0441\u0430\u0446\u0438\u0438.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>if (element &amp;&amp; !sameType) {\n newFiber = {\n   type: element.type,\n   props: element.props,\n   node: null,\n   parent: workingFiber,\n   alternate: null,\n   action: \"ADD\",\n }\n}<\/code><\/pre>\n\n\n\n<p>\u0418\u043d\u0434\u0438\u043a\u0430\u0442\u043e\u0440\u043e\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043d\u043e\u0432\u043e\u0433\u043e \u0443\u0437\u043b\u0430 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f <code>action: \"ADD\"<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>if (oldFiber &amp;&amp; !sameType) {\n oldFiber.action = \"REMOVE\"\n nodesToRemove.push(oldFiber)\n}<\/code><\/pre>\n\n\n\n<p>\u0412 \u0441\u043b\u0443\u0447\u0430\u0435, \u043a\u043e\u0433\u0434\u0430 \u043d\u0443\u0436\u043d\u043e \u0443\u0434\u0430\u043b\u0438\u0442\u044c \u0441\u0442\u0430\u0440\u044b\u0439 \u0443\u0437\u0435\u043b, \u043d\u043e\u0432\u043e\u0433\u043e \u0432\u043e\u043b\u043e\u043a\u043d\u0430 \u0443 \u043d\u0430\u0441 \u043d\u0435\u0442, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <code>action<\/code> \u043a \u0441\u0442\u0430\u0440\u043e\u043c\u0443 \u0432\u043e\u043b\u043e\u043a\u043d\u0443.<\/p>\n\n\n\n<p>\u041d\u043e \u043a\u043e\u0433\u0434\u0430 \u043c\u044b \u0444\u0438\u043a\u0441\u0438\u0440\u0443\u0435\u043c <code>fiber tree<\/code> \u0432 <code>DOM<\/code>, \u043c\u044b \u0434\u0435\u043b\u0430\u0435\u043c \u044d\u0442\u043e \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e (\u0438\u0437) <code>workingRoot<\/code>, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043d\u0435 \u0438\u043c\u0435\u0435\u0442 \u0441\u0442\u0430\u0440\u044b\u0445 \u0432\u043e\u043b\u043e\u043a\u043e\u043d.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function render(element, container) {\n workingRoot = {\n   dom: container,\n   props: {\n     children: &#91;element],\n   },\n   alternate: currentRoot,\n }\n \/\/ !\n nodesToRemove = &#91;]\n nextUnitOfWork = workingRoot\n}\n\u200b\nlet nextUnitOfWork = null\nlet currentRoot = null\nlet workingRoot = null\n\/\/ !\nlet nodesToRemove = null<\/code><\/pre>\n\n\n\n<p>\u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430\u043c \u043d\u0443\u0436\u0435\u043d \u043c\u0430\u0441\u0441\u0438\u0432 \u0434\u043b\u044f \u0443\u0437\u043b\u043e\u0432, \u043f\u043e\u0434\u043b\u0435\u0436\u0430\u0449\u0438\u0445 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044e.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function commitRoot() {\n \/\/ !\n nodesToRemove.forEach(commitWork)\n commitWork(workingRoot.child)\n currentRoot = workingRoot\n workingRoot = null\n}<\/code><\/pre>\n\n\n\n<p>\u041c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u044d\u0442\u043e\u0442 \u043c\u0430\u0441\u0441\u0438\u0432 \u043f\u0440\u0438 \u0444\u0438\u043a\u0441\u0430\u0446\u0438\u0438 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432.<\/p>\n\n\n\n<p>\u0412 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>commitWork<\/code> \u0437\u0430\u043c\u0435\u043d\u044f\u0435\u043c <code>parentNode.append(fiber.node)<\/code> \u043d\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>switch (fiber.action) {\n case 'ADD':\n   fiber.node &amp;&amp; parentNode.append(fiber.node)\n   break\n case 'REMOVE':\n   fiber.node.remove()\n   break\n case 'UPDATE':\n   fiber.node &amp;&amp; updateNode(fiber.node, fiber.alternate.props, fiber.props)\n   break\n default:\n   return\n}<\/code><\/pre>\n\n\n\n<p>\u0415\u0441\u043b\u0438 <code>fiber.action<\/code> \u0438\u043c\u0435\u0435\u0442 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 <code>ADD<\/code>, \u043c\u044b \u043f\u043e\u043c\u0435\u0449\u0430\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u0443\u0437\u0435\u043b \u0432 \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0439 \u0443\u0437\u0435\u043b. \u0415\u0441\u043b\u0438 <code>fiber.action<\/code> \u0438\u043c\u0435\u0435\u0442 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 <code>REMOVE<\/code>, \u043c\u044b \u0443\u0434\u0430\u043b\u044f\u0435\u043c \u0443\u0437\u0435\u043b. \u0415\u0441\u043b\u0438 <code>fiber.action<\/code> \u0438\u043c\u0435\u0435\u0442 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 <code>UPDATE<\/code>, \u043c\u044b \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u043c \u0443\u0437\u0435\u043b \u043d\u043e\u0432\u044b\u043c\u0438 \u043f\u0440\u043e\u043f\u0430\u043c\u0438.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function updateNode(node, prevProps, nextProps) {\n \/\/ TODO\n}<\/code><\/pre>\n\n\n\n<p>\u042d\u0442\u043e \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>updateNode<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const isProperty = key =&gt; key !== \"children\"\nconst wasAdded = (prev, next) =&gt; key =&gt;\n prev&#91;key] !== next&#91;key]\nconst wasRemoved = (prev, next) =&gt; key =&gt; !(key in next)\n\nfunction updateNode(node, prevProps, nextProps) {\n \/\/ \u0443\u0434\u0430\u043b\u044f\u0435\u043c \u0441\u0442\u0430\u0440\u044b\u0435 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430\n Object.keys(prevProps)\n   .filter(isProperty)\n   .filter(wasRemoved(prevProps, nextProps))\n   .forEach(key =&gt; {\n     dom&#91;key] = \"\"\n   })\n\u200b\n \/\/ \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043d\u043e\u0432\u044b\u0435 \u0438\u043b\u0438 \u0438\u0437\u043c\u0435\u043d\u0438\u0432\u0448\u0438\u0435\u0441\u044f \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430\n Object.keys(nextProps)\n   .filter(isProperty)\n   .filter(wasAdded(prevProps, nextProps))\n   .forEach(key =&gt; {\n     dom&#91;key] = nextProps&#91;key]\n   })\n}<\/code><\/pre>\n\n\n\n<p>\u041c\u044b \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0435\u043c \u043f\u0440\u043e\u043f\u044b \u0441\u0442\u0430\u0440\u043e\u0433\u043e \u0438 \u043d\u043e\u0432\u043e\u0433\u043e \u0432\u043e\u043b\u043e\u043a\u043e\u043d, \u0443\u0434\u0430\u043b\u044f\u0435\u043c \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0435 \u043f\u0440\u043e\u043f\u044b \u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043d\u043e\u0432\u044b\u0435 \u0438\u043b\u0438 \u0438\u0437\u043c\u0435\u043d\u0438\u0432\u0448\u0438\u0435\u0441\u044f \u043f\u0440\u043e\u043f\u044b.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const isEvent = key =&gt; key.startsWith(\"on\")\nconst isProperty = key =&gt;\n key !== \"children\" &amp;&amp; !isEvent(key)<\/code><\/pre>\n\n\n\n<p>\u041e\u0434\u043d\u0438\u043c \u0438\u0437 \u043e\u0441\u043e\u0431\u044b\u0445 \u043f\u0440\u043e\u043f\u043e\u0432 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u0441\u043e\u0431\u044b\u0442\u0438\u0439 (event listeners). \u041f\u043e\u044d\u0442\u043e\u043c\u0443, \u0435\u0441\u043b\u0438 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u043f\u0440\u043e\u043f\u0430 \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u0441 <code>on<\/code>, \u0442\u0430\u043a\u043e\u0439 \u043f\u0440\u043e\u043f \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>Object.keys(prevProps)\n .filter(isEvent)\n .filter(\n   key =&gt;\n     !(key in nextProps) ||\n     wasAdded(prevProps, nextProps)(key)\n )\n .forEach(key =&gt; {\n   const eventType = key\n     .toLowerCase()\n     .substring(2) \/\/ onClick -&gt; click\n\n   node.removeEventListener(\n     eventType,\n     prevProps&#91;key]\n   )\n })<\/code><\/pre>\n\n\n\n<p>\u0415\u0441\u043b\u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0438\u043b\u0438 \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u0441\u044f, \u0435\u0433\u043e \u043d\u0443\u0436\u043d\u043e \u0443\u0434\u0430\u043b\u0438\u0442\u044c.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>Object.keys(nextProps)\n .filter(isEvent)\n .filter(wasAdded(prevProps, nextProps))\n .forEach(key =&gt; {\n   const eventType = key\n     .toLowerCase()\n     .substring(2)\n\n   node.addEventListener(\n     eventType,\n     nextProps&#91;key]\n   )\n })<\/code><\/pre>\n\n\n\n<p>\u0417\u0430\u0442\u0435\u043c \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043d\u043e\u0432\u044b\u0435 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438.<\/p>\n\n\n\n<h2 id=\"funkcionalnye-komponenty-functional-components\">\u0424\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b (Functional Components)<\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code>\/** @jsx MyReact.createElement *\/\nfunction App(props) {\n return (\n   &lt;section id=\"welcome\"&gt;\n     &lt;h1 title=\"hello\" className=\"title\"&gt;Hello from {props.who}!&lt;\/h1&gt;\n     &lt;p style=\"color: green;\"&gt;&lt;span&gt;React&lt;\/span&gt; from {props.what}&lt;\/p&gt;\n   &lt;\/section&gt;\n )\n}\nconst element = &lt;App who=\"MyReact\" what=\"scratch\" \/&gt;\nconst container = document.getElementById(\"root\")\nMyReact.render(element, container)<\/code><\/pre>\n\n\n\n<p>\u0414\u043e\u0431\u0430\u0432\u0438\u043c \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0443 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432.<\/p>\n\n\n\n<p>\u0415\u0441\u043b\u0438 \u043c\u044b \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u043c \u0441\u0442\u0440\u043e\u043a\u0443 <code>const element = &lt;App who=\"MyReact\" what=\"scratch\" \/&gt;<\/code> \u0432 <code>JS<\/code>, \u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const element = MyReact.createElement(App, {\n who: \"MyReact\",\n what: \"scratch\"\n})<\/code><\/pre>\n\n\n\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b \u043e\u0442\u043b\u0438\u0447\u0430\u044e\u0442\u0441\u044f \u043e\u0442 \u043e\u0431\u044b\u0447\u043d\u044b\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c:<\/p>\n\n\n\n<ul><li>\u0432\u043e\u043b\u043e\u043a\u043d\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 \u043d\u0435 \u0438\u043c\u0435\u0435\u0442 \u0443\u0437\u043b\u0430<\/li><li>\u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u043c \u0432\u044b\u0437\u043e\u0432\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u0438<\/li><\/ul>\n\n\n\n<pre class=\"wp-block-code\"><code>function performUnitOfWork(fiber) {\n \/\/ !\n const isFunctionComponent =\n   fiber.type instanceof Function\n\n if (isFunctionComponent) {\n   updateFunctionComponent(fiber)\n } else {\n   updateHostComponent(fiber)\n }\n\n \/\/ ...\n}\n\u200b\nfunction updateFunctionComponent(fiber) {\n \/\/ TODO\n}\n\u200b\nfunction updateHostComponent(fiber) {\n if (!fiber.node) {\n   fiber.node = createDom(fiber)\n }\n\n reconcileChildren(fiber, fiber.props.children)\n}<\/code><\/pre>\n\n\n\n<p>\u041c\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043b\u0438 \u0442\u0438\u043f \u0432\u043e\u043b\u043e\u043a\u043d\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u0435\u0439, \u0438 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u044d\u0442\u043e\u0439 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043c \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0443\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e.<\/p>\n\n\n\n<p>\u0412 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>updateHostComponent<\/code> \u043c\u044b \u0434\u0435\u043b\u0430\u0435\u043c \u0442\u043e\u0436\u0435 \u0441\u0430\u043c\u043e\u0435, \u0447\u0442\u043e \u0438 \u0440\u0430\u043d\u044c\u0448\u0435.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>export function updateFunctionComponent(fiber) {\n const children = &#91;fiber.type(fiber.props)]\n reconcileChildren(fiber, children)\n}<\/code><\/pre>\n\n\n\n<p>\u0410 \u0432 <code>updateFunctionalComponent<\/code> \u043c\u044b \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u0443\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432.<\/p>\n\n\n\n<p>\u0412 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 <code>fiber.type<\/code> \u2014 \u044d\u0442\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u044f <code>App<\/code>, \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 <code>section<\/code> \u0441 \u043f\u043e\u0442\u043e\u043c\u043a\u0430\u043c\u0438.<\/p>\n\n\n\n<p>\u041b\u043e\u0433\u0438\u043a\u0430 \u0441\u043e\u0433\u043b\u0430\u0441\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u043e\u0442\u043e\u043c\u043a\u043e\u0432 \u043e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u0435\u0436\u043d\u0435\u0439, \u043d\u0430\u043c \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u043d\u0438\u0447\u0435\u0433\u043e \u0432 \u043d\u0435\u0439 \u0438\u0437\u043c\u0435\u043d\u044f\u0442\u044c.<\/p>\n\n\n\n<p>\u041e\u0434\u043d\u0430\u043a\u043e, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0443 \u043d\u0430\u0441 \u043f\u043e\u044f\u0432\u0438\u043b\u043e\u0441\u044c \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u0431\u0435\u0437 \u0443\u0437\u043b\u043e\u0432, \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u043f\u043e\u043c\u0435\u043d\u044f\u0442\u044c 2 \u0432\u0435\u0449\u0438 \u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>commitWork<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>let parentFiber = fiber.parent\nwhile (!parentFiber.node) {\n parentFiber = parentFiber.parent\n}\nconst parentNode = parentFiber.node<\/code><\/pre>\n\n\n\n<p>\u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u043d\u0430\u0439\u0442\u0438 \u043f\u0440\u0435\u0434\u043a\u0430 \u0442\u0435\u043a\u0443\u0449\u0435\u0433\u043e \u0443\u0437\u043b\u0430 \u043c\u044b \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u043c\u0441\u044f \u0432\u0432\u0435\u0440\u0445 \u043f\u043e <code>fiber tree<\/code> \u0434\u043e \u0442\u0435\u0445 \u043f\u043e\u0440, \u043f\u043e\u043a\u0430 \u043d\u0435 \u043e\u0431\u043d\u0430\u0440\u0443\u0436\u0438\u043c \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u0441 \u0443\u0437\u043b\u043e\u043c.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>case 'REMOVE':\n return commitRemove(fiber)\n\nfunction commitRemove(fiber) {\n if (fiber.node) {\n   return fiber.node.remove()\n }\n commitRemove(fiber.child)\n}<\/code><\/pre>\n\n\n\n<p>\u0410 \u043f\u0440\u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0438 \u0443\u0437\u043b\u0430 \u043c\u044b \u0434\u0432\u0438\u0433\u0430\u0435\u043c\u0441\u044f \u0432\u043d\u0438\u0437, \u043f\u043e\u043a\u0430 \u043d\u0435 \u043d\u0430\u0439\u0434\u0435\u043d \u043f\u043e\u0442\u043e\u043c\u043a\u0430 \u0441 \u0443\u0437\u043b\u043e\u043c. \u041a\u0440\u043e\u043c\u0435 \u0442\u043e\u0433\u043e, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0434\u0435\u043b\u0435\u0433\u0438\u0440\u0443\u0435\u0442\u0441\u044f <code>commitRemove<\/code>, \u043c\u044b \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u044b \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c <code>commitWork<\/code> \u0434\u043b\u044f \u0441\u0442\u0430\u0440\u044b\u0445 \u0443\u0437\u043b\u043e\u0432.<\/p>\n\n\n\n<h2 id=\"huki-hooks\">\u0425\u0443\u043a\u0438 (Hooks)<\/h2>\n\n\n\n<p>\u041f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435, \u0447\u0442\u043e \u043d\u0430\u043c \u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c, \u044d\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/** @jsx MyReact.createElement *\/\nfunction Counter() {\n const &#91;state, setState] = MyReact.useState(1)\n\n return (\n   &lt;h1 onClick={() =&gt; setState(c =&gt; c + 1)}&gt;\n     Count: { state }\n   &lt;\/h1&gt;\n )\n}\nconst container = document.getElementById(\"root\")\nMyReact.render(&lt;Counter \/&gt;, container)<\/code><\/pre>\n\n\n\n<p>\u0417\u0434\u0435\u0441\u044c \u0443 \u043d\u0430\u0441 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 \u0441\u0447\u0435\u0442\u0447\u0438\u043a\u0430. \u041f\u0440\u0438 \u043a\u043b\u0438\u043a\u0435 \u043f\u043e \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0443 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0441\u0447\u0435\u0442\u0447\u0438\u043a\u0430 \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430 1.<\/p>\n\n\n\n<p><em>\u041e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435<\/em>, \u0447\u0442\u043e \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c <code>MyReact.useState<\/code> \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0441\u0447\u0435\u0442\u0447\u0438\u043a\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ \u0424\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442 \u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435\nfunction useState(initialState) {\n \/\/ TODO\n}<\/code><\/pre>\n\n\n\n<p>\u041c\u044b \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e <code>Counter<\/code>, \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f <code>useState<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ !\nlet workingFiber = null\nlet hookIndex = null\n\u200b\nfunction updateFunctionComponent(fiber) {\n \/\/ !\n workingFiber = fiber\n hookIndex = 0\n workingFiber.hooks = &#91;]\n \/\/ end !\n const children = &#91;fiber.type(fiber.props)]\n reconcileChildren(fiber, children)\n}<\/code><\/pre>\n\n\n\n<p>\u041d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0434\u043b\u044f \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u043e \u0445\u0443\u043a\u0430\u0445.<\/p>\n\n\n\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043c\u044b \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u043c \u0440\u0430\u0431\u043e\u0447\u0435\u0435 \u0432\u043e\u043b\u043e\u043a\u043d\u043e (<code>workingFiber<\/code>).<\/p>\n\n\n\n<p>\u0417\u0430\u0442\u0435\u043c \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043c\u0430\u0441\u0441\u0438\u0432 <code>hooks<\/code> \u0432 \u0432\u043e\u043b\u043e\u043a\u043d\u043e \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0438\u043c\u0435\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0432\u044b\u0437\u044b\u0432\u0430\u0442\u044c <code>useState<\/code> \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437 \u0432 \u043e\u0434\u043d\u043e\u043c \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0435. \u0422\u0430\u043a\u0436\u0435 \u043c\u044b \u0444\u0438\u043a\u0441\u0438\u0440\u0443\u0435\u043c \u0438\u043d\u0434\u0435\u043a\u0441 \u0442\u0435\u043a\u0443\u0449\u0435\u0433\u043e \u0445\u0443\u043a\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function useState(initialState) {\n const oldHook =\n   workingFiber.alternate &amp;&amp;\n   workingFiber.alternate.hooks &amp;&amp;\n   workingFiber.alternate.hooks&#91;hookIndex]\n\n const hook = {\n   state: oldHook ? oldHook.state : initialState,\n }\n\u200b\n workingFiber.hooks.push(hook)\n hookIndex++\n\n return &#91;hook.state]\n}<\/code><\/pre>\n\n\n\n<p>\u041f\u0440\u0438 \u0432\u044b\u0437\u043e\u0432\u0435 <code>useState<\/code> \u043c\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u043b\u0438 \u0443 \u043d\u0430\u0441 \u0441\u0442\u0430\u0440\u044b\u0439 \u0445\u0443\u043a. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043c\u044b \u0437\u0430\u0433\u043b\u044f\u0434\u044b\u0432\u0430\u0435\u043c \u0432 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <code>alternate<\/code> \u0432\u043e\u043b\u043e\u043a\u043d\u0430, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0438\u043d\u0434\u0435\u043a\u0441 \u0445\u0443\u043a\u0430.<\/p>\n\n\n\n<p>\u0415\u0441\u043b\u0438 \u0441\u0442\u0430\u0440\u044b\u0439 \u0445\u0443\u043a \u0435\u0441\u0442\u044c, \u043c\u044b \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u043c \u0435\u0433\u043e \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0432 \u043d\u043e\u0432\u044b\u0439 \u0445\u0443\u043a, \u0438\u043d\u0430\u0447\u0435 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u0435\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043d\u0430\u0447\u0430\u043b\u044c\u043d\u044b\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c (\u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043e\u043c).<\/p>\n\n\n\n<p>\u0417\u0430\u0442\u0435\u043c \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u0445\u0443\u043a \u0432 \u0432\u043e\u043b\u043e\u043a\u043d\u043e, \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0432\u0430\u0435\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u043d\u0430 1 \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const hook = {\n   state: oldHook ? oldHook.state : initialState,\n   \/\/ !\n   queue: &#91;],\n }\n\u200b\n\/\/ !\nconst setState = action =&gt; {\n hook.queue.push(action)\n\n workingRoot = {\n   node: currentRoot.node,\n   props: currentRoot.props,\n   alternate: currentRoot,\n }\n\n nextUnitOfWork = workingRoot\n nodesToRemove = &#91;]\n}\n\u200b\nworkingFiber.hooks.push(hook)\nhookIndex++\n\n\/\/ !\nreturn &#91;hook.state, setState]<\/code><\/pre>\n\n\n\n<p><code>useState<\/code> \u0442\u0430\u043a\u0436\u0435 \u0434\u043e\u043b\u0436\u043d\u0430 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0434\u043b\u044f \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u044b \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e <code>setState<\/code>, \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u044e\u0449\u0443\u044e \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044e (\u0432 <code>Counter<\/code> \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f \u2014 \u044d\u0442\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0432\u0430\u0435\u0442 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0441\u0447\u0435\u0442\u0447\u0438\u043a\u0430 \u043d\u0430 1).<\/p>\n\n\n\n<p>\u041c\u044b \u043f\u043e\u043c\u0435\u0449\u0430\u0435\u043c \u044d\u0442\u0443 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044e \u0432 \u043e\u0447\u0435\u0440\u0435\u0434\u044c (<code>queue<\/code>) \u0445\u0443\u043a\u0430.<\/p>\n\n\n\n<p>\u0417\u0430\u0442\u0435\u043c \u043c\u044b \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u043c \u043b\u043e\u0433\u0438\u043a\u0443 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <code>render<\/code>: \u043d\u043e\u0432\u044b\u0439 <code>workingRoot<\/code> \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0435\u0434\u0438\u043d\u0438\u0446\u0435\u0439 \u0440\u0430\u0431\u043e\u0442\u044b, \u0447\u0442\u043e \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u043a \u0437\u0430\u043f\u0443\u0441\u043a\u0443 \u043d\u043e\u0432\u043e\u0439 \u0441\u0442\u0430\u0434\u0438\u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const hook = {\n state: oldHook ? oldHook.state : initial,\n queue: &#91;],\n}\n\u200b\n\/\/ !\nconst actions = oldHook ? oldHook.queue : &#91;]\nactions.forEach(action =&gt; {\n hook.state = action(hook.state)\n})<\/code><\/pre>\n\n\n\n<p>\u041e\u043f\u0435\u0440\u0430\u0446\u0438\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e\u0442\u0441\u044f \u043f\u0440\u0438 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430. \u041c\u044b \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0432\u0441\u0435 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0438 \u0438\u0437 \u043e\u0447\u0435\u0440\u0435\u0434\u0438 \u0441\u0442\u0430\u0440\u043e\u0433\u043e \u0445\u0443\u043a\u0430 \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u0438\u0445 \u043f\u043e \u043e\u0434\u043d\u043e\u0439 \u043a \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044e \u0445\u0443\u043a\u0430. \u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043c\u044b \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435.<\/p>\n\n\n\n<p>\u041f\u043e\u0436\u0430\u043b\u0443\u0439, \u043d\u0430 \u044d\u0442\u043e\u043c \u043c\u044b \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043c\u0441\u044f. \u0422\u0435\u043f\u0435\u0440\u044c \u0432\u044b \u0437\u043d\u0430\u0435\u0442\u0435, \u0441 \u0447\u0435\u0433\u043e \u043d\u0430\u0447\u0430\u0442\u044c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 <code>React<\/code>.<\/p>\n\n\n\n<p>\u041d\u043e \u043f\u0440\u0435\u0436\u0434\u0435, \u0447\u0435\u043c \u043c\u044b \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u043c, \u0432\u043d\u0435\u0441\u0435\u043c \u0435\u0449\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u0435\u043b\u043a\u0438\u0445 \u043f\u0440\u0430\u0432\u043e\u043a.<\/p>\n\n\n\n<ul><li><code>initialState<\/code> \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u0435\u0439:<\/li><\/ul>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ useState\nconst hook = {\n state: oldHook\n   ? oldHook.state\n   \/\/ !\n   : initialState instanceof Function\n   ? initialState()\n   : initialState,\n queue: &#91;]\n}<\/code><\/pre>\n\n\n\n<ul><li><code>action<\/code> \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043e\u043c:<\/li><\/ul>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ useState\nactions.forEach((action) =&gt; {\n \/\/ !\n hook.state = action instanceof Function ? action(hook.state) : action\n})<\/code><\/pre>\n\n\n\n<ul><li>\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c \u043f\u0440\u043e\u043f\u0430 <code>style<\/code> \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043e\u0431\u044a\u0435\u043a\u0442:<\/li><\/ul>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ updateNode\nObject.keys(nextProps)\n .filter(isProperty)\n .filter(wasAdded(prevProps, nextProps))\n .forEach((key) =&gt; {\n   \/\/ !\n   if (key === 'style' &amp;&amp; typeof nextProps&#91;key] === 'object') {\n     Object.assign(node.style, nextProps&#91;key])\n   } else {\n     node&#91;key] = nextProps&#91;key]\n   }\n })<\/code><\/pre>\n\n\n\n<ul><li><code>children<\/code> \u043c\u043e\u0436\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u043c\u0430\u0441\u0441\u0438\u0432:<\/li><\/ul>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ createElement\nchildren: children\n .flat()\n .map((child) =&gt;\n   typeof child === 'object' ? child : createTextElement(child)\n )<\/code><\/pre>\n\n\n\n<h2 id=\"zapusk-proekta-s-pomoschyu-snowpack\">\u0417\u0430\u043f\u0443\u0441\u043a \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <code>Snowpack<\/code><\/h2>\n\n\n\n<p>\u0412\u0435\u0441\u044c \u043a\u043e\u0434 <code>MyReact<\/code> \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442\u0441\u044f \u0432 \u043e\u0434\u043d\u043e\u043c \u0444\u0430\u0439\u043b\u0435. \u042d\u0442\u043e \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0443\u0434\u043e\u0431\u043d\u043e. \u041d\u043e \u0435\u0441\u043b\u0438 \u043f\u043e\u043f\u044b\u0442\u0430\u0442\u044c\u0441\u044f \u0440\u0430\u0437\u0434\u0435\u043b\u0438\u0442\u044c \u043a\u043e\u0434 \u043d\u0430 \u043c\u043e\u0434\u0443\u043b\u0438, \u0442\u043e \u043d\u0430\u0447\u043d\u0443\u0442\u0441\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b. \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u043e\u0448\u0438\u0431\u043a\u0443, \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u0443\u044e \u0441 \u0442\u0435\u043c, \u0447\u0442\u043e \u0438\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u044f <code>import<\/code> \u043c\u043e\u0436\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u043c\u043e\u0434\u0443\u043b\u044f\u0445. \u0417\u0430\u0442\u0435\u043c \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043d\u0430\u0447\u043d\u0435\u0442 \u0432\u044b\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0442\u044c <code>Babel<\/code>, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043e\u043d \u043d\u0435 \u043f\u043e\u043d\u0438\u043c\u0430\u0435\u0442 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 \u043c\u043e\u0434\u0443\u043b\u0435\u0439 \u2014 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0435\u043c\u0443 \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u043f\u043b\u0430\u0433\u0438\u043d. \u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u043f\u043b\u0430\u0433\u0438\u043d \u043a <code>Babel<\/code> \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043e\u0434\u043d\u043e\u0433\u043e \u0442\u043e\u043b\u044c\u043a\u043e <code>babel.config.json<\/code> \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f. \u0417\u0434\u0435\u0441\u044c \u043d\u0443\u0436\u043d\u0430 \u043f\u043e\u043c\u043e\u0449\u044c \u0441\u0431\u043e\u0440\u0449\u0438\u043a\u0430 (\u0431\u0430\u043d\u0434\u043b\u0435\u0440\u0430).<\/p>\n\n\n\n<p>\u041a\u043e\u0433\u0434\u0430 \u0440\u0435\u0447\u044c \u0437\u0430\u0445\u043e\u0434\u0438\u0442 \u043e \u0441\u0431\u043e\u0440\u0449\u0438\u043a\u0430\u0445, \u044f, \u043e\u0431\u044b\u0447\u043d\u043e, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e <a href=\"https:\/\/webpack.js.org\/\"><code>Webpack<\/code><\/a>. \u041d\u043e \u043d\u0435\u0434\u0430\u0432\u043d\u043e \u043d\u0430 \u0425\u0430\u0431\u0440\u0435 \u0432\u044b\u0448\u043b\u043e 2 \u0445\u043e\u0440\u043e\u0448\u0438\u0435 \u0441\u0442\u0430\u0442\u044c\u0438, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0441\u043e\u0437\u0434\u0430\u0442\u0435\u043b\u044c <code>snowpack<\/code> \u0434\u0435\u043b\u0438\u0442\u0441\u044f \u0441\u0432\u043e\u0438\u043c \u043e\u043f\u044b\u0442\u043e\u043c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u043e\u0442\u043a\u0440\u044b\u0442\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u044f \u0440\u0435\u0448\u0438\u043b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u044d\u0442\u043e\u0442 &#8220;\u0441\u0431\u043e\u0440\u0449\u0438\u043a \u0434\u043b\u044f \u0441\u0431\u043e\u0440\u0449\u0438\u043a\u043e\u0432&#8221;.<\/p>\n\n\n\n<p>\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0430:<\/p>\n\n\n\n<figure class=\"wp-block-image\"><img src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/yf\/n-\/vu\/yfn-vu2k1i_aepnbvr6yvhvtfqm.png\" alt=\"\"\/><\/figure>\n\n\n\n<p><br>\u0418\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u0435\u043c \u043f\u0440\u043e\u0435\u043a\u0442, \u043d\u0430\u0445\u043e\u0434\u044f\u0441\u044c \u0432 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0439 \u0434\u0438\u0440\u0435\u043a\u0442\u043e\u0440\u0438\u0438:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>yarn init -yp<\/code><\/pre>\n\n\n\n<p>\u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c <code>snowpack<\/code>, 2 \u043f\u043b\u0430\u0433\u0438\u043d\u0430 \u0434\u043b\u044f \u043d\u0435\u0433\u043e \u0438 \u0435\u0449\u0435 \u043e\u0434\u0438\u043d \u0434\u043b\u044f <code>babel<\/code>:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>yarn add -D snowpack @snowpack\/plugin-babel @snowpack\/plugin-sass @babel\/preset-react<\/code><\/pre>\n\n\n\n<p>\u041d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c <code>snowpack<\/code> (<code>snowpack.config.json<\/code>):<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>{\n \"plugins\": &#91;\n   \"@snowpack\/plugin-babel\",\n   \"@snowpack\/plugin-sass\"\n ]\n}<\/code><\/pre>\n\n\n\n<p>\u041d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c <code>babel<\/code> (<code>babel.config.json<\/code>):<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>{\n \"presets\": &#91;\n   \"@babel\/preset-react\"\n ]\n}<\/code><\/pre>\n\n\n\n<p>\u041e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u043c \u043a\u043e\u043c\u0430\u043d\u0434\u0443 \u0434\u043b\u044f \u0437\u0430\u043f\u0443\u0441\u043a\u0430 <code>snowpack<\/code> \u0432 <code>package.json<\/code>:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\"scripts\": {\n \"start\": \"snowpack dev\"\n}<\/code><\/pre>\n\n\n\n<p>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043f\u0440\u043e\u0435\u043a\u0442 \u0432 \u0440\u0435\u0436\u0438\u043c\u0435 \u0434\u043b\u044f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>yarn start<\/code><\/pre>\n\n\n\n<p>\u041a\u0440\u0430\u0441\u043e\u0442\u0430:<\/p>\n\n\n\n<figure class=\"wp-block-image\"><img src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/gp\/5l\/id\/gp5lidri_i8c94x05m2fsejuyqq.png\" alt=\"\"\/><\/figure>\n\n\n\n<h2 id=\"zaklyuchenie\">\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h2>\n\n\n\n<p>\u0418\u0442\u0430\u043a, \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043c\u044b \u0441 \u0432\u0430\u043c\u0438 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043b\u0438 \u043c\u0438\u043d\u0438-\u0432\u0435\u0440\u0441\u0438\u044e <code>React<\/code>. \u041e\u043d\u0430 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u043e\u0431\u043e\u0439 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043d\u0430\u0438\u0432\u043d\u0443\u044e \u0438\u043c\u043f\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e <code>\u22480.1%<\/code> \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430 <code>React<\/code>. \u041d\u043e, \u043a\u0430\u043a \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u0441\u044f, \u0433\u043b\u0430\u0432\u043d\u043e\u0435 \u2014 \u043d\u0430\u0447\u0430\u0442\u044c \ud83d\ude09<\/p>\n\n\n\n<p>\u041f\u043e\u043b\u0435\u0437\u043d\u044b\u0435 \u0441\u0441\u044b\u043b\u043a\u0438 \u0434\u043b\u044f \u0442\u0435\u0445, \u043a\u043e\u043c\u0443, \u043a\u0430\u043a \u0438 \u043c\u043d\u0435, \u0432\u0441\u0435\u0433\u0434\u0430 \u043c\u0430\u043b\u043e:<\/p>\n\n\n\n<ul><li><a href=\"https:\/\/github.com\/facebook\/react\/tree\/main\/packages\/react\"><code>React<\/code><\/a> \u2014 \u0438\u0441\u0445\u043e\u0434\u043d\u044b\u0439 \u043a\u043e\u0434 <code>React<\/code><\/li><li><a href=\"https:\/\/github.com\/DAB0mB\/jsx-runtime\"><code>JSX Runtime<\/code><\/a> \u2014 \u043f\u043e\u043f\u044b\u0442\u043a\u0430 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0430\u0440\u0441\u0438\u043d\u0433 <code>JSX<\/code> \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <a href=\"https:\/\/developer.mozilla.org\/ru\/docs\/Web\/JavaScript\/Reference\/Template_literals\"><code>tagged template literals<\/code><\/a><\/li><li><a href=\"https:\/\/github.com\/yisar\/fre\"><code>Fre<\/code><\/a> \u2014 \u0431\u043e\u043b\u0435\u0435 \u043f\u0440\u043e\u0434\u0432\u0438\u043d\u0443\u0442\u043e\u0435 \u0441\u043e\u0433\u043b\u0430\u0441\u043e\u0432\u0430\u043d\u0438\u0435, \u0432 \u0442\u043e\u043c \u0447\u0438\u0441\u043b\u0435, \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u043a\u043b\u044e\u0447\u0435\u0439<\/li><li><a href=\"https:\/\/github.com\/davidbarone\/didact\"><code>@dbarone\/didact<\/code><\/a> \u2014 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043e\u0432 \u0438 \u0445\u0443\u043a\u043e\u0432 <code>useEffect<\/code>, <code>useMemo<\/code> \u0438 <code>useCallback<\/code><\/li><\/ul>\n\n\n\n<p>\u041d\u0430\u0434\u0435\u044e\u0441\u044c \u0432\u0430\u043c \u0431\u044b\u043b\u043e \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e \u0438 \u0432\u044b \u043d\u0435 \u0436\u0430\u043b\u0435\u0435\u0442\u0435 \u043f\u043e\u0442\u0440\u0430\u0447\u0435\u043d\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043f\u043e\u043a\u0430\u0436\u0443 \u0432\u0430\u043c, \u0441 \u0447\u0435\u0433\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f React.<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[30],"tags":[65],"_links":{"self":[{"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=\/wp\/v2\/posts\/2321"}],"collection":[{"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2321"}],"version-history":[{"count":1,"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=\/wp\/v2\/posts\/2321\/revisions"}],"predecessor-version":[{"id":2322,"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=\/wp\/v2\/posts\/2321\/revisions\/2322"}],"wp:attachment":[{"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2321"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2321"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/lvboard.infostore.in.ua\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2321"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}