{"id":452387,"date":"2025-03-19T15:02:29","date_gmt":"2025-03-19T15:02:29","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=452387"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=452387","title":{"rendered":"<span>\u041f\u0440\u043e\u0436\u0430\u0440\u0438\u0432\u0430\u0435\u043c React<\/span>"},"content":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041f\u0440\u0438\u0432\u0435\u0442, \u0425\u0430\u0431\u0440! \u042f \u0443\u0436\u0435 \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u043b, \u0447\u0442\u043e <a href=\"https:\/\/habr.com\/ru\/articles\/870538\/\" rel=\"noopener noreferrer nofollow\">\u0443\u043c\u0435\u044e \u0440\u0430\u0437\u043d\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e \u043f\u0438\u0441\u0430\u0442\u044c \u0441\u0447\u0451\u0442\u0447\u0438\u043a\u0438<\/a>.\u041f\u0440\u0438\u0448\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0448\u0430\u0433 \u0432\u043f\u0435\u0440\u0451\u0434! \u0421\u0435\u0433\u043e\u0434\u043d\u044f \u043f\u043e\u0433\u043e\u0432\u043e\u0440\u0438\u043c \u043e \u0442\u043e\u043c \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0435, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044f \u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u044b \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 \u0435\u0436\u0435\u0434\u043d\u0435\u0432\u043d\u043e. \u0420\u0435\u0447\u044c \u043f\u043e\u0439\u0434\u0451\u0442 \u043e \u0432\u0435\u043b\u0438\u043a\u043e\u043c \u0438 \u0443\u0436\u0430\u0441\u043d\u043e\u043c ReactJS.<\/p>\n<p>\u042f \u043f\u0438\u0448\u0443 \u043d\u0430 React \u0441 2018 \u0433\u043e\u0434\u0430, \u0434\u0435\u043b\u0430\u044e \u044d\u0442\u043e, \u043d\u0430 \u043c\u043e\u0439 \u0432\u0437\u0433\u043b\u044f\u0434, \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u0441\u043d\u043e\u0441\u043d\u043e.\u041c\u043d\u0435 \u043d\u0440\u0430\u0432\u0438\u0442\u0441\u044f \u0442\u0435\u0437\u0438\u0441 \u043e \u0442\u043e\u043c, \u0447\u0442\u043e \u043f\u0440\u043e\u0444\u0435\u0441\u0441\u0438\u043e\u043d\u0430\u043b\u0438\u0437\u043c \u0437\u0430\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u0443\u043c\u0435\u043d\u0438\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0434\u043e\u0441\u0442\u043e\u0438\u043d\u0441\u0442\u0432\u0430 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430, \u043d\u043e \u0438 \u0432 \u0443\u043c\u0435\u043d\u0438\u0438 \u0447\u0451\u0442\u043a\u043e \u0432\u0438\u0434\u0435\u0442\u044c \u0435\u0433\u043e \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u0438.\u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u043e\u0437\u043d\u0438\u043a\u043b\u0430 \u0438\u0434\u0435\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0447\u0442\u043e-\u0442\u043e \u0442\u0438\u043f\u0430 \u043f\u0440\u043e\u0436\u0430\u0440\u043a\u0438 React, \u0443\u043a\u0430\u0437\u0430\u0432 \u043d\u0430 \u043b\u0438\u0447\u043d\u043e \u043c\u0435\u043d\u044f \u0440\u0430\u0437\u0434\u0440\u0430\u0436\u0430\u044e\u0449\u0438\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b. \u0421 \u043a\u0430\u043a\u0438\u043c\u0438-\u0442\u043e \u044f \u0441\u043c\u0438\u0440\u0438\u043b\u0441\u044f, \u0441 \u043a\u0430\u043a\u0438\u043c\u0438-\u0442\u043e \u043d\u0435\u0442, \u0447\u0442\u043e-\u0442\u043e \u043d\u0430\u0443\u0447\u0438\u043b\u0441\u044f \u043e\u0431\u0445\u043e\u0434\u0438\u0442\u044c. \u0415\u0441\u043b\u0438 \u0432\u0430\u0441 \u0431\u0435\u0441\u0438\u0442 \u0432 React \u0447\u0442\u043e-\u0442\u043e, \u0447\u0442\u043e \u044f \u043d\u0435 \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u043b, \u043d\u0435 \u0441\u0442\u0435\u0441\u043d\u044f\u0439\u0442\u0435\u0441\u044c \u043f\u0438\u0441\u0430\u0442\u044c \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445, \u0431\u044b\u043b\u043e \u0431\u044b \u043e\u0447\u0435\u043d\u044c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e \u0441\u0440\u0430\u0432\u043d\u0438\u0442\u044c \u043c\u043e\u0438 \u043e\u0449\u0443\u0449\u0435\u043d\u0438\u044f \u0441 \u0432\u0430\u0448\u0438\u043c\u0438.<\/p>\n<p>\u0418 \u0432\u0430\u0436\u043d\u043e\u0435: \u043d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u044b\u0435 \u043d\u0438\u0436\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b, \u044f \u0434\u043e \u0441\u0438\u0445 \u043f\u043e\u0440 \u0441\u0447\u0438\u0442\u0430\u044e React \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u043c \u0438 \u0443\u0434\u043e\u0431\u043d\u044b\u043c \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u043c \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434\u0430, \u0432 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438 SPA.\u0413\u0440\u043e\u043c\u043a\u0438\u0445 \u0441\u043b\u043e\u0432 \u0442\u0438\u043f\u0430 \u00abReactJS \u043d\u0435 \u043f\u0440\u0438\u0433\u043e\u0434\u0435\u043d \u0434\u043b\u044f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438\u00bb \u0442\u0443\u0442 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 &#8212; \u043f\u0440\u0438\u0433\u043e\u0434\u0435\u043d, \u0434\u0430 \u0435\u0449\u0451 \u043a\u0430\u043a! \u041d\u043e&#8230; \u0438 \u043d\u0430 \u0421\u043e\u043b\u043d\u0446\u0435 \u0431\u044b\u0432\u0430\u044e\u0442 \u043f\u044f\u0442\u043d\u0430.\u041f\u0440\u0438\u0441\u0442\u0443\u043f\u0438\u043c.<\/p>\n<h3>\u0422\u0432\u043e\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0442\u0430\u043a\u0430\u044f \u0442\u043e\u043b\u0441\u0442\u0430\u044f&#8230;<\/h3>\n<p>\u0412\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0430 Internet Explorer 9-10 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 jQuery (\u043f\u043e\u043c\u043d\u0438\u0442\u0435 \u0442\u0430\u043a\u0443\u044e?) \u0441\u0447\u0438\u0442\u0430\u043b\u0430\u0441\u044c \u043e\u0447\u0435\u043d\u044c \u0442\u044f\u0436\u0451\u043b\u043e\u0439. \u041c\u043d\u043e\u0433\u0438\u0435 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u043e\u0432\u0430\u043b\u0438 \u0441\u0442\u0430\u0440\u0430\u0442\u044c\u0441\u044f \u0438\u0437\u0431\u0435\u0433\u0430\u0442\u044c \u0435\u0451 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f, \u0445\u043e\u0442\u044f \u0432 \u0442\u0435 \u0434\u0438\u043a\u0438\u0435 \u0432\u0440\u0435\u043c\u0435\u043d\u0430 jQuery \u0431\u044b\u043b\u0430 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435\u0437\u0430\u043c\u0435\u043d\u0438\u043c\u0430. \u0420\u0430\u0437\u043c\u0435\u0440 \u0435\u0451 \u0431\u0430\u043d\u0434\u043b\u0430 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u043b \u0441\u0442\u0440\u0430\u0448\u043d\u044b\u0435 \u043d\u0430 \u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 72 \u041a\u0431\u00a0 (\u043c\u0438\u043d\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0438\u044f 1.4.2).\u0418 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 jQuery \u043a\u0430\u043a \u043c\u043e\u0433\u043b\u0438 \u0441\u0442\u0430\u0440\u0430\u043b\u0438\u0441\u044c \u0443\u043c\u0435\u043d\u044c\u0448\u0430\u0442\u044c \u0435\u0433\u043e, \u043a \u043f\u0440\u0438\u043c\u0435\u0440\u0443, \u0440\u0430\u0437\u0434\u0435\u043b\u044f\u044f \u043d\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0431\u0430\u043d\u0434\u043b\u043e\u0432 \u0441 \u0440\u0430\u0437\u043d\u044b\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u043e\u043c.<\/p>\n<p>\u0421\u0435\u0439\u0447\u0430\u0441 \u043d\u0430 \u0434\u0432\u043e\u0440\u0435 2025 \u0433\u043e\u0434 \u0438 \u043d\u0435 \u043f\u0440\u0438\u043d\u044f\u0442\u043e \u0441\u0447\u0438\u0442\u0430\u0442\u044c \u0431\u0430\u0439\u0442\u044b \u0438 \u0434\u0430\u0436\u0435 \u043a\u0438\u043b\u043e\u0431\u0430\u0439\u0442\u044b. \u0422\u043e, \u0447\u0442\u043e JS-\u0431\u0430\u043d\u0434\u043b \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c \u0441 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u043c\u0435\u0433\u0430\u0431\u0430\u0439\u0442, \u0443\u0436\u0435 \u043c\u0430\u043b\u043e \u043a\u043e\u0433\u043e \u0448\u043e\u043a\u0438\u0440\u0443\u0435\u0442 (\u0445\u043e\u0442\u044f \u044f \u0434\u043e \u0441\u0438\u0445 \u043f\u043e\u0440 \u043c\u043e\u0433\u0443 \u0432\u0437\u0434\u0440\u043e\u0433\u043d\u0443\u0442\u044c, \u0433\u043b\u044f\u0434\u044f \u0432 \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u0430 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430, \u043d\u043e \u044d\u0442\u043e \u043f\u0440\u043e\u0444\u0434\u0435\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f). <\/p>\n<p>\u0412 \u0442\u0440\u0435\u043d\u0434\u0435 \u043b\u0438 React?<\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0443\u0437\u043d\u0430\u0435\u043c. \u042f \u0441\u043e\u0437\u0434\u0430\u043b \u043f\u0440\u043e\u0435\u043a\u0442 \u043d\u0430 React \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e Vite \u0438 \u043c\u043e\u0434\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043b \u043a\u043e\u043d\u0444\u0438\u0433 \u0441\u0431\u043e\u0440\u043a\u0438, \u0447\u0442\u043e\u0431 \u0432\u044b\u0434\u0435\u043b\u0438\u0442\u044c React \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0447\u0430\u043d\u043a:<\/p>\n<pre><code class=\"javascript\">import { defineConfig } from 'vite' import react from '@vitejs\/plugin-react'  \/\/ https:\/\/vite.dev\/config\/ export default defineConfig({   build: {     rollupOptions: {       output: {       \/\/ \u0414\u043e\u0431\u0430\u0432\u0438\u043c \u0432\u044b\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 React \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0447\u0430\u043d\u043a         manualChunks: {           react: ['react'],         }       }     }   },   plugins: [react()], })<\/code><\/pre>\n<p>\u0421\u043e\u0431\u0435\u0440\u0451\u043c \u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0442\u0430\u043a\u043e\u0439 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442:<\/p>\n<pre><code class=\"javascript\">vite v6.2.1 building for production... \u2713 30 modules transformed. dist\/index.html                   0.54 kB \u2502 gzip:  0.33 kB dist\/assets\/react-CHdo91hT.svg    4.13 kB \u2502 gzip:  2.05 kB dist\/assets\/index-n_ryQ3BS.css    1.39 kB \u2502 gzip:  0.71 kB dist\/assets\/react-yBjzXJbu.js     6.79 kB \u2502 gzip:  2.72 kB dist\/assets\/index-CkN_Kf_f.js   137.38 kB \u2502 gzip: 44.22 kB \u2713 built in 380ms<\/code><\/pre>\n<p>\u0421\u0430\u043c \u043f\u043e \u0441\u0435\u0431\u0435 React \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u0431\u0443\u043a\u0432\u0430\u043b\u044c\u043d\u043e \u043c\u0435\u043d\u044c\u0448\u0435 7 \u041a\u0431!\u00a0 \u042d\u0442\u043e \u0434\u0430\u0436\u0435 \u043c\u0435\u043d\u044c\u0448\u0435 preact (~ 11 \u041a\u0431), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u044f\u0432\u043b\u044f\u0435\u0442 \u0441\u0435\u0431\u044f \u043b\u0435\u0433\u043a\u043e\u0439 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u043e\u0439. \u0422\u0430\u043a \u0447\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0432\u0440\u0443\u0442 \u043e \u0442\u043e\u043c, \u0447\u0442\u043e React \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0438 \u043f\u0440\u043e\u0436\u043e\u0440\u043b\u0438\u0432\u044b\u0439? \u041d\u043e \u0447\u0442\u043e \u0437\u0430 \u043e\u0441\u0442\u0430\u0432\u0448\u0438\u0435\u0441\u044f 137 \u041a\u0431&#8230;<\/p>\n<p>\u041e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e-\u0442\u043e \u0442\u0443\u0442 \u043d\u0435 \u0442\u0430\u043a. \u041f\u043e\u0433\u043b\u044f\u0434\u0438\u043c \u043d\u0430 \u043d\u0430\u0448 \u0441\u043f\u0438\u0441\u043e\u043a \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439 \u0438\u00a0 \u0432\u044b\u0434\u0435\u043b\u0438\u043c \u0435\u0449\u0451 \u043e\u0434\u0438\u043d \u0447\u0430\u043d\u043a:<\/p>\n<pre><code class=\"javascript\">reactDOM: ['react-dom\/client']<\/code><\/pre>\n<p>\u0418 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442: <\/p>\n<pre><code class=\"javascript\">\u2713 30 modules transformed. dist\/index.html                     0.62 kB \u2502 gzip:  0.35 kB dist\/assets\/react-CHdo91hT.svg      4.13 kB \u2502 gzip:  2.05 kB dist\/assets\/index-n_ryQ3BS.css      1.39 kB \u2502 gzip:  0.71 kB dist\/assets\/index-Xo5bg2S4.js       2.59 kB \u2502 gzip:  1.33 kB dist\/assets\/react-yBjzXJbu.js       6.79 kB \u2502 gzip:  2.72 kB dist\/assets\/reactDOM-CKhEkZwU.js  134.78 kB \u2502 gzip: 43.26 kB<\/code><\/pre>\n<p>\u041f\u043e\u0447\u0442\u0438 135 \u041a\u0431 \u044d\u0442\u043e React-DOM! \u0418 \u0431\u0435\u0434\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0431\u0435\u0437 \u043d\u0435\u0433\u043e \u0441\u0430\u043c \u043f\u043e \u0441\u0435\u0431\u0435 React \u043d\u0435 \u0437\u0430\u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 &#8212; \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u0441\u043c\u043e\u0436\u0435\u0442 \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c DOM-\u0434\u0435\u0440\u0435\u0432\u043e. \u0427\u0442\u043e \u0441\u043a\u0440\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u0431\u0435\u0437 \u043c\u0430\u043b\u043e\u0433\u043e 135 \u043a\u0438\u043b\u043e\u0431\u0430\u0439\u0442\u0430\u0445 \u043c\u0438\u043d\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430 &#8212; \u044f \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u044e \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0438, \u0447\u0435\u0441\u0442\u043d\u043e \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u0441\u0442\u0440\u0430\u0448\u043d\u043e \u0432\u043d\u0438\u043a\u0430\u0442\u044c \u0432 \u044d\u0442\u043e \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e. \u0424\u0430\u043a\u0442 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0432\u0430\u043c \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u043f\u0430\u043a\u0435\u0442 react, \u0447\u0442\u043e\u0431 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f React. \u0412\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 135 \u041a\u0431\u00a0 \u043a\u043e\u0434\u0430, \u0447\u0442\u043e\u0431 \u0445\u043e\u0442\u044c \u0447\u0442\u043e-\u0442\u043e \u043e\u0442\u043e\u0431\u0440\u0430\u0437\u0438\u0442\u044c!<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/b4c\/b01\/b7f\/b4cb01b7f4d8393cb0b20dbfa21163d0.png\" width=\"704\" height=\"798\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b4c\/b01\/b7f\/b4cb01b7f4d8393cb0b20dbfa21163d0.png\"\/><\/figure>\n<p>\u0418\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e, \u043a\u0441\u0442\u0430\u0442\u0438, \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u043d\u0435 \u0431\u044b\u043b\u043e \u0438 React \u043f\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u043b\u0441\u044f \u043e\u0434\u043d\u0438\u043c \u0444\u0430\u0439\u043b\u043e\u043c. React-DOM \u0431\u044b\u043b \u0432\u044b\u0434\u0435\u043b\u0435\u043d \u0432 \u0432\u0435\u0440\u0441\u0438\u0438 0.14 \u0441 \u0446\u0435\u043b\u044c\u044e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0443 React \u0431\u043e\u043b\u0435\u0435 \u043c\u043e\u0434\u0443\u043b\u044c\u043d\u043e\u0439. \u042d\u0442\u043e (\u043f\u043e \u0437\u0430\u0434\u0443\u043c\u043a\u0435) \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0433\u0440\u0430\u043c\u043e\u0442\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u043a\u043b\u0438\u0435\u043d\u0442\u0435, \u043d\u043e \u0438 \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0435 \u0438\u043b\u0438 \u0432 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u0439 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0435. \u041d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u0438\u043b\u044c\u043d\u043e \u0431\u044b\u043b\u043e \u043d\u0443\u0436\u043d\u043e \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0431\u0430\u043d\u0434\u043b\u0430 \u0432 140 \u041a\u0431 \u043d\u0430 \u0434\u0432\u0430 \u0432 7 \u0438 135 \u041a\u0431 &#8212; \u043d\u0435 \u043c\u043d\u0435 \u0441\u0443\u0434\u0438\u0442\u044c, \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u043e\u043d\u043e \u043f\u043e\u043c\u043e\u0433\u043b\u043e \u0432 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 \u0442\u043e\u0433\u043e \u0436\u0435 React-Native. \u0422\u043e\u043b\u044c\u043a\u043e \u0432\u043e\u0442&#8230; React \u0434\u043b\u044f \u0441\u0432\u043e\u0435\u0433\u043e \u043c\u043e\u043d\u0441\u0442\u0440\u0443\u043e\u0437\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u0430 \u0443\u043c\u0435\u0435\u0442 \u0443\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043c\u0430\u043b\u043e. \u0423 \u043d\u0435\u0433\u043e \u043d\u0435\u0442 \u0440\u043e\u0443\u0442\u0435\u0440\u0430, \u043d\u0435\u0442 \u0441\u0440\u0435\u0434\u0441\u0442\u0432 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 http-\u0437\u0430\u043f\u0440\u043e\u0441\u0430\u043c\u0438 (\u0432 19 \u0432\u0440\u043e\u0434\u0435 \u043f\u043e\u044f\u0432\u0438\u043b\u043e\u0441\u044c),\u00a0 \u043d\u0435\u0442 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0438\u043b\u0438 \u0445\u043e\u0442\u044f \u0431\u044b \u043d\u0430\u0431\u043e\u0440\u0430 \u0441\u0442\u0438\u043b\u0435\u0439! \u0423\u043f\u0440\u043e\u0449\u0451\u043d\u043d\u043e, \u0432\u043d\u0443\u0442\u0440\u0438 React \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u043a\u0430\u0447\u0430\u043d\u043d\u044b\u0439 \u0448\u0430\u0431\u043b\u043e\u043d\u0438\u0437\u0430\u0442\u043e\u0440, \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e \u0440\u0430\u0431\u043e\u0442\u044b \u0441 DOM (\u043d\u0430\u0434\u043e \u043f\u0440\u0438\u0437\u043d\u0430\u0442\u044c, \u043c\u043e\u0449\u043d\u0435\u0439\u0448\u0435\u0435) \u0438 \u043d\u0435\u043a\u043e\u0435 \u043f\u043e\u0434\u043e\u0431\u0438\u0435 \u0441\u0442\u0435\u0439\u0442-\u043c\u0435\u043d\u0435\u0434\u0436\u043c\u0435\u043d\u0442\u0430 \u0432 \u043b\u0438\u0446\u0435 \u0445\u0443\u043a\u043e\u0432.<\/p>\n<p>\u0418 \u0432\u0441\u0451 \u044d\u0442\u043e \u0432 preact (\u0441 \u0440\u0435\u043d\u0434\u0435\u0440\u043e\u043c \u0432 DOM) \u0441\u043f\u043e\u043a\u043e\u0439\u043d\u043e \u0432\u043c\u0435\u0449\u0430\u0435\u0442\u0441\u044f \u0432 11 \u041a\u0431, \u0447\u0442\u043e \u0432 12 \u0440\u0430\u0437 \u043c\u0435\u043d\u044c\u0448\u0435 \u043f\u0440\u0430\u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044f. \u0411\u0430\u043d\u0434\u043b Vue \u0441 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0435\u043c\u0438 \u0436\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044f\u043c\u0438 (\u0438 \u043c\u043d\u043e\u0433\u0438\u043c\u0438 \u043f\u0440\u0438\u044f\u0442\u043d\u044b\u043c\u0438 \u0444\u0438\u0447\u0430\u043c\u0438 \u0442\u0438\u043f\u0430 \u0438\u0437\u043e\u043b\u044f\u0446\u0438\u0438 \u0441\u0442\u0438\u043b\u0435\u0439 \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u0438\u043b\u0438 \u0441\u043b\u043e\u0442\u043e\u0432) \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 60 \u041a\u0411. Angular, \u0442\u043e\u0436\u0435 \u043c\u043e\u043d\u0441\u0442\u0440\u0443\u043e\u0437\u043d\u044b\u0439, \u0441\u0440\u0430\u0432\u043d\u0438\u043c \u0441 react-dom &#8212; \u0431\u0430\u043d\u0434\u043b \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 ~ 160 \u041a\u0431, \u043d\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e 60 \u0438\u0437 \u043d\u0438\u0445 \u044d\u0442\u043e \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0439 \u0440\u043e\u0443\u0442\u0435\u0440, \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0439 \u043f\u043e\u0441\u0442\u0430\u0432\u043a\u0435 React \u043d\u0435\u0442, \u0434\u0430 \u0438 \u043f\u043e \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044f\u043c Angular \u0433\u043e\u0440\u0430\u0437\u0434\u043e \u0431\u043e\u0433\u0430\u0447\u0435.\u00a0 \u0412\u043e\u0442 \u0438 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0438\u0437 \u0432\u0441\u0435\u0445 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0445 \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434-\u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u043e\u0432 (\u0434\u0430 \u0437\u043d\u0430\u044e \u044f, \u0447\u0442\u043e React \u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u043e\u0439, \u0437\u043d\u0430\u044e) React \u043e\u043a\u0430\u0437\u0430\u043b\u0441\u044f \u0441\u0430\u043c\u044b\u043c \u0442\u044f\u0436\u0451\u043b\u044b\u043c.\u00a0 \u041f\u0440\u0438\u0447\u0451\u043c, \u0432\u0441\u0435 \u044d\u0442\u0438 \u043a\u0438\u043b\u043e\u0431\u0430\u0439\u0442\u044b \u043d\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u0437\u0430\u0433\u0440\u0443\u0436\u0430\u044e\u0442\u0441\u044f, \u0430 \u0430\u043a\u0442\u0438\u0432\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f. \u041d\u0435\u0443\u0436\u0435\u043b\u0438 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u044b VirtualDOM \u0438 Reconciliation \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0433\u0440\u043e\u043c\u043d\u044b? \u0418 \u0435\u0441\u043b\u0438 \u0434\u0430, \u0442\u043e \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u043b\u0438 \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u0432\u044b\u0438\u0433\u0440\u044b\u0448 \u0432 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0441 \u0442\u0430\u043a\u0438\u043c \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u043e\u0432\u0435\u0440\u0445\u044d\u0434\u043e\u043c? \u0421\u0443\u0434\u044f \u043f\u043e <a href=\"https:\/\/krausest.github.io\/js-framework-benchmark\/current.html\" rel=\"noopener noreferrer nofollow\">\u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u0430\u043c<\/a> &#8212; \u0432\u0441\u0451 \u043e\u0447\u0435\u043d\u044c \u043f\u043b\u043e\u0445\u043e \u0438 React \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0435\u0435 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0430 \u0430\u043d\u0430\u043b\u043e\u0433\u043e\u0432 \u0431\u0435\u0437 VirtualDOM (\u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0432\u043f\u0435\u0447\u0430\u0442\u043b\u044f\u0435\u0442 \u0432 \u044d\u0442\u043e\u043c \u043f\u043b\u0430\u043d\u0435 Solid, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u0445\u043e\u0436 \u043d\u0430 React \u0441\u043d\u0430\u0440\u0443\u0436\u0438, \u043d\u043e \u043a\u0430\u0440\u0434\u0438\u043d\u0430\u043b\u044c\u043d\u043e \u0434\u0440\u0443\u0433\u043e\u0439 \u0432\u043d\u0443\u0442\u0440\u0438). \u041f\u043e\u0447\u0435\u043c\u0443 &#8212; \u0442\u0435\u043c\u0430 \u0434\u043b\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438.<\/p>\n<h3>JSX \u044d\u0442\u043e \u043f\u043e\u0447\u0442\u0438 HTML. \u041d\u043e \u043d\u0435 HTML.<\/h3>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/a4f\/39c\/a8a\/a4f39ca8a706b2ea80198b63f96b8e9b.png\" width=\"1398\" height=\"1040\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a4f\/39c\/a8a\/a4f39ca8a706b2ea80198b63f96b8e9b.png\"\/><\/figure>\n<p>\u041f\u043e\u043d\u044f\u0442\u043d\u043e, \u0447\u0442\u043e JSX = JS + XML, \u044f \u044d\u0442\u043e \u0437\u043d\u0430\u044e. \u041d\u043e \u0432 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0435 \u0437\u0430\u0434\u0430\u0447 JSX \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0438\u043c\u0435\u043d\u043d\u043e \u043a\u0430\u043a \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u0435\u043b\u044c HTML-\u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0438 \u0438 \u043f\u043e \u0444\u0430\u043a\u0442\u0443 \u043a\u0443\u0434\u0430 \u0431\u043b\u0438\u0436\u0435 \u043a HTML, \u0447\u0435\u043c \u043a XML. \u0418\u0437 \u044d\u0442\u043e\u0433\u043e \u0438 \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u0445\u043e\u0434\u0438\u0442\u044c.<\/p>\n<p>\u041e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u044f\u0437\u044b\u043a \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f JavaScript \u0438 \u044f\u0437\u044b\u043a \u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0438 HTML &#8212; \u043e\u0447\u0435\u043d\u044c \u0440\u0430\u0437\u043d\u044b\u0435 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0441 \u0434\u0440\u0443\u0433\u0438\u043c, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u0431\u0443\u0434\u0435\u0442 \u043a\u043e\u043c\u043f\u0440\u043e\u043c\u0438\u0441\u0441\u043e\u043c. JSX \u043a\u0430\u043a \u0440\u0430\u0437 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u0430\u044f \u0438\u043b\u043b\u044e\u0441\u0442\u0440\u0430\u0446\u0438\u044f \u0442\u0430\u043a\u043e\u0433\u043e \u043a\u043e\u043c\u043f\u0440\u043e\u043c\u0438\u0441\u0441\u0430.<\/p>\n<p>\u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0432\u044b \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0430\u0442\u0440\u0438\u0431\u0443\u0442 <em>class<\/em> &#8212; \u0432\u043c\u0435\u0441\u0442\u043e \u043d\u0435\u0433\u043e \u043d\u0443\u0436\u043d\u043e \u043f\u0438\u0441\u0430\u0442\u044c <em>className<\/em>, \u0432\u0435\u0434\u044c <em>class<\/em> &#8212; \u044d\u0442\u043e \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0435 \u0441\u043b\u043e\u0432\u043e <em>JS<\/em> (\u043f\u0440\u0438\u0447\u0451\u043c, \u043e\u043d\u043e \u0431\u044b\u043b\u043e \u0442\u0430\u043a\u043e\u0432\u044b\u043c \u0435\u0449\u0451 \u0434\u043e \u043f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u044f \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0432 \u044f\u0437\u044b\u043a\u0435) . \u0410\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0441 for-htmlFor &#8212; \u043e\u043a\u0435\u0439, \u0442\u0443\u0442 \u0442\u043e\u0436\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e. \u0417\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u044c 2 \u043e\u0442\u043b\u0438\u0447\u0438\u044f, \u043d\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430.<\/p>\n<p>\u0422\u0443\u0442 \u0435\u0441\u0442\u044c 2 \u0437\u0430\u0431\u0430\u0432\u043d\u044b\u0445 \u043c\u043e\u043c\u0435\u043d\u0442\u0430. \u041f\u0435\u0440\u0432\u044b\u0439: \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u0438\u0441\u0430\u0442\u044c class, \u0438 \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c, \u043d\u043e React \u043f\u043e\u0440\u0443\u0433\u0430\u0435\u0442\u0441\u044f \u0432 \u0441\u0442\u0438\u043b\u0435 \u00ab\u043d\u0435 \u043d\u0430\u0434\u043e \u0442\u0430\u043a\u00bb. \u0412\u0442\u043e\u0440\u043e\u0439:\u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u0432 \u0442\u0430\u043a\u043e\u043c \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0438 \u043d\u0435 \u0431\u044b\u043b\u043e. \u0412 Preact, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0442\u043e\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 JSX, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0432\u043f\u043e\u043b\u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0438\u0441\u044c \u0442\u0440\u0430\u0434\u0438\u0446\u0438\u043e\u043d\u043d\u044b\u0435 HTML-\u043d\u044b\u0435 class \u0438 for (\u0442\u0443\u0442 \u0441\u043c\u0435\u0448\u043d\u043e, \u0447\u0442\u043e \u0440\u0430\u0434\u0438 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u0438 \u0441 React \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430\u043c Preact <a href=\"https:\/\/github.com\/preactjs\/preact\/pull\/695\" rel=\"noopener noreferrer nofollow\">\u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u043d\u0430 htmlFor<\/a>).<\/p>\n<p>\u0418\u043b\u0438 \u0435\u0449\u0451 \u043c\u043e\u043c\u0435\u043d\u0442 &#8212; \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u0435 \u043a \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430.React \u043f\u0440\u0438 \u0432\u0441\u0435\u0439 \u0435\u0433\u043e \u0441\u0432\u043e\u0431\u043e\u0434\u0435 \u043c\u0435\u0441\u0442\u0430\u043c\u0438 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u0435\u043d. \u041e\u043d \u043d\u0435 \u043f\u0440\u043e\u0436\u0443\u0451\u0442 \u043d\u0430\u043b\u0438\u0447\u0438\u0435 \u0431\u043e\u043b\u0435\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0438 \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043e\u0431\u0435\u0440\u043d\u0443\u0442\u044c \u0432\u0441\u044e \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u044e \u0432 \u0445\u043e\u0442\u044f \u0431\u044b React.Fragment (\u0441\u0435\u0439\u0447\u0430\u0441, \u043a \u0441\u0447\u0430\u0441\u0442\u044c\u044e, \u0441\u043e\u043a\u0440\u0430\u0449\u0430\u044e\u0449\u0438\u0439\u0441\u044f \u0434\u043e &lt;&gt;&lt;\/&gt;).\u042f \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u044e, \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435\u044f\u0432\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0442\u044c \u044d\u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 &lt;&gt;&lt;\/&gt; \u0431\u044b\u043b\u043e \u0431\u044b (\u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435) \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0445\u043e\u0440\u043e\u0448\u0435\u0439 \u0438\u0434\u0435\u0435\u0439, \u043d\u043e \u043c\u0435\u043d\u044c\u0448\u0435 \u0440\u0430\u0437\u0434\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u044c \u0434\u0435\u043b\u0430\u0442\u044c \u044d\u0442\u043e \u043d\u0435 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442.<\/p>\n<p>\u041d\u043e \u0441\u0442\u043e\u0438\u043b\u043e \u043d\u0430\u043c \u0441\u043c\u0438\u0440\u0438\u0442\u044c\u0441\u044f \u0441 \u044d\u0442\u0438\u043c\u0438 \u0440\u0430\u0437\u043b\u0438\u0447\u0438\u044f\u043c\u0438, \u043d\u0430 \u0441\u0446\u0435\u043d\u0443 \u0432\u044b\u0445\u043e\u0434\u044f\u0442 \u0435\u0449\u0451 \u0438 \u0435\u0449\u0451. HTML case-insensitive \u044f\u0437\u044b\u043a &#8212; \u0447\u0442\u043e \u0442\u044d\u0433\u0438, \u0447\u0442\u043e \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b \u043c\u043e\u0436\u043d\u043e \u043f\u0438\u0441\u0430\u0442\u044c \u0432 \u043a\u0430\u043a\u043e\u043c \u0443\u0433\u043e\u0434\u043d\u043e \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0435.\u0422\u0430\u043a\u043e\u0439 \u043a\u043e\u0434 \u0432 HTML \u0431\u0443\u0434\u0435\u0442 \u0432\u043f\u043e\u043b\u043d\u0435 \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u0435\u043d \u0438 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0440\u043e\u0432\u043d\u043e \u0442\u0430\u043a, \u043a\u0430\u043a \u0434\u043e\u043b\u0436\u0435\u043d (\u0447\u0442\u043e, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u0441\u043e\u0432\u0441\u0435\u043c \u043d\u0435 \u043f\u043e\u0432\u043e\u0434 \u0442\u0430\u043a \u043f\u0438\u0441\u0430\u0442\u044c):<\/p>\n<pre><code class=\"javascript\">&lt;!DOCTYPE html&gt; &lt;html lang='en'&gt; &lt;head&gt; &lt;title&gt;CaSe INsensITIVe&lt;\/title&gt; &lt;\/head&gt; &lt;body&gt; &lt;DIV&gt;     &lt;sPaN&gt;Hello&lt;\/SpAn&gt;     &lt;button ONCLICK='alert(\"hello\")'&gt;HELLO&lt;\/button&gt; &lt;\/DIV&gt; &lt;\/body&gt;<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u043d\u0435 \u0432\u0435\u0440\u0438\u0442\u0435 &#8212; \u043f\u0440\u043e\u0432\u0435\u0440\u044c\u0442\u0435 \u043d\u0430 \u0432\u0430\u043b\u0438\u0434\u0430\u0442\u043e\u0440\u0435 W3C. \u041a\u043e\u0434 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u0432\u0430\u043b\u0438\u0434\u0435\u043d, \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442 \u0432\u0430\u043b\u0438\u0434\u0430\u0442\u043e\u0440\u0430 \u043d\u0438\u0436\u0435<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/cfe\/7ed\/685\/cfe7ed68586caf3f6835874a09e6773e.png\" width=\"1398\" height=\"1064\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/cfe\/7ed\/685\/cfe7ed68586caf3f6835874a09e6773e.png\"\/><\/figure>\n<p>\u0410 \u0432\u043e\u0442 React+JSX \u0442\u0430\u043a\u043e\u0435 \u0443\u0436\u0435 \u043d\u0435 \u043f\u0440\u043e\u0433\u043b\u043e\u0442\u044f\u0442. \u0412 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435, \u044d\u0442\u043e \u043d\u0435 \u0431\u0435\u0434\u0430, \u0432\u0435\u0434\u044c \u043a\u043e\u043c\u0443 \u0432 \u0437\u0434\u0440\u0430\u0432\u043e\u043c \u0443\u043c\u0435 \u043f\u0440\u0438\u0434\u0451\u0442 \u0432 \u0433\u043e\u043b\u043e\u0432\u0443 \u0438\u0433\u0440\u0430\u0442\u044c\u0441\u044f \u0441 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u043e\u043c \u0432 HTML-\u0442\u044d\u0433\u0430\u0445. \u041d\u043e! \u0412\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0447\u0451\u0442\u043a\u043e \u043f\u043e\u043c\u043d\u0438\u0442\u044c, \u0447\u0442\u043e \u0432\u043c\u0435\u0441\u0442\u043e onclick \u043d\u0430\u0434\u043e \u043f\u0438\u0441\u0430\u0442\u044c onClick (\u0438 \u043d\u0438\u043a\u0430\u043a \u0438\u043d\u0430\u0447\u0435), \u0441 \u0434\u0440\u0443\u0433\u0438\u043c\u0438 \u044d\u0432\u0435\u043d\u0442\u0430\u043c\u0438 \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e, \u0430\u0442\u0440\u0438\u0431\u0443\u0442 readonly \u043f\u0438\u0448\u0435\u0442\u0441\u044f \u043a\u0430\u043a readOnly (\u0438 \u043d\u0438\u043a\u0430\u043a \u0438\u043d\u0430\u0447\u0435) \u0438 \u0442 \u043f. \u0412\u0441\u0435 \u044d\u0442\u0438 \u0440\u0430\u0437\u043b\u0438\u0447\u0438\u044f \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u044c, \u0438 \u0432\u044b \u0438\u0445 \u0440\u0430\u043d\u043e \u0438\u043b\u0438 \u043f\u043e\u0437\u0434\u043d\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u0435, \u043d\u043e&#8230; \u0417\u0430\u0447\u0435\u043c \u0436\u0435 \u0442\u043e\u0433\u0434\u0430 JSX \u0442\u0430\u043a \u043f\u043e\u0445\u043e\u0436 \u043d\u0430 HTML? \u0422\u043e, \u0447\u0442\u043e \u043c\u044b \u043d\u0435 \u043c\u043e\u0436\u0435\u043c \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u0437\u044f\u0442\u044c \u0438 \u0432\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0433\u043e\u0442\u043e\u0432\u0443\u044e \u0432\u0451\u0440\u0441\u0442\u043a\u0443 \u0432 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u043e\u0447\u0435\u043d\u044c \u0431\u0435\u0441\u0438\u0442 \u0438 \u0432\u044b\u043d\u0443\u0436\u0434\u0430\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0435\u0440\u044b HTML&lt;-&gt;JSX.<\/p>\n<p>\u0410 \u0435\u0449\u0451 \u0438\u043c\u044f \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0434\u043e\u043b\u0436\u043d\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u0442\u044c\u0441\u044f \u0441 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0431\u0443\u043a\u0432\u044b.<\/p>\n<pre><code class=\"javascript\">const comp = () =&gt; {     return &lt;div&gt;comp&lt;\/div&gt; }  const Comp = comp;  const App = () =&gt; {     return (&lt;&gt;         &lt;Comp \/&gt; {\/* Ok *\/}         &lt;comp \/&gt; {\/* \u041e\u0448\u0438\u0431\u043a\u0430 *\/}     &lt;\/&gt;); }<\/code><\/pre>\n<p>\u0412\u043f\u0440\u043e\u0447\u0435\u043c, \u0442\u0430\u043a\u043e\u0435 \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0443\u0436\u0435 \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u0438\u0432\u044b\u0447\u043d\u043e, \u0447\u0442\u043e \u043f\u0440\u043e\u043d\u0438\u043a\u043b\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0435\u0437\u0434\u0435. \u041f\u0440\u043e\u0441\u0442\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u0435 \u0438 \u0436\u0438\u0432\u0438\u0442\u0435 \u0441 \u044d\u0442\u0438\u043c.<\/p>\n<p>\u0420\u0430\u0437\u043b\u0438\u0447\u0438\u044f JSX \u0438 HTML \u043d\u0435 \u0444\u0430\u0442\u0430\u043b\u044c\u043d\u044b\u0435, \u043d\u043e \u0438\u0445 \u043c\u043d\u043e\u0433\u043e \u0438 \u043e\u043d\u0438 \u0440\u0430\u0437\u0434\u0440\u0430\u0436\u0430\u044e\u0442. \u0418 \u0442\u043e, \u0447\u0442\u043e \u0441\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c \u043a \u044d\u0442\u0438\u043c \u043c\u0435\u043b\u043a\u0438\u043c \u043f\u0430\u043a\u043e\u0441\u0442\u044f\u043c \u043f\u0440\u0438\u0432\u044b\u043a\u0430\u0435\u0448\u044c, \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u043e \u043d\u0435 \u043f\u043e\u0432\u043e\u0434 \u043d\u0435 \u043f\u043e\u0431\u0443\u0445\u0442\u0435\u0442\u044c \u043f\u043e \u044d\u0442\u043e\u043c\u0443 \u043f\u043e\u0432\u043e\u0434\u0443.<\/p>\n<h3>\u0420\u0430\u0434\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0432\u043e\u043f\u0440\u043e\u0441\u0430 \u043e\u0448\u0438\u0431\u043e\u043a<\/h3>\n<p>\u041d\u0430 \u043c\u043e\u0439 \u0432\u0437\u0433\u043b\u044f\u0434 &#8212; \u0441\u0430\u043c\u0430\u044f \u0436\u0443\u0442\u043a\u0430\u044f \u043d\u0435\u0434\u043e\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043d\u0430\u0448\u0435\u0439 \u043b\u044e\u0431\u0438\u043c\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438.<\/p>\n<p>\u0417\u043d\u0430\u043a\u043e\u043c\u0430\u044f \u043b\u044e\u0431\u043e\u043c\u0443 \u043e\u043f\u044b\u0442\u043d\u043e\u043c\u0443 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0443 React \u043a\u0430\u0440\u0442\u0438\u043d\u0430 &#8212; \u0438\u0437\u043c\u0435\u043d\u044f\u0435\u0448\u044c \u043a\u043e\u0434 \u043a\u0430\u043a\u043e\u0433\u043e-\u0442\u043e \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 \u0438&#8230; \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0448\u044c \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0441 \u0431\u0435\u043b\u044b\u043c \u044d\u043a\u0440\u0430\u043d\u043e\u043c.\u042d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0440\u0435\u0430\u043b\u044c\u043d\u0430\u044f \u043e\u0448\u0438\u0431\u043a\u0430, \u043e\u043f\u0435\u0447\u0430\u0442\u043a\u0430 \u0438\u043b\u0438 \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 &#8212; \u043f\u043b\u0435\u0432\u0430\u0442\u044c, \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043f\u0430\u0434\u0430\u0435\u0442 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e.<\/p>\n<p>\u0412\u043e\u0442 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u043f\u0440\u0438\u043c\u0435\u0440:<\/p>\n<pre><code class=\"javascript\">import { useEffect, useState } from 'react';  export const ErrorItem = () =&gt; {     let [value, setValue] = useState('hello');     useEffect(() =&gt; {         setTimeout(() =&gt; {             setValue({message: 'hello'})             }, 2000)     }, []);      return &lt;div&gt;{value}&lt;\/div&gt; }<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u0432\u044b \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 ErrorItem, \u0441\u043f\u0443\u0441\u0442\u044f \u043f\u0430\u0440\u0443 \u0441\u0435\u043a\u0443\u043d\u0434 \u043e\u0431\u043d\u0430\u0440\u0443\u0436\u0438\u0442\u0435, \u0447\u0442\u043e \u0432\u0441\u0451 \u0432\u0430\u0448\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0443\u043f\u0430\u043b\u043e. \u041d\u0435 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u0430 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0432\u0441\u0451, \u0434\u043e \u043f\u0443\u0441\u0442\u043e\u0433\u043e \u044d\u043a\u0440\u0430\u043d\u0430.React \u043f\u0440\u0438 \u043e\u0448\u0438\u0431\u043a\u0435 \u0432 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0442\u043c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u0442 \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0441\u0451 DOM-\u0434\u0435\u0440\u0435\u0432\u043e, \u0433\u0434\u0435 \u043e\u043d \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d. \u041f\u0440\u0438\u0447\u0451\u043c\u00a0 \u0434\u0430\u0436\u0435 \u043f\u0440\u0438\u0447\u0438\u043d\u0430 \u043e\u0448\u0438\u0431\u043a\u0438 \u043d\u0435 \u0441\u0442\u043e\u043b\u044c \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u0430 &#8212; \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u043f\u0440\u043e\u0441\u0442\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u044c, \u0447\u0442\u043e \u0432 JSX-\u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0443 \u043d\u0435\u043b\u044c\u0437\u044f \u043f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0442\u044c \u043e\u0431\u044a\u0435\u043a\u0442, \u044d\u0442\u043e \u0432\u044b\u0437\u043e\u0432\u0435\u0442 \u043e\u0448\u0438\u0431\u043a\u0443 \u0440\u0435\u043d\u0434\u0435\u0440\u0430 (\u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u044b\u0432\u0435\u0441\u0442\u0438 \u044d\u0442\u043e\u0442 \u043e\u0431\u044a\u0435\u043a\u0442 \u043a\u0430\u043a JSON \u043e\u043f\u044f\u0442\u044c \u0436\u0435 \u043d\u0435 \u0432\u043b\u0435\u0437\u043b\u0430 \u0432 135 \u041a\u0431 React-DOM, \u0432\u0438\u0434\u0438\u043c\u043e).<\/p>\n<p>\u041b\u0430\u0434\u043d\u043e, \u043d\u0430\u0432\u0435\u0440\u043d\u044f\u043a\u0430 \u0443 \u0442\u0430\u043a\u043e\u0433\u043e \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u0435\u0441\u0442\u044c \u043f\u0440\u0438\u0447\u0438\u043d\u044b.\u041d\u043e \u0440\u0430\u0437\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u044f \u043d\u0430 Vue, \u044f \u043f\u0440\u043e\u0441\u0442\u043e \u043a\u0430\u0439\u0444\u043e\u0432\u0430\u043b \u0441 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u043f\u0440\u0438 \u043e\u0442\u043b\u0430\u0434\u043a\u0435 \u0442\u0443\u043f\u043e \u0432\u044b\u0432\u0435\u0441\u0442\u0438 \u043e\u0431\u044a\u0435\u043a\u0442 \u043d\u0430 \u044d\u043a\u0440\u0430\u043d. React \u0442\u0430\u043a \u043d\u0435 \u0443\u043c\u0435\u0435\u0442, \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043e\u0431\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0442\u044c \u0432 JSON.stringify.<\/p>\n<p>\u0414\u043b\u044f \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f, \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u044b\u0439 \u043a\u043e\u0434 \u043d\u0430 Vue<\/p>\n<pre><code class=\"javascript\">&lt;script setup&gt; import { ref } from 'vue' let message = ref({hello: {value: 'hello'}})  setTimeout(() =&gt; {     message.value = {hello: null} }, 2000)  &lt;\/script&gt;  &lt;template&gt;     &lt;div&gt;         &lt;span&gt;Hello&lt;\/span&gt;         &lt;div&gt;{{message.hello.value}}&lt;\/div&gt;     &lt;\/div&gt; &lt;\/template&gt;<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u0432\u044b \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 \u0438\u0437 \u044d\u0442\u043e\u0433\u043e \u0444\u0430\u0439\u043b\u0430, \u0442\u043e \u0441\u043f\u0443\u0441\u0442\u044f 2 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u0432\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0435 \u043f\u0443\u0441\u0442\u043e\u0442\u0443 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u043c\u0435\u0441\u0442\u0435, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u043b \u0431\u044b\u0442\u044c \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442. \u041e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u0442\u044c \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c. \u0422\u0410\u041a \u0418 \u0414\u041e\u041b\u0416\u041d\u041e \u0411\u042b\u0422\u042c! \u041f\u041e \u0423\u041c\u041e\u041b\u0427\u0410\u041d\u0418\u042e! \u041f\u0440\u043e\u0441\u0442\u0438\u0442\u0435 \u0437\u0430 \u043a\u0430\u043f\u0441, \u043d\u043e \u0442\u043e, \u0447\u0442\u043e \u0432 React \u044d\u0442\u043e \u043d\u0435 \u0442\u0430\u043a, \u043f\u043e\u0436\u0430\u043b\u0443\u0439, \u0441\u0430\u043c\u043e\u0435 \u0433\u0440\u0443\u0441\u0442\u043d\u043e\u0435, \u0441 \u0447\u0435\u043c \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0441\u0442\u0430\u043b\u043a\u0438\u0432\u0430\u0442\u044c\u0441\u044f \u043f\u0440\u0438 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0435.<\/p>\n<p>\u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435, \u0444\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e \u0435\u0441\u0442\u044c \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b &#8212; ErrorBoundary, <a href=\"https:\/\/react.dev\/reference\/react\/Component#catching-rendering-errors-with-an-error-boundary\" rel=\"noopener noreferrer nofollow\">\u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u0432 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 React<\/a>. \u041d\u043e \u044d\u0442\u043e \u0436\u0435 \u0438\u0437\u0434\u0435\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u0442\u0432\u043e! \u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u0433\u043e\u0442\u043e\u0432\u043e\u0433\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 ErrorBoundary \u0432 \u043f\u043e\u0441\u0442\u0430\u0432\u043a\u0435 React \u043d\u0435\u0442 &#8212; \u0435\u0433\u043e \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u043f\u0438\u0441\u0430\u0442\u044c \u0441\u0430\u043c\u043e\u043c\u0443 \u043b\u0438\u0431\u043e \u0438\u0441\u043a\u0430\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443. \u0412\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, ErrorBoundary \u043c\u043e\u0436\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043a\u043b\u0430\u0441\u0441\u043e\u0432\u044b\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0443 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0445 \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435\u0442 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0445 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439.\u0410 \u0432-\u0442\u0440\u0435\u0442\u044c\u0438\u0445 &#8212; \u043e\u0431\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0442\u044c \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u0432\u043e\u043e\u0431\u0449\u0435 \u043a\u0430\u0436\u0434\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u0438\u043d\u0430\u0447\u0435 \u0440\u0443\u0445\u043d\u0435\u0442 \u0432\u0441\u0451 \u0432\u043d\u0443\u0442\u0440\u0438.\u041f\u0440\u043e\u0441\u0442\u043e \u0440\u0443\u0445\u043d\u0435\u0442 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0431\u043e\u043b\u0435\u0435 \u043a\u0440\u0430\u0441\u0438\u0432\u043e.<\/p>\n<p>\u0418 \u0432\u0435\u0441\u044c \u0443\u0436\u0430\u0441 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u044d\u0442\u043e \u043f\u0440\u0438\u043e\u0431\u0440\u0435\u0442\u0451\u043d\u043d\u044b\u0439 \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043e\u043a.\u0422\u0430\u043a\u043e\u0435 \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043e \u0432 React 16\u00a0 \u0438 \u0431\u044b\u043b\u043e \u0446\u0438\u043d\u0438\u0447\u043d\u043e \u043d\u0430\u0437\u0432\u0430\u043d\u043e <a href=\"https:\/\/legacy.reactjs.org\/blog\/2017\/09\/26\/react-v16.0.html#better-error-handling\" rel=\"noopener noreferrer nofollow\">Better error handling<\/a>.\u0412 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435, \u0434\u043e \u044d\u0442\u043e\u0433\u043e \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0448\u0438\u0431\u043e\u043a \u0432 React \u0442\u043e\u0436\u0435 \u0431\u044b\u043b\u0430 \u043d\u0435 \u0444\u043e\u043d\u0442\u0430\u043d, \u043d\u043e \u044d\u0442\u043e \u0443\u043b\u0443\u0447\u0448\u0435\u043d\u0438\u0435 \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u0441\u0440\u043e\u0434\u043d\u0438 \u043e\u0442\u0440\u0443\u0431\u0430\u043d\u0438\u044e \u0433\u043e\u043b\u043e\u0432\u044b \u043f\u0440\u0438 \u0433\u043e\u043b\u043e\u0432\u043d\u043e\u0439 \u0431\u043e\u043b\u0438.\u0425\u043e\u0440\u043e\u0448\u043e, \u0445\u043e\u0442\u044c \u0441\u0430\u043c\u0438 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 React \u043f\u0440\u0438\u0437\u043d\u0430\u044e\u0442, \u0447\u0442\u043e \u00abit\u2019s probably not the ideal user experience\u00bb.<\/p>\n<h3>React \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e, \u0442\u0438\u043f\u044b \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e<\/h3>\n<p>\u0418\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0439 \u0444\u0430\u043a\u0442 &#8212; React \u0447\u0443\u0442\u044c \u043b\u0438 \u043d\u0435 \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u0430\u044f \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u0430\u044f JavaScript-\u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0434\u043b\u044f \u043f\u043e\u0441\u0442\u0440\u043e\u0435\u043d\u0438\u044f \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430, \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u0430\u044f \u043d\u0435 \u043d\u0430 TypeScript. Vue, Angular, SolidJS \u0438 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u0438\u0433\u0440\u043e\u043a\u043e\u0432 \u043f\u043e\u043c\u0435\u043d\u044c\u0448\u0435 \u0431\u044b\u043b\u0438 \u043b\u0438\u0431\u043e \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043d\u044b \u043d\u0430 TypeScript, \u043b\u0438\u0431\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u044b \u043d\u0430 \u043d\u0451\u043c \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e.<\/p>\n<p>\u042f \u043d\u0435 \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u043b \u0442\u043e\u043f-4, Svelte. \u0415\u0433\u043e \u0442\u043e\u0436\u0435 \u0441 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043e\u0433\u043e\u0432\u043e\u0440\u043a\u043e\u0439 \u043c\u043e\u0436\u043d\u043e \u043e\u0442\u043d\u0435\u0441\u0442\u0438 \u043a \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u043c \u043d\u0430 TypeScript. \u041d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u0432 \u043a\u043e\u0434\u043e\u0432\u043e\u0439 \u0431\u0430\u0437\u0435 \u0441\u043f\u043b\u043e\u0448\u044c JS \u0444\u0430\u0439\u043b\u044b, \u0432\u043d\u0443\u0442\u0440\u0438 \u043d\u0438\u0445 \u0432\u043f\u043e\u043b\u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0442\u0438\u043f\u044b TypeScript \u043f\u043e\u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e\u043c <a href=\"https:\/\/www.typescriptlang.org\/docs\/handbook\/jsdoc-supported-types.html\" rel=\"noopener noreferrer nofollow\">JsDoc<\/a>. \u041d\u0430\u0432\u0435\u0440\u043d\u043e\u0435, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0443 Svelte \u0442\u0430\u043a\u043e\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u043a\u0430\u0436\u0435\u0442\u0441\u044f \u0443\u0434\u043e\u0431\u043d\u044b\u043c.<\/p>\n<p>\u0410 \u0447\u0442\u043e \u0436\u0435 React? \u0415\u0441\u043b\u0438 \u0432\u044b \u0437\u0430\u0439\u0434\u0451\u0442\u0435 \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 <a href=\"https:\/\/github.com\/facebook\/react\/\" rel=\"noopener noreferrer nofollow\">git-\u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f ReactJS<\/a>, \u0442\u043e \u0443\u0432\u0438\u0434\u0438\u0442\u0435 \u0442\u0430\u043a\u0443\u044e \u043a\u0430\u0440\u0442\u0438\u043d\u0443:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/1ce\/c31\/f36\/1cec31f36533b7f211dd012453b20c64.png\" alt=\"\u041b\u0438\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u043e\u0442\u0441\u0442\u0443\u043f\u043b\u0435\u043d\u0438\u0435: \u0414\u0430, \u044f \u0442\u043e\u0436\u0435 \u043f\u043e\u0441\u043c\u0435\u044f\u043b\u0441\u044f \u0441 \u043d\u0430\u043b\u0438\u0447\u0438\u044f \u043a\u043e\u0434\u0430 \u043d\u0430 CoffeeScript. \u041f\u0440\u0438 \u0431\u043b\u0438\u0436\u0430\u0439\u0448\u0435\u043c \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u0438\u0438 \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c,\u00a0 \u0447\u0442\u043e \u043d\u0430 \u043d\u0451\u043c \u043d\u0430\u043f\u0438\u0441\u0430\u043d \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435\u0441\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u044b React \u0441 CoffeeScript.\u00a0 \u0421\u0430\u043c \u0436\u0435 \u044f\u0437\u044b\u043a, \u0441\u0443\u0434\u044f \u043f\u043e \u0433\u0438\u0442\u0445\u0430\u0431\u0443, \u0434\u0430\u0432\u043d\u044b\u043c-\u0434\u0430\u0432\u043d\u043e \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u043b\u0441\u044f \u043d\u0430 \u043f\u043e\u043a\u043e\u0439 - \u0447\u0442\u043e \u043d\u0435\u0443\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e. \u0423\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u0435\u0435, \u0447\u0442\u043e \u0432 2025 \u0433\u043e\u0434\u0443 \u043a\u043e\u0433\u043e-\u0442\u043e \u0432\u043e\u043b\u043d\u0443\u0435\u0442 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u044c React \u0441 CoffeeScript\" title=\"\u041b\u0438\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u043e\u0442\u0441\u0442\u0443\u043f\u043b\u0435\u043d\u0438\u0435: \u0414\u0430, \u044f \u0442\u043e\u0436\u0435 \u043f\u043e\u0441\u043c\u0435\u044f\u043b\u0441\u044f \u0441 \u043d\u0430\u043b\u0438\u0447\u0438\u044f \u043a\u043e\u0434\u0430 \u043d\u0430 CoffeeScript. \u041f\u0440\u0438 \u0431\u043b\u0438\u0436\u0430\u0439\u0448\u0435\u043c \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u0438\u0438 \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c,\u00a0 \u0447\u0442\u043e \u043d\u0430 \u043d\u0451\u043c \u043d\u0430\u043f\u0438\u0441\u0430\u043d \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435\u0441\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u044b React \u0441 CoffeeScript.\u00a0 \u0421\u0430\u043c \u0436\u0435 \u044f\u0437\u044b\u043a, \u0441\u0443\u0434\u044f \u043f\u043e \u0433\u0438\u0442\u0445\u0430\u0431\u0443, \u0434\u0430\u0432\u043d\u044b\u043c-\u0434\u0430\u0432\u043d\u043e \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u043b\u0441\u044f \u043d\u0430 \u043f\u043e\u043a\u043e\u0439 - \u0447\u0442\u043e \u043d\u0435\u0443\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e. \u0423\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u0435\u0435, \u0447\u0442\u043e \u0432 2025 \u0433\u043e\u0434\u0443 \u043a\u043e\u0433\u043e-\u0442\u043e \u0432\u043e\u043b\u043d\u0443\u0435\u0442 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u044c React \u0441 CoffeeScript\" width=\"1304\" height=\"606\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/1ce\/c31\/f36\/1cec31f36533b7f211dd012453b20c64.png\"\/><\/p>\n<div><figcaption>\u041b\u0438\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u043e\u0442\u0441\u0442\u0443\u043f\u043b\u0435\u043d\u0438\u0435: \u0414\u0430, \u044f \u0442\u043e\u0436\u0435 \u043f\u043e\u0441\u043c\u0435\u044f\u043b\u0441\u044f \u0441 \u043d\u0430\u043b\u0438\u0447\u0438\u044f \u043a\u043e\u0434\u0430 \u043d\u0430 CoffeeScript. \u041f\u0440\u0438 \u0431\u043b\u0438\u0436\u0430\u0439\u0448\u0435\u043c \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u0438\u0438 \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c,\u00a0 \u0447\u0442\u043e \u043d\u0430 \u043d\u0451\u043c \u043d\u0430\u043f\u0438\u0441\u0430\u043d \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435\u0441\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u044b React \u0441 CoffeeScript.\u00a0 \u0421\u0430\u043c \u0436\u0435 \u044f\u0437\u044b\u043a, \u0441\u0443\u0434\u044f \u043f\u043e \u0433\u0438\u0442\u0445\u0430\u0431\u0443, \u0434\u0430\u0432\u043d\u044b\u043c-\u0434\u0430\u0432\u043d\u043e \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u043b\u0441\u044f \u043d\u0430 \u043f\u043e\u043a\u043e\u0439 &#8212; \u0447\u0442\u043e \u043d\u0435\u0443\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e. \u0423\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u0435\u0435, \u0447\u0442\u043e \u0432 2025 \u0433\u043e\u0434\u0443 \u043a\u043e\u0433\u043e-\u0442\u043e \u0432\u043e\u043b\u043d\u0443\u0435\u0442 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u044c React \u0441 CoffeeScript<\/figcaption><\/div>\n<\/figure>\n<p>26.5% TypeScript \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u044b \u0432\u0432\u043e\u0434\u0438\u0442\u044c \u0432\u0430\u0441 \u0432 \u0437\u0430\u0431\u043b\u0443\u0436\u0434\u0435\u043d\u0438\u0435 &#8212; \u044d\u0442\u043e, \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u043c, React Compiler. \u0421\u0430\u043c React \u043d\u0430\u043f\u0438\u0441\u0430\u043d \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e Flow &#8212; \u043c\u0435\u043d\u0435\u0435 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u043e\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0438\u0434\u0435\u0438 \u00abJavaScript \u0441 \u0442\u0438\u043f\u0430\u043c\u0438\u00bb \u043e\u0442 Facebook (\u0447\u0442\u043e \u043b\u043e\u0433\u0438\u0447\u043d\u043e, \u0438\u0431\u043e \u043a\u043e\u0440\u043d\u0438 React \u0442\u0430\u043c \u0436\u0435, \u0432 \u0433\u043b\u0443\u0431\u0438\u043d\u0430\u0445 \u0437\u0430\u043f\u0440\u0435\u0449\u0451\u043d\u043d\u043e\u0439 \u0432 \u0420\u0424 \u044d\u043a\u0441\u0442\u0440\u0435\u043c\u0438\u0441\u0442\u0441\u043a\u043e\u0439 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u0438 Meta).<\/p>\n<p>\u041a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u0431\u044b, \u043d\u0443 \u0438 \u0447\u0442\u043e \u0441 \u0442\u043e\u0433\u043e? \u041a\u0430\u043a\u0430\u044f \u0440\u0430\u0437\u043d\u0438\u0446\u0430, \u043d\u0430 \u0447\u0451\u043c \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043e, \u0432 <s>\u0436\u0435\u043b\u0443\u0434\u043a\u0435 \u0432\u0441\u0451 \u043f\u0435\u0440\u0435\u043c\u0435\u0448\u0430\u0435\u0442\u0441\u044f <\/s>\u0432 \u0438\u0442\u043e\u0433\u0435 \u0432\u0441\u0451 \u0442\u0440\u0430\u043d\u0441\u043f\u0438\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 JavaScript. \u041e\u0434\u043d\u0430\u043a\u043e \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e Flow \u0445\u043e\u0442\u044c \u0438 \u043c\u0435\u0441\u0442\u0430\u043c\u0438 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u0445\u043e\u0436 \u043d\u0430 TypeScript (\u043a\u0430\u043a \u0447\u0435\u043b\u043e\u0432\u0435\u043a \u0431\u043e\u043b\u044c\u0448\u0435 \u0433\u043e\u0434\u0430 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0432\u0448\u0438\u0439 \u043f\u0440\u043e\u0435\u043a\u0442 \u043d\u0430 Flow, \u0433\u043e\u0432\u043e\u0440\u044e &#8212; \u0440\u0430\u0437\u043b\u0438\u0447\u0438\u044f \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0435\u0433\u0434\u0430 \u043a\u043e\u0441\u043c\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0435), \u0432 \u043e\u0431\u0449\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0441 \u043d\u0438\u043c \u043d\u0435 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c. \u0422\u0430\u0439\u043f\u0438\u043d\u0433\u0438 \u0434\u043b\u044f TypeScript \u0432 React \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u044e\u0442 &#8212; \u043d\u0435\u0442 TypeScript, \u043d\u0435\u0442 \u0438 \u0442\u0430\u0439\u043f\u0438\u043d\u0433\u043e\u0432. \u0414\u043b\u044f React \u0438\u0445 \u043d\u0443\u0436\u043d\u043e \u0441\u0442\u0430\u0432\u0438\u0442\u044c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u043f\u0430\u043a\u0435\u0442\u043e\u043c <strong>@types\/react<\/strong>.\u00a0 \u0418 \u0435\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u043d\u0435 \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u043b\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043f\u0440\u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0438 React, \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0435 \u0441 \u043d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u043c\u0438 \u0442\u0438\u043f\u0430\u043c\u0438 &#8212; \u044f \u0432\u0430\u0441 \u043f\u043e\u0437\u0434\u0440\u0430\u0432\u043b\u044f\u044e, \u0432\u044b, \u0432\u0438\u0434\u0438\u043c\u043e, \u0431\u043e\u043b\u0435\u0435 \u0432\u0435\u0437\u0443\u0447\u0438 \u0438 \u043a\u0432\u0430\u043b\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043d\u044b, \u0447\u0435\u043c \u044f. \u042f \u0441\u0442\u0430\u043b\u043a\u0438\u0432\u0430\u043b\u0441\u044f \u0441 \u043d\u0435\u0432\u0435\u0440\u043d\u043e \u043f\u0440\u0438\u043b\u0435\u0442\u0430\u044e\u0449\u0435\u0439 \u0432\u0435\u0440\u0441\u0438\u0435\u0439 <strong>@types\/react <\/strong>\u043e\u0447\u0435\u043d\u044c \u0447\u0430\u0441\u0442\u043e,\u0438 \u0432\u0441\u0435\u0433\u0434\u0430 \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u0431\u043e\u043b\u044c\u043d\u043e. \u0412\u043f\u0440\u043e\u0447\u0435\u043c, \u0441\u0435\u0439\u0447\u0430\u0441 \u043f\u043e \u043e\u0449\u0443\u0449\u0435\u043d\u0438\u044f\u043c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0441\u0442\u0430\u043b\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u0435\u043d\u0435\u0435 \u0430\u043a\u0442\u0443\u0430\u043b\u044c\u043d\u043e\u0439 &#8212; \u0442\u043e \u043b\u0438 \u044f \u043f\u0440\u0438\u0432\u044b\u043a, \u0442\u043e \u043b\u0438 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0430 <strong>react<\/strong> \u0438 <strong>@types\/react<\/strong> \u043e\u043a\u043e\u043d\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043b\u0430\u0441\u044c.<\/p>\n<h3>\u0425\u0443\u043a\u0438 &#8212; \u0438 \u0442\u0430\u043a \u0441\u043e\u0439\u0434\u0451\u0442!<\/h3>\n<p>\u0422\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439, \u043a\u043e\u0433\u0434\u0430 \u0438\u0434\u0435\u044f \u043a\u0440\u0443\u0442\u0430\u044f, \u0430 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f&#8230; \u041d\u0443, \u043d\u0435 \u0442\u0430\u043a\u0430\u044f \u043a\u0440\u0443\u0442\u0430\u044f, \u0441\u043a\u0430\u0436\u0435\u043c \u0442\u0430\u043a. \u0417\u0430 \u0433\u043e\u0434\u044b, \u043f\u0440\u043e\u0448\u0435\u0434\u0448\u0438\u0435 \u0441 \u043f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u044f \u0445\u0443\u043a\u043e\u0432, \u043c\u044b \u043a \u043d\u0438\u043c \u0443\u0436\u0435 \u043f\u0440\u0438\u0432\u044b\u043a\u043b\u0438, \u043d\u043e \u0435\u0441\u043b\u0438 \u0432\u0434\u0443\u043c\u0430\u0442\u044c\u0441\u044f, \u0433\u0440\u0430\u0431\u043b\u0435\u0439 \u0432 \u0438\u0445 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043d\u0430\u043a\u0438\u0434\u0430\u043d\u043e \u043d\u0435\u043c\u0430\u043b\u043e.<\/p>\n<p>\u041d\u0430\u0447\u043d\u0451\u043c \u0441 \u0431\u0430\u0437\u044b: \u043f\u0440\u0430\u0432\u0438\u043b\u0430 \u0445\u0443\u043a\u043e\u0432. \u0418\u0445 \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c:<\/p>\n<ul>\n<li>\n<p>\u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u0445 \u0438 \u0434\u0440\u0443\u0433\u0438\u0445 \u0445\u0443\u043a\u0430\u0445<\/p>\n<\/li>\n<li>\n<p>\u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u0432\u0435\u0440\u0445\u043d\u0435\u043c \u0443\u0440\u043e\u0432\u043d\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f &#8212; \u043d\u0435\u043b\u044c\u0437\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0445\u0443\u043a\u0438 \u0432 \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u0445, \u0446\u0438\u043a\u043b\u0430\u0445 \u0438 \u043b\u044e\u0431\u044b\u0445 \u0434\u0440\u0443\u0433\u0438\u0445 \u043c\u0435\u0441\u0442\u0430\u0445, \u0433\u0434\u0435 \u0445\u0443\u043a \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043d\u0435 \u0432\u044b\u0437\u0432\u0430\u043d \u043f\u0440\u0438 \u043a\u0430\u043a\u043e\u043c-\u0442\u043e \u0443\u0441\u043b\u043e\u0432\u0438\u0438<\/p>\n<\/li>\n<\/ul>\n<p>\u041a \u043f\u0435\u0440\u0432\u043e\u043c\u0443 \u043f\u0440\u0430\u0432\u0438\u043b\u0443 \u0432 \u0446\u0435\u043b\u043e\u043c \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u0432 \u043d\u0435\u0442, \u044d\u0442\u043e \u0432\u043f\u043e\u043b\u043d\u0435 \u043b\u043e\u0433\u0438\u0447\u043d\u043e. \u041d\u043e \u043e\u0442\u043a\u0443\u0434\u0430 \u0432\u0437\u044f\u043b\u043e\u0441\u044c \u0432\u0442\u043e\u0440\u043e\u0435?<\/p>\n<p>\u0420\u0430\u0437\u0433\u0430\u0434\u043a\u0430 \u043f\u0440\u043e\u0441\u0442\u0430: <strong>React \u043f\u043e\u043b\u0430\u0433\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u043f\u043e\u0440\u044f\u0434\u043e\u043a \u0432\u044b\u0437\u043e\u0432\u0430 \u0445\u0443\u043a\u043e\u0432!<\/strong> \u0418\u043d\u044b\u043c\u0438 \u0441\u043b\u043e\u0432\u0430\u043c\u0438, \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0445\u0443\u043a\u043e\u0432 \u0432\u043d\u0443\u0442\u0440\u0438 \u0445\u0440\u0430\u043d\u0438\u0442\u0441\u044f \u0432 \u0441\u0442\u0440\u043e\u0433\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u043e\u043c \u043f\u043e\u0440\u044f\u0434\u043a\u0435. \u0415\u0441\u043b\u0438 \u043f\u043e\u0440\u044f\u0434\u043e\u043a \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u0441\u044f, \u0442\u043e \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 (\u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e) \u0441\u0442\u0430\u043d\u0435\u0442 \u043d\u0435\u0432\u0430\u043b\u0438\u0434\u043d\u044b\u043c. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0445\u0443\u043a \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432\u0441\u0435\u0433\u0434\u0430, \u043d\u0443\u0436\u0435\u043d \u043b\u0438 \u043e\u043d \u0438\u043b\u0438 \u043d\u0435\u0442.<\/p>\n<p>\u041d\u0435 \u043a\u0430\u0436\u0435\u0442\u0441\u044f \u043b\u0438 \u0432\u0430\u043c \u044d\u0442\u043e \u043a\u043e\u0441\u0442\u044b\u043b\u0451\u043c? \u041b\u0438\u0447\u043d\u043e \u043c\u043d\u0435 \u043a\u0430\u0436\u0435\u0442\u0441\u044f. \u041d\u043e \u043a\u043e\u0441\u0442\u044b\u043b\u044c \u044d\u0442\u043e \u0432\u0441\u0435\u043c \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0439 \u0438 \u043f\u0440\u0438\u0432\u044b\u0447\u043d\u044b\u0439, \u0441 \u043d\u0438\u043c \u0443\u0436\u0435 \u0432\u0441\u0435 \u0441\u043c\u0438\u0440\u0438\u043b\u0438\u0441\u044c. \u0421\u043c\u0438\u0440\u0438\u043c\u0441\u044f \u0438 \u043c\u044b.<\/p>\n<p>\u0418\u043b\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u044c \u0432\u0440\u0443\u0447\u043d\u0443\u044e \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0445\u0443\u043a\u043e\u0432 \u0432 \u043c\u0430\u0441\u0441\u0438\u0432\u0435? \u041d\u0435\u0442, \u0432 \u044d\u0442\u043e\u043c \u0435\u0441\u0442\u044c \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u0448\u0430\u0440\u043c, \u043d\u043e&#8230;\u00a0 \u042d\u0442\u043e \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043a\u0430\u043a \u0440\u0443\u0447\u043d\u0430\u044f \u043f\u0440\u0430\u0432\u043a\u0430 \u0443\u0431\u043e\u0433\u043e\u0441\u0442\u0438 \u0441\u0430\u043c\u043e\u0433\u043e \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u0430 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0445 \u0445\u0443\u043a\u043e\u0432! \u041c\u0435\u043d\u044f, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043e\u0447\u0435\u043d\u044c \u0432\u0435\u0441\u0435\u043b\u0438\u0442 \u0442\u043e\u0442 \u0444\u0430\u043a\u0442, \u0447\u0442\u043e <strong>eslint<\/strong> \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u0445 \u043f\u0440\u0430\u0432\u0438\u043b \u043c\u043e\u0436\u0435\u0442 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u043d\u0435\u0445\u0432\u0430\u0442\u043a\u0443 \u043a\u0430\u043a\u0438\u0445-\u0442\u043e \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439 \u0443 \u0445\u0443\u043a\u0430, \u0430 \u0441\u0430\u043c React \u043d\u0435\u0442.\u00a0 \u0425\u043e\u0442\u044f \u0442\u0443\u0442 \u044f \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043b\u0443\u043a\u0430\u0432\u043b\u044e &#8212; \u0443\u0436\u0435 \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u044b\u0439 React Compiler \u0432\u0440\u043e\u0434\u0435 \u0431\u044b \u043d\u0430\u0443\u0447\u0438\u043b\u0441\u044f \u0433\u0434\u0435 \u043d\u0430\u0434\u043e \u043f\u043e\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c <strong>useCallback<\/strong>, <strong>useMemo<\/strong> \u0438 <strong>memo<\/strong>. \u041d\u043e \u043f\u043e\u043a\u0430, \u0441\u0443\u0434\u044f \u043f\u043e \u0432\u0441\u0435\u043c\u0443, React Compiler \u0435\u0449\u0451 \u043d\u0435 \u0433\u043e\u0442\u043e\u0432 \u0434\u043e \u043a\u043e\u043d\u0446\u0430, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0440\u0430\u0441\u043a\u0438\u0434\u044b\u0432\u0430\u0442\u044c \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438, <strong>useCallback<\/strong> \u0438 \u043f\u0440\u043e\u0447\u0430\u044f \u043f\u0440\u043e\u0447\u0430\u044f \u043f\u0440\u043e\u0447\u0430\u044f \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u0440\u0443\u043a\u0430\u043c\u0438.<\/p>\n<p>\u041d\u043e \u0443 \u043c\u0435\u043d\u044f \u0435\u0441\u0442\u044c \u0438 \u0441\u0432\u043e\u0439 \u00ab\u043b\u044e\u0431\u0438\u043c\u0447\u0438\u043a\u00bb. <strong>useEffect<\/strong>.\u00a0 \u041f\u0440\u0438 \u0432\u043d\u0435\u0448\u043d\u0435\u0439 \u043f\u0440\u043e\u0441\u0442\u043e\u0442\u0435 \u0435\u0433\u043e \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435\u00a0 \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0435\u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u0442\u0440\u0435\u0431\u0443\u0435\u0442 <a href=\"https:\/\/habr.com\/ru\/companies\/ruvds\/articles\/445276\/\" rel=\"noopener noreferrer nofollow\">\u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u0431\u043e\u0440\u0430 \u043e\u0442 \u0441\u0430\u043c\u043e\u0433\u043e \u0414\u044d\u043d\u0430 \u0410\u0431\u0440\u0430\u043c\u043e\u0432\u0430<\/a>. \u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u0432\u0430\u0448 \u043e\u043f\u044b\u0442 \u0441 <strong>useEffect<\/strong> \u0443\u0434\u0430\u0447\u043d\u044b\u0439, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u043d\u043e \u043c\u043e\u0438\u043c \u0433\u043b\u0430\u0432\u043d\u044b\u043c \u043f\u0440\u0430\u0432\u0438\u043b\u043e\u043c \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0445\u0443\u043a\u0430 \u0441\u0442\u0430\u043b\u043e \u00ab\u0435\u0441\u043b\u0438 \u043c\u043e\u0436\u0435\u0448\u044c \u0435\u0433\u043e \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c &#8212; \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u00bb.<\/p>\n<p>\u041f\u043e\u043d\u044f\u0442\u043d\u043e, \u0447\u0442\u043e \u043c\u044b \u043f\u0440\u0438\u0432\u044b\u043a\u043b\u0438 \u043a \u043c\u0430\u0433\u0438\u0438: \u0447\u0442\u043e \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u0434\u0430\u0447\u0435 \u043f\u0443\u0441\u0442\u043e\u0433\u043e \u043c\u0430\u0441\u0441\u0438\u0432\u0430 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439 <strong>useEffect<\/strong> \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f \u043b\u0438\u0448\u044c \u0440\u0430\u0437, \u0447\u0442\u043e \u0435\u0441\u043b\u0438 \u043d\u0435 \u043f\u0435\u0440\u0435\u0434\u0430\u0442\u044c \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0432\u043e\u043e\u0431\u0449\u0435, \u043e\u043d \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0437\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u043a\u0430\u0436\u0434\u044b\u0439 \u0440\u0435\u043d\u0434\u0435\u0440. \u0418 \u043c\u043e\u0451 \u043b\u044e\u0431\u0438\u043c\u043e\u0435 &#8212; \u043e\u0447\u0438\u0441\u0442\u043a\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0445 \u0440\u0435\u0441\u0443\u0440\u0441\u043e\u0432 \u043a\u0430\u043a&#8230; \u0432\u044b\u0437\u043e\u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u0438, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u043a\u043e\u043b\u0431\u044d\u043a <strong>useEffect<\/strong>. \u0415\u0441\u043b\u0438 \u0443 \u043f\u0435\u0440\u0432\u044b\u0445 \u0434\u0432\u0443\u0445 \u043a\u0435\u0439\u0441\u043e\u0432 \u0434\u0430\u0436\u0435 \u0435\u0441\u0442\u044c \u043a\u0430\u043a\u0430\u044f-\u0442\u043e \u043b\u043e\u0433\u0438\u043a\u0430, \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043d\u0435 \u0438\u043d\u0442\u0443\u0438\u0442\u0438\u0432\u043d\u043e \u0438, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043b\u0438\u0448\u0430\u0435\u0442 \u043d\u0430\u0441 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u043f\u0435\u0440\u0435\u0434\u0430\u0442\u044c \u0432 <strong>useEffect<\/strong> \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u0443\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e. \u041d\u0435\u0442, \u043c\u044b \u043a \u044d\u0442\u043e\u043c\u0443 \u0443\u0436\u0435 \u043f\u0440\u0438\u0432\u044b\u043a\u043b\u0438 \u0438 \u043e\u0442\u043d\u043e\u0441\u0438\u043c\u0441\u044f \u043a\u0430\u043a \u043a \u0434\u043e\u043b\u0436\u043d\u043e\u043c\u0443, \u043d\u043e \u0435\u0441\u043b\u0438 \u0432\u0434\u0443\u043c\u0430\u0442\u044c\u0441\u044f &#8212; \u0430 \u043f\u043e\u0447\u0435\u043c\u0443 \u044d\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u043d\u043e \u0438\u043c\u0435\u043d\u043d\u043e \u0442\u0430\u043a \u043d\u0435\u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u0430 \u043d\u0435, \u0441\u043a\u0430\u0436\u0435\u043c, \u043e\u043f\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u043c? \u042f \u0442\u0430\u043a \u0438 \u043d\u0435 \u043f\u043e\u043d\u044f\u043b. \u041d\u0430\u043f\u0438\u0448\u0438\u0442\u0435, \u0435\u0441\u043b\u0438 \u043f\u043e\u043d\u044f\u043b\u0438 \u0432\u044b.<\/p>\n<p>\u041d\u043e \u0432\u0441\u0451 \u0436\u0435 &#8212; \u0445\u0443\u043a\u0438 \u044d\u0442\u043e \u0432\u043f\u043e\u043b\u043d\u0435 \u043d\u0435\u043f\u043b\u043e\u0445\u043e. \u0414\u0430, \u043a &#8230;\u043a\u0445\u043c&#8230; \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u044f\u043c \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0445 \u0445\u0443\u043a\u043e\u0432 \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u043f\u0440\u0438\u0432\u044b\u043a\u043d\u0443\u0442\u044c, \u043d\u043e \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0432\u044b\u0434\u0435\u043b\u0438\u0442\u044c \u043b\u043e\u0433\u0438\u043a\u0443 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0445\u0443\u043a \u0438 \u043f\u0435\u0440\u0435\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u043e \u0442\u043e\u0433\u043e \u0441\u0442\u043e\u0438\u0442. \u0425\u043e\u0442\u044f, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u0441 \u044d\u0442\u0438\u043c \u0432\u043f\u043e\u043b\u043d\u0435 \u0441\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0438 \u0445\u043e\u0440\u043e\u0448\u0438\u0439 \u0441\u0442\u0435\u0439\u0442-\u043c\u0435\u043d\u0435\u0434\u0436\u0435\u0440.<\/p>\n<h3>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h3>\n<p>\u0418\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u044f \u0434\u0443\u043c\u0430\u043b, \u0447\u0442\u043e \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u0438 React \u044f \u0431\u0443\u0434\u0443 \u043f\u043e\u0434\u0431\u0438\u0440\u0430\u0442\u044c \u0441 \u0442\u0440\u0443\u0434\u043e\u043c \u0438 \u043c\u043d\u0435 \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u043f\u0440\u043e\u0441\u0438\u0442\u044c \u043f\u043e\u043c\u043e\u0449\u0438 \u0443 \u043a\u043e\u043b\u043b\u0435\u0433, \u0447\u0442\u043e\u0431 \u0441\u0442\u0430\u0442\u044c\u044f \u043d\u0435 \u0431\u044b\u043b\u0430 \u0443\u0436 \u0441\u043b\u0438\u0448\u043a\u043e\u043c \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u043e\u0439. \u0412 \u0438\u0442\u043e\u0433\u0435, \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u0432\u043e\u043b\u0435\u0432\u044b\u043c \u0440\u0435\u0448\u0435\u043d\u0438\u0435\u043c \u0441\u0435\u0431\u044f \u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c \u0438 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0441\u043e\u043a\u0440\u0430\u0449\u0430\u0442\u044c \u0441\u0442\u0430\u0442\u044c\u044e. \u041e\u0437\u043d\u0430\u0447\u0430\u0435\u0442 \u043b\u0438 \u044d\u0442\u043e, \u0447\u0442\u043e React \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043b\u043e\u0445? \u041c\u043d\u0435 \u0442\u0440\u0443\u0434\u043d\u043e \u043e\u0442\u0432\u0435\u0442\u0438\u0442\u044c \u043d\u0430 \u044d\u0442\u043e\u0442 \u0432\u043e\u043f\u0440\u043e\u0441. \u041d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u043f\u0435\u0440\u0435\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u044b\u0435 \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u0438, \u0441\u0432\u043e\u044e \u0440\u0430\u0431\u043e\u0442\u0443 React \u0434\u0435\u043b\u0430\u0435\u0442 \u0438 \u0434\u0435\u043b\u0430\u0435\u0442 \u0435\u0451 \u0445\u043e\u0440\u043e\u0448\u043e &#8212; \u0442\u044b\u0441\u044f\u0447\u0438 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0449\u0438\u0445 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439 \u0438 \u043e\u0433\u0440\u043e\u043c\u043d\u0430\u044f \u044d\u043a\u043e\u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u0442\u043e\u043c\u0443 \u043f\u043e\u0434\u0442\u0432\u0435\u0440\u0436\u0434\u0435\u043d\u0438\u0435. \u041a \u043d\u0435\u043f\u0440\u0438\u044f\u0442\u043d\u044b\u043c \u043c\u0435\u043b\u043e\u0447\u0430\u043c (\u0438 \u043d\u0435 \u043c\u0435\u043b\u043e\u0447\u0430\u043c) \u0441\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c \u043f\u0440\u0438\u0432\u044b\u043a\u0430\u0435\u0448\u044c, \u0438\u043d\u0442\u0443\u0438\u0442\u0438\u0432\u043d\u043e \u0443\u0447\u0438\u0448\u044c\u0441\u044f \u0438\u0445 \u043e\u0431\u0445\u043e\u0434\u0438\u0442\u044c \u0438 \u043f\u043e\u0437\u043d\u0430\u0451\u0448\u044c \u043d\u0435\u043a\u0438\u0439 \u0434\u0437\u0435\u043d React &#8212; \u0447\u0442\u043e \u0431\u044b \u044d\u0442\u043e \u043d\u0438 \u0437\u043d\u0430\u0447\u0438\u043b\u043e.<\/p>\n<p>\u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0441\u0432\u043e\u0438 \u0431\u043e\u043b\u0435\u0432\u044b\u0435 \u0442\u043e\u0447\u043a\u0438 \u0432 React \u0438\u043b\u0438 \u0434\u0440\u0443\u0433\u0438\u0445 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430\u0445, \u0435\u0441\u043b\u0438 \u0432\u044b \u043d\u0435 \u0441\u043e\u0433\u043b\u0430\u0441\u043d\u044b \u0441 \u0432\u044b\u0441\u043a\u0430\u0437\u0430\u043d\u043d\u044b\u043c \u0432 \u0441\u0442\u0430\u0442\u044c\u0435 \u0438\u043b\u0438 \u043f\u0440\u043e\u0441\u0442\u043e \u0445\u043e\u0442\u0438\u0442\u0435 \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0438\u0442\u044c \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u0442\u044c \u0432\u0441\u0451 \u043d\u0430 $mol &#8212; \u0431\u0443\u0434\u0443 \u0440\u0430\u0434 \u0432\u0438\u0434\u0435\u0442\u044c \u0432\u0430\u0441 \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445.\u0421\u043f\u0430\u0441\u0438\u0431\u043e \u0437\u0430 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435!<\/p>\n<\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><!----><!----><\/div>\n<p><!----><!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/892406\/\"> https:\/\/habr.com\/ru\/articles\/892406\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041f\u0440\u0438\u0432\u0435\u0442, \u0425\u0430\u0431\u0440! \u042f \u0443\u0436\u0435 \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u043b, \u0447\u0442\u043e <a href=\"https:\/\/habr.com\/ru\/articles\/870538\/\" rel=\"noopener noreferrer nofollow\">\u0443\u043c\u0435\u044e \u0440\u0430\u0437\u043d\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e \u043f\u0438\u0441\u0430\u0442\u044c \u0441\u0447\u0451\u0442\u0447\u0438\u043a\u0438<\/a>.\u041f\u0440\u0438\u0448\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0448\u0430\u0433 \u0432\u043f\u0435\u0440\u0451\u0434! \u0421\u0435\u0433\u043e\u0434\u043d\u044f \u043f\u043e\u0433\u043e\u0432\u043e\u0440\u0438\u043c \u043e \u0442\u043e\u043c \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0435, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044f \u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u044b \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 \u0435\u0436\u0435\u0434\u043d\u0435\u0432\u043d\u043e. \u0420\u0435\u0447\u044c \u043f\u043e\u0439\u0434\u0451\u0442 \u043e \u0432\u0435\u043b\u0438\u043a\u043e\u043c \u0438 \u0443\u0436\u0430\u0441\u043d\u043e\u043c ReactJS.<\/p>\n<p>\u042f \u043f\u0438\u0448\u0443 \u043d\u0430 React \u0441 2018 \u0433\u043e\u0434\u0430, \u0434\u0435\u043b\u0430\u044e \u044d\u0442\u043e, \u043d\u0430 \u043c\u043e\u0439 \u0432\u0437\u0433\u043b\u044f\u0434, \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u0441\u043d\u043e\u0441\u043d\u043e.\u041c\u043d\u0435 \u043d\u0440\u0430\u0432\u0438\u0442\u0441\u044f \u0442\u0435\u0437\u0438\u0441 \u043e \u0442\u043e\u043c, \u0447\u0442\u043e \u043f\u0440\u043e\u0444\u0435\u0441\u0441\u0438\u043e\u043d\u0430\u043b\u0438\u0437\u043c \u0437\u0430\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u0443\u043c\u0435\u043d\u0438\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0434\u043e\u0441\u0442\u043e\u0438\u043d\u0441\u0442\u0432\u0430 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430, \u043d\u043e \u0438 \u0432 \u0443\u043c\u0435\u043d\u0438\u0438 \u0447\u0451\u0442\u043a\u043e \u0432\u0438\u0434\u0435\u0442\u044c \u0435\u0433\u043e \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u0438.\u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u043e\u0437\u043d\u0438\u043a\u043b\u0430 \u0438\u0434\u0435\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0447\u0442\u043e-\u0442\u043e \u0442\u0438\u043f\u0430 \u043f\u0440\u043e\u0436\u0430\u0440\u043a\u0438 React, \u0443\u043a\u0430\u0437\u0430\u0432 \u043d\u0430 \u043b\u0438\u0447\u043d\u043e \u043c\u0435\u043d\u044f \u0440\u0430\u0437\u0434\u0440\u0430\u0436\u0430\u044e\u0449\u0438\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b. \u0421 \u043a\u0430\u043a\u0438\u043c\u0438-\u0442\u043e \u044f \u0441\u043c\u0438\u0440\u0438\u043b\u0441\u044f, \u0441 \u043a\u0430\u043a\u0438\u043c\u0438-\u0442\u043e \u043d\u0435\u0442, \u0447\u0442\u043e-\u0442\u043e \u043d\u0430\u0443\u0447\u0438\u043b\u0441\u044f \u043e\u0431\u0445\u043e\u0434\u0438\u0442\u044c. \u0415\u0441\u043b\u0438 \u0432\u0430\u0441 \u0431\u0435\u0441\u0438\u0442 \u0432 React \u0447\u0442\u043e-\u0442\u043e, \u0447\u0442\u043e \u044f \u043d\u0435 \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u043b, \u043d\u0435 \u0441\u0442\u0435\u0441\u043d\u044f\u0439\u0442\u0435\u0441\u044c \u043f\u0438\u0441\u0430\u0442\u044c \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445, \u0431\u044b\u043b\u043e \u0431\u044b \u043e\u0447\u0435\u043d\u044c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e \u0441\u0440\u0430\u0432\u043d\u0438\u0442\u044c \u043c\u043e\u0438 \u043e\u0449\u0443\u0449\u0435\u043d\u0438\u044f \u0441 \u0432\u0430\u0448\u0438\u043c\u0438.<\/p>\n<p>\u0418 \u0432\u0430\u0436\u043d\u043e\u0435: \u043d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u044b\u0435 \u043d\u0438\u0436\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b, \u044f \u0434\u043e \u0441\u0438\u0445 \u043f\u043e\u0440 \u0441\u0447\u0438\u0442\u0430\u044e React \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u043c \u0438 \u0443\u0434\u043e\u0431\u043d\u044b\u043c \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u043c \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434\u0430, \u0432 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438 SPA.\u0413\u0440\u043e\u043c\u043a\u0438\u0445 \u0441\u043b\u043e\u0432 \u0442\u0438\u043f\u0430 \u00abReactJS \u043d\u0435 \u043f\u0440\u0438\u0433\u043e\u0434\u0435\u043d \u0434\u043b\u044f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438\u00bb \u0442\u0443\u0442 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 &#8212; \u043f\u0440\u0438\u0433\u043e\u0434\u0435\u043d, \u0434\u0430 \u0435\u0449\u0451 \u043a\u0430\u043a! \u041d\u043e&#8230; \u0438 \u043d\u0430 \u0421\u043e\u043b\u043d\u0446\u0435 \u0431\u044b\u0432\u0430\u044e\u0442 \u043f\u044f\u0442\u043d\u0430.\u041f\u0440\u0438\u0441\u0442\u0443\u043f\u0438\u043c.<\/p>\n<h3>\u0422\u0432\u043e\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0442\u0430\u043a\u0430\u044f \u0442\u043e\u043b\u0441\u0442\u0430\u044f&#8230;<\/h3>\n<p>\u0412\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0430 Internet Explorer 9-10 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 jQuery (\u043f\u043e\u043c\u043d\u0438\u0442\u0435 \u0442\u0430\u043a\u0443\u044e?) \u0441\u0447\u0438\u0442\u0430\u043b\u0430\u0441\u044c \u043e\u0447\u0435\u043d\u044c \u0442\u044f\u0436\u0451\u043b\u043e\u0439. \u041c\u043d\u043e\u0433\u0438\u0435 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u043e\u0432\u0430\u043b\u0438 \u0441\u0442\u0430\u0440\u0430\u0442\u044c\u0441\u044f \u0438\u0437\u0431\u0435\u0433\u0430\u0442\u044c \u0435\u0451 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f, \u0445\u043e\u0442\u044f \u0432 \u0442\u0435 \u0434\u0438\u043a\u0438\u0435 \u0432\u0440\u0435\u043c\u0435\u043d\u0430 jQuery \u0431\u044b\u043b\u0430 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435\u0437\u0430\u043c\u0435\u043d\u0438\u043c\u0430. \u0420\u0430\u0437\u043c\u0435\u0440 \u0435\u0451 \u0431\u0430\u043d\u0434\u043b\u0430 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u043b \u0441\u0442\u0440\u0430\u0448\u043d\u044b\u0435 \u043d\u0430 \u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 72 \u041a\u0431\u00a0 (\u043c\u0438\u043d\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0438\u044f 1.4.2).\u0418 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 jQuery \u043a\u0430\u043a \u043c\u043e\u0433\u043b\u0438 \u0441\u0442\u0430\u0440\u0430\u043b\u0438\u0441\u044c \u0443\u043c\u0435\u043d\u044c\u0448\u0430\u0442\u044c \u0435\u0433\u043e, \u043a \u043f\u0440\u0438\u043c\u0435\u0440\u0443, \u0440\u0430\u0437\u0434\u0435\u043b\u044f\u044f \u043d\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0431\u0430\u043d\u0434\u043b\u043e\u0432 \u0441 \u0440\u0430\u0437\u043d\u044b\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u043e\u043c.<\/p>\n<p>\u0421\u0435\u0439\u0447\u0430\u0441 \u043d\u0430 \u0434\u0432\u043e\u0440\u0435 2025 \u0433\u043e\u0434 \u0438 \u043d\u0435 \u043f\u0440\u0438\u043d\u044f\u0442\u043e \u0441\u0447\u0438\u0442\u0430\u0442\u044c \u0431\u0430\u0439\u0442\u044b \u0438 \u0434\u0430\u0436\u0435 \u043a\u0438\u043b\u043e\u0431\u0430\u0439\u0442\u044b. \u0422\u043e, \u0447\u0442\u043e JS-\u0431\u0430\u043d\u0434\u043b \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c \u0441 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u043c\u0435\u0433\u0430\u0431\u0430\u0439\u0442, \u0443\u0436\u0435 \u043c\u0430\u043b\u043e \u043a\u043e\u0433\u043e \u0448\u043e\u043a\u0438\u0440\u0443\u0435\u0442 (\u0445\u043e\u0442\u044f \u044f \u0434\u043e \u0441\u0438\u0445 \u043f\u043e\u0440 \u043c\u043e\u0433\u0443 \u0432\u0437\u0434\u0440\u043e\u0433\u043d\u0443\u0442\u044c, \u0433\u043b\u044f\u0434\u044f \u0432 \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u0430 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430, \u043d\u043e \u044d\u0442\u043e \u043f\u0440\u043e\u0444\u0434\u0435\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f). <\/p>\n<p>\u0412 \u0442\u0440\u0435\u043d\u0434\u0435 \u043b\u0438 React?<\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0443\u0437\u043d\u0430\u0435\u043c. \u042f \u0441\u043e\u0437\u0434\u0430\u043b \u043f\u0440\u043e\u0435\u043a\u0442 \u043d\u0430 React \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e Vite \u0438 \u043c\u043e\u0434\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043b \u043a\u043e\u043d\u0444\u0438\u0433 \u0441\u0431\u043e\u0440\u043a\u0438, \u0447\u0442\u043e\u0431 \u0432\u044b\u0434\u0435\u043b\u0438\u0442\u044c React \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0447\u0430\u043d\u043a:<\/p>\n<pre><code class=\"javascript\">import { defineConfig } from 'vite' import react from '@vitejs\/plugin-react'  \/\/ https:\/\/vite.dev\/config\/ export default defineConfig({   build: {     rollupOptions: {       output: {       \/\/ \u0414\u043e\u0431\u0430\u0432\u0438\u043c \u0432\u044b\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 React \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0447\u0430\u043d\u043a         manualChunks: {           react: ['react'],         }       }     }   },   plugins: [react()], })<\/code><\/pre>\n<p>\u0421\u043e\u0431\u0435\u0440\u0451\u043c \u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0442\u0430\u043a\u043e\u0439 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442:<\/p>\n<pre><code class=\"javascript\">vite v6.2.1 building for production... \u2713 30 modules transformed. dist\/index.html                   0.54 kB \u2502 gzip:  0.33 kB dist\/assets\/react-CHdo91hT.svg    4.13 kB \u2502 gzip:  2.05 kB dist\/assets\/index-n_ryQ3BS.css    1.39 kB \u2502 gzip:  0.71 kB dist\/assets\/react-yBjzXJbu.js     6.79 kB \u2502 gzip:  2.72 kB dist\/assets\/index-CkN_Kf_f.js   137.38 kB \u2502 gzip: 44.22 kB \u2713 built in 380ms<\/code><\/pre>\n<p>\u0421\u0430\u043c \u043f\u043e \u0441\u0435\u0431\u0435 React \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u0431\u0443\u043a\u0432\u0430\u043b\u044c\u043d\u043e \u043c\u0435\u043d\u044c\u0448\u0435 7 \u041a\u0431!\u00a0 \u042d\u0442\u043e \u0434\u0430\u0436\u0435 \u043c\u0435\u043d\u044c\u0448\u0435 preact (~ 11 \u041a\u0431), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u044f\u0432\u043b\u044f\u0435\u0442 \u0441\u0435\u0431\u044f \u043b\u0435\u0433\u043a\u043e\u0439 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u043e\u0439. \u0422\u0430\u043a \u0447\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0432\u0440\u0443\u0442 \u043e \u0442\u043e\u043c, \u0447\u0442\u043e React \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0438 \u043f\u0440\u043e\u0436\u043e\u0440\u043b\u0438\u0432\u044b\u0439? \u041d\u043e \u0447\u0442\u043e \u0437\u0430 \u043e\u0441\u0442\u0430\u0432\u0448\u0438\u0435\u0441\u044f 137 \u041a\u0431&#8230;<\/p>\n<p>\u041e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e-\u0442\u043e \u0442\u0443\u0442 \u043d\u0435 \u0442\u0430\u043a. \u041f\u043e\u0433\u043b\u044f\u0434\u0438\u043c \u043d\u0430 \u043d\u0430\u0448 \u0441\u043f\u0438\u0441\u043e\u043a \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439 \u0438\u00a0 \u0432\u044b\u0434\u0435\u043b\u0438\u043c \u0435\u0449\u0451 \u043e\u0434\u0438\u043d \u0447\u0430\u043d\u043a:<\/p>\n<pre><code class=\"javascript\">reactDOM: ['react-dom\/client']<\/code><\/pre>\n<p>\u0418 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442: <\/p>\n<pre><code class=\"javascript\">\u2713 30 modules transformed. dist\/index.html                     0.62 kB \u2502 gzip:  0.35 kB dist\/assets\/react-CHdo91hT.svg      4.13 kB \u2502 gzip:  2.05 kB dist\/assets\/index-n_ryQ3BS.css      1.39 kB \u2502 gzip:  0.71 kB dist\/assets\/index-Xo5bg2S4.js       2.59 kB \u2502 gzip:  1.33 kB dist\/assets\/react-yBjzXJbu.js       6.79 kB \u2502 gzip:  2.72 kB dist\/assets\/reactDOM-CKhEkZwU.js  134.78 kB \u2502 gzip: 43.26 kB<\/code><\/pre>\n<p>\u041f\u043e\u0447\u0442\u0438 135 \u041a\u0431 \u044d\u0442\u043e React-DOM! \u0418 \u0431\u0435\u0434\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0431\u0435\u0437 \u043d\u0435\u0433\u043e \u0441\u0430\u043c \u043f\u043e \u0441\u0435\u0431\u0435 React \u043d\u0435 \u0437\u0430\u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 &#8212; \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u0441\u043c\u043e\u0436\u0435\u0442 \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c DOM-\u0434\u0435\u0440\u0435\u0432\u043e. \u0427\u0442\u043e \u0441\u043a\u0440\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u0431\u0435\u0437 \u043c\u0430\u043b\u043e\u0433\u043e 135 \u043a\u0438\u043b\u043e\u0431\u0430\u0439\u0442\u0430\u0445 \u043c\u0438\u043d\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430 &#8212; \u044f \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u044e \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0438, \u0447\u0435\u0441\u0442\u043d\u043e \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u0441\u0442\u0440\u0430\u0448\u043d\u043e \u0432\u043d\u0438\u043a\u0430\u0442\u044c \u0432 \u044d\u0442\u043e \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e. \u0424\u0430\u043a\u0442 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0432\u0430\u043c \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u043f\u0430\u043a\u0435\u0442 react, \u0447\u0442\u043e\u0431 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f React. \u0412\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 135 \u041a\u0431\u00a0 \u043a\u043e\u0434\u0430, \u0447\u0442\u043e\u0431 \u0445\u043e\u0442\u044c \u0447\u0442\u043e-\u0442\u043e \u043e\u0442\u043e\u0431\u0440\u0430\u0437\u0438\u0442\u044c!<\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0418\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e, \u043a\u0441\u0442\u0430\u0442\u0438, \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u043d\u0435 \u0431\u044b\u043b\u043e \u0438 React \u043f\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u043b\u0441\u044f \u043e\u0434\u043d\u0438\u043c \u0444\u0430\u0439\u043b\u043e\u043c. React-DOM \u0431\u044b\u043b \u0432\u044b\u0434\u0435\u043b\u0435\u043d \u0432 \u0432\u0435\u0440\u0441\u0438\u0438 0.14 \u0441 \u0446\u0435\u043b\u044c\u044e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0443 React \u0431\u043e\u043b\u0435\u0435 \u043c\u043e\u0434\u0443\u043b\u044c\u043d\u043e\u0439. \u042d\u0442\u043e (\u043f\u043e \u0437\u0430\u0434\u0443\u043c\u043a\u0435) \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0433\u0440\u0430\u043c\u043e\u0442\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u043a\u043b\u0438\u0435\u043d\u0442\u0435, \u043d\u043e \u0438 \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0435 \u0438\u043b\u0438 \u0432 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u0439 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0435. \u041d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u0438\u043b\u044c\u043d\u043e \u0431\u044b\u043b\u043e \u043d\u0443\u0436\u043d\u043e \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0431\u0430\u043d\u0434\u043b\u0430 \u0432 140 \u041a\u0431 \u043d\u0430 \u0434\u0432\u0430 \u0432 7 \u0438 135 \u041a\u0431 &#8212; \u043d\u0435 \u043c\u043d\u0435 \u0441\u0443\u0434\u0438\u0442\u044c, \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u043e\u043d\u043e \u043f\u043e\u043c\u043e\u0433\u043b\u043e \u0432 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 \u0442\u043e\u0433\u043e \u0436\u0435 React-Native. \u0422\u043e\u043b\u044c\u043a\u043e \u0432\u043e\u0442&#8230; React \u0434\u043b\u044f \u0441\u0432\u043e\u0435\u0433\u043e \u043c\u043e\u043d\u0441\u0442\u0440\u0443\u043e\u0437\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u0430 \u0443\u043c\u0435\u0435\u0442 \u0443\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043c\u0430\u043b\u043e. \u0423 \u043d\u0435\u0433\u043e \u043d\u0435\u0442 \u0440\u043e\u0443\u0442\u0435\u0440\u0430, \u043d\u0435\u0442 \u0441\u0440\u0435\u0434\u0441\u0442\u0432 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 http-\u0437\u0430\u043f\u0440\u043e\u0441\u0430\u043c\u0438 (\u0432 19 \u0432\u0440\u043e\u0434\u0435 \u043f\u043e\u044f\u0432\u0438\u043b\u043e\u0441\u044c),\u00a0 \u043d\u0435\u0442 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0438\u043b\u0438 \u0445\u043e\u0442\u044f \u0431\u044b \u043d\u0430\u0431\u043e\u0440\u0430 \u0441\u0442\u0438\u043b\u0435\u0439! \u0423\u043f\u0440\u043e\u0449\u0451\u043d\u043d\u043e, \u0432\u043d\u0443\u0442\u0440\u0438 React \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u043a\u0430\u0447\u0430\u043d\u043d\u044b\u0439 \u0448\u0430\u0431\u043b\u043e\u043d\u0438\u0437\u0430\u0442\u043e\u0440, \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e \u0440\u0430\u0431\u043e\u0442\u044b \u0441 DOM (\u043d\u0430\u0434\u043e \u043f\u0440\u0438\u0437\u043d\u0430\u0442\u044c, \u043c\u043e\u0449\u043d\u0435\u0439\u0448\u0435\u0435) \u0438 \u043d\u0435\u043a\u043e\u0435 \u043f\u043e\u0434\u043e\u0431\u0438\u0435 \u0441\u0442\u0435\u0439\u0442-\u043c\u0435\u043d\u0435\u0434\u0436\u043c\u0435\u043d\u0442\u0430 \u0432 \u043b\u0438\u0446\u0435 \u0445\u0443\u043a\u043e\u0432.<\/p>\n<p>\u0418 \u0432\u0441\u0451 \u044d\u0442\u043e \u0432 preact (\u0441 \u0440\u0435\u043d\u0434\u0435\u0440\u043e\u043c \u0432 DOM) \u0441\u043f\u043e\u043a\u043e\u0439\u043d\u043e \u0432\u043c\u0435\u0449\u0430\u0435\u0442\u0441\u044f \u0432 11 \u041a\u0431, \u0447\u0442\u043e \u0432 12 \u0440\u0430\u0437 \u043c\u0435\u043d\u044c\u0448\u0435 \u043f\u0440\u0430\u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044f. \u0411\u0430\u043d\u0434\u043b Vue \u0441 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0435\u043c\u0438 \u0436\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044f\u043c\u0438 (\u0438 \u043c\u043d\u043e\u0433\u0438\u043c\u0438 \u043f\u0440\u0438\u044f\u0442\u043d\u044b\u043c\u0438 \u0444\u0438\u0447\u0430\u043c\u0438 \u0442\u0438\u043f\u0430 \u0438\u0437\u043e\u043b\u044f\u0446\u0438\u0438 \u0441\u0442\u0438\u043b\u0435\u0439 \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u0438\u043b\u0438 \u0441\u043b\u043e\u0442\u043e\u0432) \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 60 \u041a\u0411. Angular, \u0442\u043e\u0436\u0435 \u043c\u043e\u043d\u0441\u0442\u0440\u0443\u043e\u0437\u043d\u044b\u0439, \u0441\u0440\u0430\u0432\u043d\u0438\u043c \u0441 react-dom &#8212; \u0431\u0430\u043d\u0434\u043b \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 ~ 160 \u041a\u0431, \u043d\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e 60 \u0438\u0437 \u043d\u0438\u0445 \u044d\u0442\u043e \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0439 \u0440\u043e\u0443\u0442\u0435\u0440, \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0439 \u043f\u043e\u0441\u0442\u0430\u0432\u043a\u0435 React \u043d\u0435\u0442, \u0434\u0430 \u0438 \u043f\u043e \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044f\u043c Angular \u0433\u043e\u0440\u0430\u0437\u0434\u043e \u0431\u043e\u0433\u0430\u0447\u0435.\u00a0 \u0412\u043e\u0442 \u0438 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0438\u0437 \u0432\u0441\u0435\u0445 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0445 \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434-\u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u043e\u0432 (\u0434\u0430 \u0437\u043d\u0430\u044e \u044f, \u0447\u0442\u043e React \u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u043e\u0439, \u0437\u043d\u0430\u044e) React \u043e\u043a\u0430\u0437\u0430\u043b\u0441\u044f \u0441\u0430\u043c\u044b\u043c \u0442\u044f\u0436\u0451\u043b\u044b\u043c.\u00a0 \u041f\u0440\u0438\u0447\u0451\u043c, \u0432\u0441\u0435 \u044d\u0442\u0438 \u043a\u0438\u043b\u043e\u0431\u0430\u0439\u0442\u044b \u043d\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u0437\u0430\u0433\u0440\u0443\u0436\u0430\u044e\u0442\u0441\u044f, \u0430 \u0430\u043a\u0442\u0438\u0432\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f. \u041d\u0435\u0443\u0436\u0435\u043b\u0438 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u044b VirtualDOM \u0438 Reconciliation \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0433\u0440\u043e\u043c\u043d\u044b? \u0418 \u0435\u0441\u043b\u0438 \u0434\u0430, \u0442\u043e \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u043b\u0438 \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u0432\u044b\u0438\u0433\u0440\u044b\u0448 \u0432 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0441 \u0442\u0430\u043a\u0438\u043c \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u043e\u0432\u0435\u0440\u0445\u044d\u0434\u043e\u043c? \u0421\u0443\u0434\u044f \u043f\u043e <a href=\"https:\/\/krausest.github.io\/js-framework-benchmark\/current.html\" rel=\"noopener noreferrer nofollow\">\u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u0430\u043c<\/a> &#8212; \u0432\u0441\u0451 \u043e\u0447\u0435\u043d\u044c \u043f\u043b\u043e\u0445\u043e \u0438 React \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0435\u0435 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0430 \u0430\u043d\u0430\u043b\u043e\u0433\u043e\u0432 \u0431\u0435\u0437 VirtualDOM (\u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0432\u043f\u0435\u0447\u0430\u0442\u043b\u044f\u0435\u0442 \u0432 \u044d\u0442\u043e\u043c \u043f\u043b\u0430\u043d\u0435 Solid, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u0445\u043e\u0436 \u043d\u0430 React \u0441\u043d\u0430\u0440\u0443\u0436\u0438, \u043d\u043e \u043a\u0430\u0440\u0434\u0438\u043d\u0430\u043b\u044c\u043d\u043e \u0434\u0440\u0443\u0433\u043e\u0439 \u0432\u043d\u0443\u0442\u0440\u0438). \u041f\u043e\u0447\u0435\u043c\u0443 &#8212; \u0442\u0435\u043c\u0430 \u0434\u043b\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438.<\/p>\n<h3>JSX \u044d\u0442\u043e \u043f\u043e\u0447\u0442\u0438 HTML. \u041d\u043e \u043d\u0435 HTML.<\/h3>\n<figure class=\"full-width\"><\/figure>\n<p>\u041f\u043e\u043d\u044f\u0442\u043d\u043e, \u0447\u0442\u043e JSX = JS + XML, \u044f \u044d\u0442\u043e \u0437\u043d\u0430\u044e. \u041d\u043e \u0432 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0435 \u0437\u0430\u0434\u0430\u0447 JSX \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0438\u043c\u0435\u043d\u043d\u043e \u043a\u0430\u043a \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u0435\u043b\u044c HTML-\u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0438 \u0438 \u043f\u043e \u0444\u0430\u043a\u0442\u0443 \u043a\u0443\u0434\u0430 \u0431\u043b\u0438\u0436\u0435 \u043a HTML, \u0447\u0435\u043c \u043a XML. \u0418\u0437 \u044d\u0442\u043e\u0433\u043e \u0438 \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u0445\u043e\u0434\u0438\u0442\u044c.<\/p>\n<p>\u041e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u044f\u0437\u044b\u043a \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f JavaScript \u0438 \u044f\u0437\u044b\u043a \u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0438 HTML &#8212; \u043e\u0447\u0435\u043d\u044c \u0440\u0430\u0437\u043d\u044b\u0435 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0441 \u0434\u0440\u0443\u0433\u0438\u043c, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u0431\u0443\u0434\u0435\u0442 \u043a\u043e\u043c\u043f\u0440\u043e\u043c\u0438\u0441\u0441\u043e\u043c. JSX \u043a\u0430\u043a \u0440\u0430\u0437 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u0430\u044f \u0438\u043b\u043b\u044e\u0441\u0442\u0440\u0430\u0446\u0438\u044f \u0442\u0430\u043a\u043e\u0433\u043e \u043a\u043e\u043c\u043f\u0440\u043e\u043c\u0438\u0441\u0441\u0430.<\/p>\n<p>\u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0432\u044b \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0430\u0442\u0440\u0438\u0431\u0443\u0442 <em>class<\/em> &#8212; \u0432\u043c\u0435\u0441\u0442\u043e \u043d\u0435\u0433\u043e \u043d\u0443\u0436\u043d\u043e \u043f\u0438\u0441\u0430\u0442\u044c <em>className<\/em>, \u0432\u0435\u0434\u044c <em>class<\/em> &#8212; \u044d\u0442\u043e \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0435 \u0441\u043b\u043e\u0432\u043e <em>JS<\/em> (\u043f\u0440\u0438\u0447\u0451\u043c, \u043e\u043d\u043e \u0431\u044b\u043b\u043e \u0442\u0430\u043a\u043e\u0432\u044b\u043c \u0435\u0449\u0451 \u0434\u043e \u043f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u044f \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0432 \u044f\u0437\u044b\u043a\u0435) . \u0410\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0441 for-htmlFor &#8212; \u043e\u043a\u0435\u0439, \u0442\u0443\u0442 \u0442\u043e\u0436\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e. \u0417\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u044c 2 \u043e\u0442\u043b\u0438\u0447\u0438\u044f, \u043d\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430.<\/p>\n<p>\u0422\u0443\u0442 \u0435\u0441\u0442\u044c 2 \u0437\u0430\u0431\u0430\u0432\u043d\u044b\u0445 \u043c\u043e\u043c\u0435\u043d\u0442\u0430. \u041f\u0435\u0440\u0432\u044b\u0439: \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u0438\u0441\u0430\u0442\u044c class, \u0438 \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c, \u043d\u043e React \u043f\u043e\u0440\u0443\u0433\u0430\u0435\u0442\u0441\u044f \u0432 \u0441\u0442\u0438\u043b\u0435 \u00ab\u043d\u0435 \u043d\u0430\u0434\u043e \u0442\u0430\u043a\u00bb. \u0412\u0442\u043e\u0440\u043e\u0439:\u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u0432 \u0442\u0430\u043a\u043e\u043c \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0438 \u043d\u0435 \u0431\u044b\u043b\u043e. \u0412 Preact, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0442\u043e\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 JSX, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0432\u043f\u043e\u043b\u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0438\u0441\u044c \u0442\u0440\u0430\u0434\u0438\u0446\u0438\u043e\u043d\u043d\u044b\u0435 HTML-\u043d\u044b\u0435 class \u0438 for (\u0442\u0443\u0442 \u0441\u043c\u0435\u0448\u043d\u043e, \u0447\u0442\u043e \u0440\u0430\u0434\u0438 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u0438 \u0441 React \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430\u043c Preact <a href=\"https:\/\/github.com\/preactjs\/preact\/pull\/695\" rel=\"noopener noreferrer nofollow\">\u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u043d\u0430 htmlFor<\/a>).<\/p>\n<p>\u0418\u043b\u0438 \u0435\u0449\u0451 \u043c\u043e\u043c\u0435\u043d\u0442 &#8212; \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u0435 \u043a \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430.React \u043f\u0440\u0438 \u0432\u0441\u0435\u0439 \u0435\u0433\u043e \u0441\u0432\u043e\u0431\u043e\u0434\u0435 \u043c\u0435\u0441\u0442\u0430\u043c\u0438 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u0435\u043d. \u041e\u043d \u043d\u0435 \u043f\u0440\u043e\u0436\u0443\u0451\u0442 \u043d\u0430\u043b\u0438\u0447\u0438\u0435 \u0431\u043e\u043b\u0435\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0438 \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043e\u0431\u0435\u0440\u043d\u0443\u0442\u044c \u0432\u0441\u044e \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u044e \u0432 \u0445\u043e\u0442\u044f \u0431\u044b React.Fragment (\u0441\u0435\u0439\u0447\u0430\u0441, \u043a \u0441\u0447\u0430\u0441\u0442\u044c\u044e, \u0441\u043e\u043a\u0440\u0430\u0449\u0430\u044e\u0449\u0438\u0439\u0441\u044f \u0434\u043e &lt;&gt;&lt;\/&gt;).\u042f \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u044e, \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435\u044f\u0432\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0442\u044c \u044d\u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 &lt;&gt;&lt;\/&gt; \u0431\u044b\u043b\u043e \u0431\u044b (\u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435) \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0445\u043e\u0440\u043e\u0448\u0435\u0439 \u0438\u0434\u0435\u0435\u0439, \u043d\u043e \u043c\u0435\u043d\u044c\u0448\u0435 \u0440\u0430\u0437\u0434\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u044c \u0434\u0435\u043b\u0430\u0442\u044c \u044d\u0442\u043e \u043d\u0435 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442.<\/p>\n<p>\u041d\u043e \u0441\u0442\u043e\u0438\u043b\u043e \u043d\u0430\u043c \u0441\u043c\u0438\u0440\u0438\u0442\u044c\u0441\u044f \u0441 \u044d\u0442\u0438\u043c\u0438 \u0440\u0430\u0437\u043b\u0438\u0447\u0438\u044f\u043c\u0438, \u043d\u0430 \u0441\u0446\u0435\u043d\u0443 \u0432\u044b\u0445\u043e\u0434\u044f\u0442 \u0435\u0449\u0451 \u0438 \u0435\u0449\u0451. HTML case-insensitive \u044f\u0437\u044b\u043a &#8212; \u0447\u0442\u043e \u0442\u044d\u0433\u0438, \u0447\u0442\u043e \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b \u043c\u043e\u0436\u043d\u043e \u043f\u0438\u0441\u0430\u0442\u044c \u0432 \u043a\u0430\u043a\u043e\u043c \u0443\u0433\u043e\u0434\u043d\u043e \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0435.\u0422\u0430\u043a\u043e\u0439 \u043a\u043e\u0434 \u0432 HTML \u0431\u0443\u0434\u0435\u0442 \u0432\u043f\u043e\u043b\u043d\u0435 \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u0435\u043d \u0438 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0440\u043e\u0432\u043d\u043e \u0442\u0430\u043a, \u043a\u0430\u043a \u0434\u043e\u043b\u0436\u0435\u043d (\u0447\u0442\u043e, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u0441\u043e\u0432\u0441\u0435\u043c \u043d\u0435 \u043f\u043e\u0432\u043e\u0434 \u0442\u0430\u043a \u043f\u0438\u0441\u0430\u0442\u044c):<\/p>\n<pre><code class=\"javascript\">&lt;!DOCTYPE html&gt; &lt;html lang='en'&gt; &lt;head&gt; &lt;title&gt;CaSe INsensITIVe&lt;\/title&gt; &lt;\/head&gt; &lt;body&gt; &lt;DIV&gt;     &lt;sPaN&gt;Hello&lt;\/SpAn&gt;     &lt;button ONCLICK='alert(\"hello\")'&gt;HELLO&lt;\/button&gt; &lt;\/DIV&gt; &lt;\/body&gt;<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u043d\u0435 \u0432\u0435\u0440\u0438\u0442\u0435 &#8212; \u043f\u0440\u043e\u0432\u0435\u0440\u044c\u0442\u0435 \u043d\u0430 \u0432\u0430\u043b\u0438\u0434\u0430\u0442\u043e\u0440\u0435 W3C. \u041a\u043e\u0434 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u0432\u0430\u043b\u0438\u0434\u0435\u043d, \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442 \u0432\u0430\u043b\u0438\u0434\u0430\u0442\u043e\u0440\u0430 \u043d\u0438\u0436\u0435<\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0410 \u0432\u043e\u0442 React+JSX \u0442\u0430\u043a\u043e\u0435 \u0443\u0436\u0435 \u043d\u0435 \u043f\u0440\u043e\u0433\u043b\u043e\u0442\u044f\u0442. \u0412 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435, \u044d\u0442\u043e \u043d\u0435 \u0431\u0435\u0434\u0430, \u0432\u0435\u0434\u044c \u043a\u043e\u043c\u0443 \u0432 \u0437\u0434\u0440\u0430\u0432\u043e\u043c \u0443\u043c\u0435 \u043f\u0440\u0438\u0434\u0451\u0442 \u0432 \u0433\u043e\u043b\u043e\u0432\u0443 \u0438\u0433\u0440\u0430\u0442\u044c\u0441\u044f \u0441 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u043e\u043c \u0432 HTML-\u0442\u044d\u0433\u0430\u0445. \u041d\u043e! \u0412\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0447\u0451\u0442\u043a\u043e \u043f\u043e\u043c\u043d\u0438\u0442\u044c, \u0447\u0442\u043e \u0432\u043c\u0435\u0441\u0442\u043e onclick \u043d\u0430\u0434\u043e \u043f\u0438\u0441\u0430\u0442\u044c onClick (\u0438 \u043d\u0438\u043a\u0430\u043a \u0438\u043d\u0430\u0447\u0435), \u0441 \u0434\u0440\u0443\u0433\u0438\u043c\u0438 \u044d\u0432\u0435\u043d\u0442\u0430\u043c\u0438 \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e, \u0430\u0442\u0440\u0438\u0431\u0443\u0442 readonly \u043f\u0438\u0448\u0435\u0442\u0441\u044f \u043a\u0430\u043a readOnly (\u0438 \u043d\u0438\u043a\u0430\u043a \u0438\u043d\u0430\u0447\u0435) \u0438 \u0442 \u043f. \u0412\u0441\u0435 \u044d\u0442\u0438 \u0440\u0430\u0437\u043b\u0438\u0447\u0438\u044f \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u044c, \u0438 \u0432\u044b \u0438\u0445 \u0440\u0430\u043d\u043e \u0438\u043b\u0438 \u043f\u043e\u0437\u0434\u043d\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u0435, \u043d\u043e&#8230; \u0417\u0430\u0447\u0435\u043c \u0436\u0435 \u0442\u043e\u0433\u0434\u0430 JSX \u0442\u0430\u043a \u043f\u043e\u0445\u043e\u0436 \u043d\u0430 HTML? \u0422\u043e, \u0447\u0442\u043e \u043c\u044b \u043d\u0435 \u043c\u043e\u0436\u0435\u043c \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u0437\u044f\u0442\u044c \u0438 \u0432\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0433\u043e\u0442\u043e\u0432\u0443\u044e \u0432\u0451\u0440\u0441\u0442\u043a\u0443 \u0432 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u043e\u0447\u0435\u043d\u044c \u0431\u0435\u0441\u0438\u0442 \u0438 \u0432\u044b\u043d\u0443\u0436\u0434\u0430\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0435\u0440\u044b HTML&lt;-&gt;JSX.<\/p>\n<p>\u0410 \u0435\u0449\u0451 \u0438\u043c\u044f \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0434\u043e\u043b\u0436\u043d\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u0442\u044c\u0441\u044f \u0441 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0431\u0443\u043a\u0432\u044b.<\/p>\n<pre><code class=\"javascript\">const comp = () =&gt; {     return &lt;div&gt;comp&lt;\/div&gt; }  const Comp = comp;  const App = () =&gt; {     return (&lt;&gt;         &lt;Comp \/&gt; {\/* Ok *\/}         &lt;comp \/&gt; {\/* \u041e\u0448\u0438\u0431\u043a\u0430 *\/}     &lt;\/&gt;); }<\/code><\/pre>\n<p>\u0412\u043f\u0440\u043e\u0447\u0435\u043c, \u0442\u0430\u043a\u043e\u0435 \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0443\u0436\u0435 \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u0438\u0432\u044b\u0447\u043d\u043e, \u0447\u0442\u043e \u043f\u0440\u043e\u043d\u0438\u043a\u043b\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0435\u0437\u0434\u0435. \u041f\u0440\u043e\u0441\u0442\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u0435 \u0438 \u0436\u0438\u0432\u0438\u0442\u0435 \u0441 \u044d\u0442\u0438\u043c.<\/p>\n<p>\u0420\u0430\u0437\u043b\u0438\u0447\u0438\u044f JSX \u0438 HTML \u043d\u0435 \u0444\u0430\u0442\u0430\u043b\u044c\u043d\u044b\u0435, \u043d\u043e \u0438\u0445 \u043c\u043d\u043e\u0433\u043e \u0438 \u043e\u043d\u0438 \u0440\u0430\u0437\u0434\u0440\u0430\u0436\u0430\u044e\u0442. \u0418 \u0442\u043e, \u0447\u0442\u043e \u0441\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c \u043a \u044d\u0442\u0438\u043c \u043c\u0435\u043b\u043a\u0438\u043c \u043f\u0430\u043a\u043e\u0441\u0442\u044f\u043c \u043f\u0440\u0438\u0432\u044b\u043a\u0430\u0435\u0448\u044c, \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u043e \u043d\u0435 \u043f\u043e\u0432\u043e\u0434 \u043d\u0435 \u043f\u043e\u0431\u0443\u0445\u0442\u0435\u0442\u044c \u043f\u043e \u044d\u0442\u043e\u043c\u0443 \u043f\u043e\u0432\u043e\u0434\u0443.<\/p>\n<h3>\u0420\u0430\u0434\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0432\u043e\u043f\u0440\u043e\u0441\u0430 \u043e\u0448\u0438\u0431\u043e\u043a<\/h3>\n<p>\u041d\u0430 \u043c\u043e\u0439 \u0432\u0437\u0433\u043b\u044f\u0434 &#8212; \u0441\u0430\u043c\u0430\u044f \u0436\u0443\u0442\u043a\u0430\u044f \u043d\u0435\u0434\u043e\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043d\u0430\u0448\u0435\u0439 \u043b\u044e\u0431\u0438\u043c\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438.<\/p>\n<p>\u0417\u043d\u0430\u043a\u043e\u043c\u0430\u044f \u043b\u044e\u0431\u043e\u043c\u0443 \u043e\u043f\u044b\u0442\u043d\u043e\u043c\u0443 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0443 React \u043a\u0430\u0440\u0442\u0438\u043d\u0430 &#8212; \u0438\u0437\u043c\u0435\u043d\u044f\u0435\u0448\u044c \u043a\u043e\u0434 \u043a\u0430\u043a\u043e\u0433\u043e-\u0442\u043e \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 \u0438&#8230; \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0448\u044c \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0441 \u0431\u0435\u043b\u044b\u043c \u044d\u043a\u0440\u0430\u043d\u043e\u043c.\u042d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0440\u0435\u0430\u043b\u044c\u043d\u0430\u044f \u043e\u0448\u0438\u0431\u043a\u0430, \u043e\u043f\u0435\u0447\u0430\u0442\u043a\u0430 \u0438\u043b\u0438 \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 &#8212; \u043f\u043b\u0435\u0432\u0430\u0442\u044c, \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043f\u0430\u0434\u0430\u0435\u0442 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e.<\/p>\n<p>\u0412\u043e\u0442 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u043f\u0440\u0438\u043c\u0435\u0440:<\/p>\n<pre><code class=\"javascript\">import { useEffect, useState } from 'react';  export const ErrorItem = () =&gt; {     let [value, setValue] = useState('hello');     useEffect(() =&gt; {         setTimeout(() =&gt; {             setValue({message: 'hello'})             }, 2000)     }, []);      return &lt;div&gt;{value}&lt;\/div&gt; }<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u0432\u044b \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 ErrorItem, \u0441\u043f\u0443\u0441\u0442\u044f \u043f\u0430\u0440\u0443 \u0441\u0435\u043a\u0443\u043d\u0434 \u043e\u0431\u043d\u0430\u0440\u0443\u0436\u0438\u0442\u0435, \u0447\u0442\u043e \u0432\u0441\u0451 \u0432\u0430\u0448\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0443\u043f\u0430\u043b\u043e. \u041d\u0435 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u0430 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0432\u0441\u0451, \u0434\u043e \u043f\u0443\u0441\u0442\u043e\u0433\u043e \u044d\u043a\u0440\u0430\u043d\u0430.React \u043f\u0440\u0438 \u043e\u0448\u0438\u0431\u043a\u0435 \u0432 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0442\u043c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u0442 \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0441\u0451 DOM-\u0434\u0435\u0440\u0435\u0432\u043e, \u0433\u0434\u0435<\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-452387","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/452387","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=452387"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/452387\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=452387"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=452387"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=452387"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}