{"id":341432,"date":"2022-11-18T15:00:47","date_gmt":"2022-11-18T15:00:47","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=341432"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=341432","title":{"rendered":"<span>\u041f\u0440\u043e\u0446\u0435\u0441\u0441 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430 Vue<\/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>\u0414\u043e\u0431\u0440\u044b\u0439 \u0434\u0435\u043d\u044c! \u041c\u0435\u043d\u044f \u0437\u043e\u0432\u0443\u0442 \u0410\u043b\u0435\u043a\u0441\u0430\u043d\u0434\u0440, \u044f \u0440\u0430\u0431\u043e\u0442\u0430\u044e frontend-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u043c \u0432 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 Nord Clan. \u0412 <a href=\"https:\/\/habr.com\/ru\/company\/nordclan\/blog\/690522\/\">\u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435<\/a> \u043c\u044b \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043b\u0438 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 Vue, \u0430 \u0442\u0435\u043f\u0435\u0440\u044c \u043d\u0430\u0434\u043e \u043a\u0430\u043a-\u0442\u043e \u00ab\u043f\u0440\u0438\u0441\u0442\u0440\u043e\u0438\u0442\u044c\u00bb \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u044d\u0442\u043e\u0439 \u0441\u0430\u043c\u043e\u0439 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430. \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0434\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u043c \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u043f\u0430\u043a\u0435\u0442\u044b:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/7a5\/8e5\/4c3\/7a58e54c30768acfa29864ecd5bb271b.png\" alt=\"\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0445 \u043f\u0430\u043a\u0435\u0442\u043e\u0432 Vue\" title=\"\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0445 \u043f\u0430\u043a\u0435\u0442\u043e\u0432 Vue\" width=\"1560\" height=\"371\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/7a5\/8e5\/4c3\/7a58e54c30768acfa29864ecd5bb271b.png\"\/><figcaption>\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0445 \u043f\u0430\u043a\u0435\u0442\u043e\u0432 Vue<\/figcaption><\/figure>\n<p>\u0412 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430 \u0431\u0443\u0434\u0443\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043f\u0430\u043a\u0435\u0442\u044b <strong>runtime-dom<\/strong> \u0438 <strong>runtime-core<\/strong>. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c, runtime-dom \u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u0440\u0430\u0449\u0430\u0442\u044c\u0441\u044f \u043a \u0441\u0432\u043e\u0435\u043c\u0443 \u0441\u0442\u0430\u0440\u0448\u0435\u043c\u0443 \u0431\u0440\u0430\u0442\u0443 runtime-core, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u043e\u043b\u0435\u0435 \u043c\u0443\u0434\u0440\u044b\u0439 \u0438 \u0437\u043d\u0430\u0435\u0442 \u043a\u0430\u043a, \u043a\u043e\u0433\u0434\u0430, \u0438 \u0433\u0434\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c api \u0438\u0437 runtime-dom.<\/p>\n<p>\u041d\u0430\u0447\u043d\u0435\u043c \u043a\u0430\u043a \u043e\u0431\u044b\u0447\u043d\u043e \u0438\u0437\u0434\u0430\u043b\u0435\u043a\u0430, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0431\u0443\u0434\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043d\u0430\u0431\u0440\u043e\u0441\u043a\u0438 \u0441\u0445\u0435\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430, \u0430 \u0434\u0430\u043b\u0435\u0435 \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u0442\u044c\u0441\u044f \u0432 \u043d\u0438\u0445.<\/p>\n<p>\u0421\u0442\u0440\u0435\u043b\u043a\u0438 \u0432 \u044d\u0442\u0438\u0445 \u0441\u0445\u0435\u043c\u0430\u0445 \u0431\u0443\u0434\u0443\u0442 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u043d\u0430 \u0432\u044b\u0437\u043e\u0432\u044b \u0434\u0440\u0443\u0433\u0438\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u0430 \u043f\u0443\u043d\u043a\u0442\u0438\u0440\u043d\u044b\u0435 \u043b\u0438\u043d\u0438\u0438 \u043d\u0430 \u043a\u043e\u0434, \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u043c\u044b\u0439 \u0432\u043d\u0443\u0442\u0440\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u0439. \u0421\u043a\u0430\u0436\u0435\u043c \u0442\u0430\u043a, \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u0434\u0436\u0443\u043c\u0430\u043d\u0434\u0436\u0438 \u0432 \u043c\u0438\u0440\u0430 \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434\u0430, \u0438 \u0434\u0436\u0443\u043d\u0433\u043b\u0438 \u043a\u043e\u0434\u0430 \u0431\u0443\u0434\u0443\u0442 \u0432\u0441\u0435 \u0433\u0443\u0449\u0435 \u0438 \u0433\u0443\u0449\u0435&#8230;<\/p>\n<h3>\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430<\/h3>\n<p>\u0412\u043e\u0437\u044c\u043c\u0435\u043c \u043c\u043e\u0449\u043d\u044b\u0439 \u043c\u0438\u043a\u0440\u043e\u0441\u043a\u043e\u043f \u0438 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0442\u043e, \u043a\u0430\u043a \u044d\u0442\u0438 \u043f\u0430\u043a\u0435\u0442\u044b (runtime-dom \u0438 runtime-core) \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0443\u044e\u0442 \u043c\u0435\u0436\u0434\u0443 \u0441\u043e\u0431\u043e\u0439 \u0441 \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043f\u043e\u0448\u0430\u0433\u043e\u0432\u044b\u043c \u0438 \u0434\u0435\u0442\u0430\u043b\u044c\u043d\u044b\u043c \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435\u043c \u0434\u0430\u043d\u043d\u043e\u0439 \u0441\u0445\u0435\u043c\u044b:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/8f0\/1da\/f5e\/8f01daf5eb8bc4119bbb6fb241e0ea7d.png\" alt=\"\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430\" title=\"\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430\" width=\"1160\" height=\"520\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/8f0\/1da\/f5e\/8f01daf5eb8bc4119bbb6fb241e0ea7d.png\"\/><figcaption>\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430<\/figcaption><\/figure>\n<p>\u041f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0438\u0437 app (\u0431\u0435\u0440\u0435\u043c \u043b\u044e\u0431\u043e\u0435 Vue-\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435) \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u044e createApp(), \u0438 \u043f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c \u0434\u0430\u043d\u043d\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 ensureRenderer:<\/p>\n<pre><code class=\"typescript\">export const createApp = (...args) => {   const app = ensureRenderer(); }<\/code><\/pre>\n<p>ensureRenderer \u043b\u0438\u0431\u043e \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u043d\u043e\u0432\u044b\u0439 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430, \u043b\u0438\u0431\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0443\u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0439:<\/p>\n<pre><code class=\"typescript\">function ensureRenderer() {   return (     renderer ||     (renderer = createRenderer(rendererOptions))   ) }<\/code><\/pre>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u044f createrRenderer \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0438\u0437 \u043f\u0430\u043a\u0435\u0442\u0430 runtime-core \u0438 \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442 \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430 \u043e\u0431\u044a\u0435\u043a\u0442 \u0441 \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 DOM (rendererOptions), \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0443\u0434\u0443\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u044b\u0445 \u043d\u043e\u0434 \u0432\u043d\u0443\u0442\u0440\u0438 runtime-core.<\/p>\n<p>\u0417\u0430\u043c\u0435\u0442\u0438\u043c, \u0447\u0442\u043e renderer \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u043d\u0435 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d, \u0442\u0430\u043a \u043a\u0430\u043a \u0442\u0438\u043f renderer \u043c\u043e\u0436\u0435\u0442 \u043e\u0442\u043b\u0438\u0447\u0430\u0442\u044c\u0441\u044f \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 \u0441\u0440\u0435\u0434 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043a\u043e\u0434\u0430:<\/p>\n<pre><code class=\"typescript\">let renderer: Renderer&lt;Element | ShadowRoot> | HydrationRenderer<\/code><\/pre>\n<p>\u0412 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f createRenderer, \u0442\u0430\u043a \u043a\u0430\u043a \u043f\u043e\u043a\u0430 \u0447\u0442\u043e \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e renderer \u0441\u043e\u0437\u0434\u0430\u043d\u043e \u043d\u0435 \u0431\u044b\u043b\u043e:<\/p>\n<pre><code class=\"typescript\">(renderer = createRenderer(rendererOptions))<\/code><\/pre>\n<p>\u042d\u0442\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u0432 \u0441\u0432\u043e\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c \u0432\u044b\u0437\u043e\u0432\u0435\u0442 baseCreateRenderer \u0438\u0437 \u043f\u0430\u043a\u0435\u0442\u0430 runtime-core, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0442\u0432\u0435\u0447\u0430\u0435\u0442 \u0437\u0430 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043d\u043e\u0432\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430.<\/p>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u0438 patch, render, mount \u0438 \u0442.\u0434. \u0431\u0443\u0434\u0443\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u044b\u0435 \u0438\u0437 runtime-dom \u043c\u0435\u0442\u043e\u0434\u044b (hostInsert, hostRemove \u0438 \u0442.\u0434):<\/p>\n<pre><code class=\"typescript\">function baseCreateRenderer(   options: RendererOptions, ) {   const {     insert: hostInsert,     remove: hostRemove,     createElement: hostCreateElement,     createText: hostCreateText,     \/\/ ...   } = options    const patch = () => {     \/\/ ...   }    const render = () => {     \/\/ ...   }    const mount = () => {     \/\/ ...   }    \/\/ ... }<\/code><\/pre>\n<p>\u041a\u043e\u043d\u0435\u0447\u043d\u043e \u00ab\u043f\u043e\u0440\u0442\u044f\u043d\u043a\u0430\u00bb \u043a\u043e\u0434\u0430 \u0432 \u044d\u0442\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u0431\u043e\u043b\u044c\u0448\u0435, \u043d\u043e \u043c\u043d\u0435 \u043d\u0435 \u043e\u0445\u043e\u0442\u0430 \u043f\u0443\u0433\u0430\u0442\u044c \u0432\u0430\u0441 \u0442\u0430\u043a \u0436\u0435, \u043a\u0430\u043a \u0438\u0441\u043f\u0443\u0433\u0430\u043b\u0441\u044f \u044f \u043f\u0440\u0438 \u0435\u0435 \u0432\u0438\u0434\u0435. \u041e\u0434\u043d\u0430\u043a\u043e \u0436\u0435, \u0438\u043c\u0435\u043d\u043d\u043e \u044d\u0442\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 <s>\u043e\u0431\u0443\u0447\u0438\u0442\u0441\u044f \u0448\u0430\u0431\u043b\u043e\u043d\u0430\u043c \u0440\u0435\u0444\u0430\u043a\u0442\u043e\u0440\u0438\u043d\u0433\u0430<\/s> \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0441\u0442\u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433.<\/p>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u044f baseCreateRenderer \u0432\u043e\u0437\u0432\u0440\u0430\u0442\u0438\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u0443\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e render, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u044e createAppAPI:<\/p>\n<pre><code class=\"typescript\">function baseCreateRenderer(   options: RendererOptions, ) {   \/\/ ...     return {     render,     createApp: createAppAPI(render)   } }<\/code><\/pre>\n<p>createAppAPI \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u044e, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438 \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u0438\u0442 \u043c\u0435\u0442\u043e\u0434\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0432 app, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, createApp().mount() \u0438\u043b\u0438 createApp().unmount():<\/p>\n<pre><code class=\"typescript\">export function createAppAPI&lt;HostElement>(   render: RootRenderFunction, ): CreateAppFunction&lt;HostElement> {   return function createApp(rootComponent) {     const app = {       mount() {         \/\/ ...       },       unmount() {         \/\/ ...       },     }      return app   } }<\/code><\/pre>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043a\u0430\u043a \u0440\u0430\u0437 \u0432\u044b\u0437\u043e\u0432\u0435\u0442 createApp, \u0430 \u0434\u0430\u043b\u0435\u0435 \u0441 \u0440\u0430\u0434\u043e\u0441\u0442\u044c\u044e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u043c\u0435\u0442\u043e\u0434 mount, \u0434\u0430\u0436\u0435 \u043d\u0435 \u043f\u043e\u0434\u043e\u0437\u0440\u0435\u0432\u0430\u044f \u043e \u0442\u0435\u0445 \u0441\u0442\u0440\u0430\u0448\u043d\u044b\u0445 \u0432\u0435\u0449\u0430\u0445, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0443\u0442 \u0432 \u00ab\u0447\u0435\u0440\u043d\u043e\u043c-\u0447\u0435\u0440\u043d\u043e\u043c \u044f\u0449\u0438\u043a\u0435\u00bb&#8230;<\/p>\n<p>\u0412\u043e\u0437\u044c\u043c\u0435\u043c \u0441\u0442\u0430\u0440\u044b\u0439 \u043f\u0440\u0438\u043c\u0435\u0440 \u0438\u0437 \u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438. \u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 rootComponent \u043f\u0435\u0440\u0435\u0434\u0430\u0434\u0438\u043c \u043b\u0438\u0442\u0435\u0440\u0430\u043b \u043e\u0431\u044a\u0435\u043a\u0442\u0430, \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0449\u0438\u0439 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u0438 \u043c\u0435\u0442\u043e\u0434\u044b \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0433\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430:<\/p>\n<pre><code class=\"typescript\">Vue   .createApp({     data: () => ({       dynamic: 1     }),     template: `       &lt;div>         &lt;div>foo&lt;\/div>         &lt;div>bar&lt;\/div>         &lt;div>{{ dynamic }}&lt;\/div>       &lt;\/div>     `,   })   .mount('#app')<\/code><\/pre>\n<p>\u0412\u0435\u0440\u043d\u0435\u043c\u0441\u044f \u043a \u0444\u0443\u043d\u043a\u0446\u0438\u0438 createApp. \u041a\u0430\u043a \u0440\u0430\u0437 \u043e\u043d\u0430 \u0438 \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 Vue.createApp, \u0430 \u0440\u0430\u043d\u0435\u0435 baseCreaterenderer (\u043f\u043e\u043c\u043d\u0438\u043c, \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f \u0432 ensureRenderer) \u0443\u0436\u0435 \u043b\u044e\u0431\u0435\u0437\u043d\u043e \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u0438\u043b \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0447\u0435\u0440\u0435\u0437 \u0432\u044b\u0437\u043e\u0432 createApp:<\/p>\n<pre><code class=\"typescript\">export const createApp = (...args) => {   const app = ensureRenderer().createApp(); }<\/code><\/pre>\n<p>\u0418\u0442\u0430\u043a, \u043f\u0435\u0440\u0432\u044b\u0439 \u044d\u0442\u0430\u043f \u043f\u0440\u043e\u0439\u0434\u0435\u043d, \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0441\u043e\u0437\u0434\u0430\u043d, \u043f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u043a \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c\u0443 \u044d\u0442\u0430\u043f\u0443 &#8212; \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e, <s>\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e \u0432\u0438\u0434\u0435\u043e\u043a\u0443\u0440\u0441\u0430<\/s> <s>\u043f\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044e \u0441\u0432\u043e\u0435\u0439 \u0440\u0435\u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438<\/s>.<\/p>\n<h3>\u041a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u0448\u0430\u0431\u043b\u043e\u043d\u0430, \u043a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode (\u0438\u043b\u0438 initialVNode) \u0438 patch-\u0444\u0443\u043d\u043a\u0446\u0438\u044f<\/h3>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/ad4\/e8b\/1af\/ad4e8b1aff4fa8c0e54725982d35e9b7.png\" alt=\"\u041c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\" title=\"\u041c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\" width=\"1340\" height=\"1000\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/ad4\/e8b\/1af\/ad4e8b1aff4fa8c0e54725982d35e9b7.png\"\/><figcaption>\u041c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430<\/figcaption><\/figure>\n<p>app.createApp() \u0443\u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u043b\u0430 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0438 \u0438\u043c\u0435\u0435\u0442 \u0432\u0441\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u043c\u0435\u0442\u043e\u0434\u044b \u0434\u043b\u044f \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0435\u043d\u0438\u044f \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e \u043c\u0435\u0442\u043e\u0434 mount, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0443\u0434\u0435\u0442 \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0438\u0441\u0430\u043d \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 runtime-dom:<\/p>\n<pre><code class=\"typescript\">export const createApp = (...args) => {   const app = ensureRenderer().createApp();    const { mount } = app    app.mount = (containerOrSelector: Element | ShadowRoot | string) => {     \/\/ \u0417\u0434\u0435\u0441\u044c \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 containerOrSelector \u043d\u0430 \u0432\u0430\u043b\u0438\u0434\u043d\u043e\u0441\u0442\u044c      const proxy = mount(containerOrSelector)      return proxy   } }<\/code><\/pre>\n<p>\u041c\u0435\u0442\u043e\u0434 mount \u0432\u044b\u0437\u043e\u0432\u0435\u0442 \u043a\u0430\u043a \u0440\u0430\u0437 \u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 \u043c\u0435\u0442\u043e\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0437\u0434\u0430\u043b createApp, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0438\u0437 baseCreateRenderer, \u043f\u0435\u0440\u0435\u0434\u0430\u0432 \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430 \u0441\u0435\u043b\u0435\u043a\u0442\u043e\u0440 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430 \u0438\u043b\u0438 \u0441\u0430\u043c \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440, \u043a\u0443\u0434\u0430 \u0431\u0443\u0434\u0435\u0442 \u0441\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043e Vue-\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435.<\/p>\n<p>\u041f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u0432 \u043c\u0435\u0442\u043e\u0434\u0443 mount, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b\u0441\u044f \u0432 createAppAPI. \u041c\u0435\u0442\u043e\u0434 mount \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u043a\u043e\u0440\u043d\u0435\u0432\u0443\u044e vnode \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u043e\u0433\u043e template, data \u0438 \u0442.\u0434.:<\/p>\n<pre><code class=\"typescript\">export function createAppAPI(   render: RootRenderFunction, ): CreateAppFunction {   return function createApp(rootComponent, rootProps = null) {      \/\/ ...      const app = {       mount(rootContainer) {         \/\/ \u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0439 vnode (initialVNode)         const vnode = createVNode(rootComponent)          render(vnode, rootContainer)       },     }      return app   } }<\/code><\/pre>\n<p>\u041a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a:<\/p>\n<pre><code class=\"typescript\">const vnode = {   dynamicChildren: null,   dynamicProps: null,   patchFlag: 0,   shapeFlag: 4,   data: () => ({ dynamic: 1 }),   template: `           \\n&lt;div>\\n               &lt;div>foo&lt;\/div>\\n       &lt;div>bar&lt;\/div>\\n               &lt;div>{{ dynamic }}&lt;\/div>\\n           &lt;\/div>\\n ` }<\/code><\/pre>\n<p>shapeFlag \u0441\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c \u00ab4\u00bb \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442 STATEFUL_COMPONENT. patchFlag \u0431\u0443\u0434\u0435\u0442 \u0442\u0430\u043a\u0436\u0435 \u043d\u0443\u0436\u0435\u043d \u0432 \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u043c \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0435\u0442\u0430. \u041f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u0434\u043b\u044f shapeFlag \u0438 patchFlag \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u044b \u0447\u0435\u0440\u0435\u0437 <a href=\"https:\/\/learn.javascript.ru\/bitwise-operators\"><u>\u043f\u043e\u0431\u0438\u0442\u043e\u0432\u0443\u044e \u043c\u0430\u0441\u043a\u0443<\/u><\/a> \u0434\u043b\u044f \u0443\u0434\u043e\u0431\u0441\u0442\u0432\u0430, \u043a\u0445\u043c, \u043f\u0440\u043e\u0441\u0442\u0438\u0442\u0435, \u043f\u0440\u043e\u0432\u0435\u0440\u043e\u043a \u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438.<\/p>\n<p>\u0412\u0435\u0440\u043d\u0435\u043c\u0441\u044f \u043a \u043c\u0435\u0442\u043e\u0434\u0443 mount, \u043f\u043e\u0434\u0441\u0442\u0430\u0432\u0438\u043c \u0441\u044e\u0434\u0430 \u044d\u0442\u0443 \u0441\u0430\u043c\u0443\u044e \u043a\u043e\u0440\u043d\u0435\u0432\u0443\u044e vnode:<\/p>\n<pre><code class=\"typescript\">mount(rootContainer) {   const vnode = {     dynamicChildren: null,     dynamicProps: null,     patchFlag: 0,     shapeFlag: 4,     data: () => ({ dynamic: 1 }),     template: `             \\n&lt;div>\\n                 &lt;div>foo&lt;\/div>\\n         &lt;div>bar&lt;\/div>\\n                 &lt;div>{{ dynamic }}&lt;\/div>\\n             &lt;\/div>\\n `   }    render(vnode, rootContainer) }<\/code><\/pre>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u044f render, \u043a\u0430\u043a \u043f\u043e\u043c\u043d\u0438\u043c, \u0431\u044b\u043b\u0430 \u043e\u0431\u044a\u044f\u0432\u043b\u0435\u043d\u0430 \u0432 baseCreateRenderer. \u041e\u043d\u0430 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u00ab\u043f\u0430\u0442\u0447\u0438\u043d\u0433\u0430\u00bb \u043d\u043e\u0432\u043e\u0439 vnode \u0432 container (#app):<\/p>\n<pre><code class=\"typescript\">function baseCreateRenderer(   options: RendererOptions, ) {   const patch = () => {     \/\/ ...   }    const render = () => {     patch(container._vnode || null, vnode, container)   } }<\/code><\/pre>\n<p>\u041f\u043e\u0436\u0430\u043b\u0443\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u044f patch \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u043e\u0439 \u0438\u0437 \u0441\u0430\u043c\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0432\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, big boss \u0432 \u0441\u0432\u043e\u0435\u043c \u043f\u0430\u043a\u0435\u0442\u0435.<\/p>\n<p>\u042d\u0442\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u00ab\u043f\u0440\u043e\u043a\u0441\u0438\u0440\u0443\u0435\u0442\u00bb \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0442\u043e\u0439 \u0438\u043b\u0438 \u0438\u043d\u043e\u0439 vnode \u043d\u0443\u0436\u043d\u043e\u043c\u0443 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0443 (\u043f\u0430\u0440\u0434\u043e\u043d \u0437\u0430 \u0442\u0430\u0432\u0442\u043e\u043b\u043e\u0433\u0438\u044e), \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u044f \u0442\u0438\u043f vnode \u043f\u043e shapeFlag, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0442\u0438\u043f \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u043f\u043e patchFlag.<\/p>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c \u043e\u043d\u0430 \u043e\u0442\u0432\u0435\u0447\u0430\u0435\u0442 \u0437\u0430 \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0442\u0435\u043c, \u043a\u0430\u043a \u0442\u043e\u0442 \u0438\u043b\u0438 \u0443\u0437\u0435\u043b VDOM \u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u043d \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u043e\u0431\u0445\u043e\u0434\u0430 VDOM-\u0434\u0435\u0440\u0435\u0432\u0430:<\/p>\n<pre><code class=\"typescript\">const patch: PatchFn = (     n1,     n2,     container, ) => {     if (n1 === n2) {       \/\/ \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u043c\u0430\u044f \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u0430\u044f \u043d\u043e\u0434\u0430 n1 \u0438\u0434\u0435\u043d\u0442\u0438\u0447\u043d\u0430 \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u043e\u0439 \u043d\u043e\u0434\u0435 n2       \/\/ \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u0434\u0435\u043b\u0430\u0442\u044c     }      if (n1 &amp;&amp; !isSameVNodeType(n1, n2)) {       \/\/ \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u043c\u0430\u044f \u0432\u043d\u043e\u0434\u0430 n1 \u043d\u0435 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u0438\u043c \u0438 \u0442\u0435\u043c \u0442\u0438\u043f\u043e\u043c \u0441 n2       \/\/ \u0440\u0430\u0437\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432\u0435\u0441\u044c n1, \u0447\u0442\u043e\u0431\u044b \u0441\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u043d\u043e\u0432\u043e \u0431\u0435\u0437 \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0435\u0442\u0430     }      const { type, ref, shapeFlag } = n2      switch (type) {       default:         if (shapeFlag &amp; ShapeFlags.ELEMENT) {           \/\/ \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c n1 \u0432 n2 \u043a\u0430\u043a \u0435\u043b\u0435\u043c\u0435\u043d\u0442         } else if (shapeFlag &amp; ShapeFlags.COMPONENT) {           \/\/ \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c n1 \u0432 n2 \u043a\u0430\u043a \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442         }     } }<\/code><\/pre>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u043e\u043a \u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432 \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u0431\u043e\u043b\u044c\u0448\u0435, \u043d\u043e \u043b\u0443\u0447\u0448\u0435 \u0441\u0444\u043e\u043a\u0443\u0441\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u043c.<\/p>\n<p>\u041a\u0430\u043a \u043f\u043e\u043c\u043d\u0438\u043c, \u043d\u0430\u0448\u0430 \u043a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode \u0438\u043c\u0435\u0435\u0442 shapeFlag \u0440\u0430\u0432\u043d\u044b\u0439 STATEFUL_COMPONENT, \u0430 \u0437\u043d\u0430\u0447\u0438\u0442 \u043f\u043e\u0440\u0430 \u0432\u044b\u0445\u043e\u0434\u0438\u0442\u044c \u043d\u0430 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0435 processComponent:<\/p>\n<pre><code class=\"typescript\">const patch: PatchFn = (     n1,     n2,     container,   ) => {     \/\/ ...      const { type, ref, shapeFlag } = n2      switch (type) {       \/\/ ...        default:         \/\/ ...          if (shapeFlag &amp; ShapeFlags.COMPONENT) {           processComponent(n1, n2, container)         }     } }<\/code><\/pre>\n<p>\u041b\u043e\u0433\u0438\u043a\u0430 \u0440\u0430\u0431\u043e\u0442\u044b \u0444\u0443\u043d\u043a\u0446\u0438\u0439-\u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432 \u043d\u0443\u0436\u043d\u043e\u0433\u043e \u0442\u0438\u043f\u0430 vnode \u0441\u0445\u043e\u0436\u0430 \u043c\u0435\u0436\u0434\u0443 \u0441\u043e\u0431\u043e\u0439, \u0431\u0443\u0434\u044c \u0442\u043e processComponent, processText, processElement \u0438 \u0442.\u0434. \u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u043d\u0430\u043b\u0438\u0447\u0438\u0435 n1 (\u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u0430\u044f vnode), \u0438 \u0435\u0441\u043b\u0438 \u043e\u043d\u0430 \u0435\u0441\u0442\u044c, \u0442\u043e \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0435\u0442\u0430, \u0430 \u0435\u0441\u043b\u0438 \u043d\u0435\u0442 \u2014 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f.<\/p>\n<p>\u0412 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u043e\u0435 \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f mountComponent:<\/p>\n<pre><code class=\"typescript\">const processComponent = (     n1: VNode | null,     n2: VNode,     container: RendererElement, ) => {      \/\/ n1 \u0440\u0430\u0432\u043d\u044f\u0435\u0442\u0441\u044f null, \u0437\u043d\u0430\u0447\u0438\u0442 \u043c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442      if (n1 == null) {       mountComponent(         n2,         container,       )     } else {       updateComponent(n1, n2)     } }<\/code><\/pre>\n<p>\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u044f mountComponent? \u041e\u043d\u0430 \u0443\u0436\u0435 \u0431\u044b\u043b\u0430 \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u0430 \u0432 <a href=\"https:\/\/habr.com\/ru\/company\/nordclan\/blog\/690522\/\"><u>\u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0435<\/u><\/a> \u043f\u0440\u043e \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044e \u0432 Vue, \u0433\u0434\u0435 \u044d\u0442\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u043e\u043c\u043e\u0433\u0430\u0435\u0442 \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0441\u0442\u0438 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044e \u0448\u0430\u0431\u043b\u043e\u043d\u0430 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 \u0432 runtime, \u0430 \u043f\u043e\u0442\u043e\u043c \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438, \u043e\u0441\u0432\u0435\u0436\u0438\u043c \u043f\u0430\u043c\u044f\u0442\u044c:<\/p>\n<pre><code class=\"typescript\">const mountComponent: MountComponentFn = (   initialVNode,   container, ) => {   const instance: ComponentInternalInstance = (     initialVNode.component = createComponentInstance(initialVNode)       )      \/\/ \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u0438 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0435\u0442 \u0437\u0434\u0435\u0441\u044c   setupComponent(instance)     \/\/ \u0430 \u0437\u0434\u0435\u0441\u044c \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0435\u0442 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433   setupRenderEffect(     instance,     container,   ) }<\/code><\/pre>\n<p>createComponentInstance \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430. \u041f\u043e\u043b\u0435\u0439 \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u0431\u043e\u043b\u044c\u0448\u0435, \u0432\u044b\u0434\u0435\u043b\u0438\u043c \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435:<\/p>\n<pre><code class=\"typescript\">const instance: ComponentInternalInstance = {     uid: uid++,     vnode, \/\/ \u043a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode     type, \/\/ { data: { ... }, template: `` }     appContext, \/\/ \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f (mount, render, directives)     render: null, \/\/ render-\u0444\u0443\u043d\u043a\u0446\u0438\u044f, \u0431\u0443\u0434\u0435\u0442 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0430 \u043f\u043e\u0441\u043b\u0435 \u043f\u0430\u0440\u0441\u0438\u043d\u0433\u0430 template     isMounted: false, \/\/ \u0444\u043b\u0430\u0433 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f mounted     isUnmounted: false, \/\/ \u0444\u043b\u0430\u0433 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f unmounted }<\/code><\/pre>\n<p>\u0414\u0430\u043b\u0435\u0435 \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f setupComponent, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u0440\u0438\u043c\u0435\u0442 \u043d\u043e\u0432\u044b\u0439 instance:<\/p>\n<pre><code class=\"typescript\">const mountComponent: MountComponentFn = (   initialVNode,   container, ) => {   \/\/ ...    setupComponent(instance)     \/\/ ... }<\/code><\/pre>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u044f setupComponent \u043f\u043e\u0441\u043b\u0435 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043f\u0440\u0438\u0433\u043e\u0442\u043e\u0432\u043b\u0435\u043d\u0438\u0439 \u0432\u044b\u0437\u043e\u0432\u0435\u0442 finishSetupComponent, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0441\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u0435\u0442 \u0448\u0430\u0431\u043b\u043e\u043d \u0432 render-\u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442 \u0435\u0435 \u0432 instance.render. \u0423\u0441\u043b\u043e\u0432\u0438\u0439 \u043c\u043d\u043e\u0433\u043e, \u043d\u043e \u0441\u043a\u043e\u0440\u043e \u043f\u0440\u0438\u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u044f\u0441\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u0431\u0440\u0438\u0433\u0430\u0434\u0430:<\/p>\n<pre><code class=\"typescript\">export function finishComponentSetup(   instance: ComponentInternalInstance, ) {   const Component = instance.type    if (!instance.render) {     if (compile &amp;&amp; !Component.render) {       if (Component.template) {         Component.render = compile(template, finalCompilerOptions)       }     }      instance.render = Component.render   }  }<\/code><\/pre>\n<p>\u0412 \u043f\u0435\u0440\u0432\u0443\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c <s>\u043f\u0440\u0438\u0435\u0437\u0436\u0430\u0435\u0442 \u043f\u043e\u044f\u0441\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u0431\u0440\u0438\u0433\u0430\u0434\u0430<\/s> \u0438\u0437\u0432\u043b\u0435\u043a\u0430\u0435\u0442\u0441\u044f \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442:<\/p>\n<pre><code class=\"typescript\">export function finishComponentSetup(   instance: ComponentInternalInstance, ) {   const Component = instance.type \/\/ { template: \"&lt;div>...\", data: () => { ... } }     \/\/ ... }<\/code><\/pre>\n<p>\u0414\u0430\u043b\u0435\u0435 \u0438\u0434\u0435\u0442 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 \u043d\u0430 \u043d\u0430\u043b\u0438\u0447\u0438\u0435 \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440\u0430 compile, \u0448\u0430\u0431\u043b\u043e\u043d\u0430 template \u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u0445 render-\u0444\u0443\u043d\u043a\u0446\u0438\u0439. \u041f\u0440\u0438 \u0443\u0441\u043f\u0435\u0448\u043d\u044b\u0445 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430\u0445 \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c\u0441\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f compile, \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u043c \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0431\u0443\u0434\u0435\u0442 \u043d\u043e\u0432\u0430\u044f \u0440\u0435\u043d\u0434\u0435\u0440-\u0444\u0443\u043d\u043a\u0446\u0438\u044f:<\/p>\n<pre><code class=\"typescript\">export function finishComponentSetup(   instance: ComponentInternalInstance, ) {   \/\/ \u043c\u043e\u0436\u0435\u0442 \u0443\u0436\u0435 \u0435\u0441\u0442\u044c render-\u0444\u0443\u043d\u043a\u0446\u0438\u044f?   if (!instance.render) {     \/\/ render-\u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u043d\u0435\u0442, \u0430 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440 \u0435\u0441\u0442\u044c!?    if (compile &amp;&amp; !Component.render) {        \/\/ \u043e\u0442\u043b\u0438\u0447\u043d\u043e, \u043d\u0443\u0436\u0435\u043d \u0435\u0449\u0435 template\u2026       if (Component.template) {         Component.render = compile(template, finalCompilerOptions)       }     }     \/\/ ... }<\/code><\/pre>\n<p>\u041d\u043e\u0432\u0430\u044f render-\u0444\u0443\u043d\u043a\u0446\u0438\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u043d\u0430 \u0438\u043d\u0441\u0442\u0430\u043d\u0441\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430:<\/p>\n<pre><code class=\"typescript\">export function finishComponentSetup(   instance: ComponentInternalInstance, ) {   \/\/ ...    instance.render = Component.render() }<\/code><\/pre>\n<p>finishComponentSetup \u0437\u0430\u0432\u0435\u0440\u0448\u0438\u043b\u0441\u044f \u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043b render-\u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0432 instance. \u0412 \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u043c \u0432\u044b\u0437\u043e\u0432 \u044d\u0442\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0441\u043e\u0437\u0434\u0430\u0441\u0442 VDOM.<\/p>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0440\u0438\u0448\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 render-\u0444\u0443\u043d\u043a\u0446\u0438\u044e \u00a0\u00ab\u043d\u0430 \u0431\u0443\u043c\u0430\u0433\u0443\u00bb \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u0438 setupRenderEffect (\u0437\u0434\u0435\u0441\u044c \u043c\u043e\u0433\u043b\u0430 \u0431\u044b \u0431\u044b\u0442\u044c \u0432\u0430\u0448\u0430 \u0440\u0435\u043a\u043b\u0430\u043c\u0430 \u0431\u0430\u0440\u0430\u0431\u0430\u043d\u043d\u043e\u0439 \u0434\u0440\u043e\u0431\u0438):<\/p>\n<pre><code class=\"typescript\">const mountComponent: MountComponentFn = (   initialVNode,   container, ) => {   \/\/ ...     setupRenderEffect(     instance,     container,   ) }<\/code><\/pre>\n<p>\u041f\u0435\u0440\u0435\u0434\u0430\u0435\u0442\u0441\u044f \u0432 \u043d\u0435\u0435 instance \u0441 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0439 vnode, \u0430 \u0442\u0430\u043a\u0436\u0435 container (#app), \u043a\u0443\u0434\u0430 \u043d\u0430\u0434\u043e \u0431\u0443\u0434\u0435\u0442 \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c VDOM.<\/p>\n<p>setupRenderEffect \u0432\u044b\u0437\u043e\u0432\u0435\u0442 render-\u0444\u0443\u043d\u043a\u0446\u0438\u044e, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u043e\u0441\u0442\u0440\u043e\u0438\u0442 VDOM. \u0412 \u0441\u0430\u043c\u043e\u043c \u043d\u0430\u0447\u0430\u043b\u0435 \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f renderComponentRoot, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 VDOM-\u0434\u0435\u0440\u0435\u0432\u043e, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043c\u043e\u0436\u0435\u0442 \u0432\u043a\u043b\u044e\u0447\u0430\u0442\u044c \u043f\u043e\u0434\u0434\u0435\u0440\u0435\u0432\u044c\u044f, \u043f\u043e \u043a\u043e\u0442\u043e\u0440\u044b\u043c \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0434\u0435\u043d \u043e\u0431\u0445\u043e\u0434:<\/p>\n<pre><code class=\"typescript\">const setupRenderEffect: SetupRenderEffectFn = () => {   \/\/ ...   const subTree = (instance.subTree = renderComponentRoot(instance))    \/\/ ... }<\/code><\/pre>\n<p>renderComponentRoot \u0432\u044b\u0437\u043e\u0432\u0435\u0442 \u0437\u0430\u0432\u0435\u0442\u043d\u0443\u044e render-\u0444\u0443\u043d\u043a\u0446\u0438\u044e, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0431\u044b\u043b\u0430 \u0441\u043e\u0437\u0434\u0430\u043d\u0430 \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438, \u043f\u0435\u0440\u0435\u0434\u0430\u0432 \u0432 \u043d\u0435\u0435 Proxy-\u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430, \u0434\u043b\u044f \u043e\u0442\u0441\u043b\u0435\u0436\u0438\u0432\u0430\u043d\u0438\u044f \u0438\u0445 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439 \u0438 \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0438\u0445 \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0435\u0442\u043e\u0432. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0432 \u043f\u0440\u043e\u043a\u0441\u0438-\u043e\u0431\u044a\u0435\u043a\u0442\u0435 \u0431\u0443\u0434\u0443\u0442 $props, $data \u0438 \u0442.\u0434. <\/p>\n<p>\u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u043a\u0430\u043a \u0441\u043a\u0430\u0437\u0430\u043b \u0431\u044b \u041a\u0430\u043d\u0435\u0432\u0441\u043a\u0438\u0439, \u044d\u0442\u043e \u0441\u043e\u0432\u0441\u0435\u043c \u0434\u0440\u0443\u0433\u0430\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f, \u0430 \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u0435\u0440\u043d\u0435\u043c\u0441\u044f \u043a renderComponentRoot:<\/p>\n<pre><code class=\"typescript\">export function renderComponentRoot(   instance: ComponentInternalInstance ): VNode {   const {     proxy,   } = instance    let result: VNode    \/\/ \u0421\u043e\u0437\u0434\u0430\u0442\u044c \u043d\u043e\u0432\u043e\u0435 VDOM-\u0434\u0435\u0440\u0435\u0432\u043e   result = render!.call(     proxy   )    return result }<\/code><\/pre>\n<p>render-\u0444\u0443\u043d\u043a\u0446\u0438\u044f \u0432\u0435\u0440\u043d\u0435\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 VDOM-\u0434\u0435\u0440\u0435\u0432\u043e:<\/p>\n<pre><code class=\"typescript\">{   type: \"div\",   shapeFlag: 17, \u00a0\u00a0patchFlag: 0,   children: [     { shapeFlag: 9, patchFlag: -1, children: \u201cfoo\u201d, type: 'div' },     { shapeFlag: 9, patchFlag: -1, children: \u201cbar\u201d, type: 'div' }, \u00a0\u00a0\u00a0 { shapeFlag: 9, patchFlag: 1, children: \u201c1\u201d, type: 'div' },   ] }<\/code><\/pre>\n<p>\u0421\u0445\u0435\u043c\u0430\u0442\u0438\u0447\u043d\u043e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 vnode \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u043a\u0430\u043a \u0434\u0435\u0440\u0435\u0432\u043e component- \u0438 <a href=\"https:\/\/reactjs.org\/docs\/implementation-notes.html#mounting-host-elements\">host- \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432<\/a>, \u0433\u0434\u0435 host-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043a\u043e\u043d\u0435\u0447\u043d\u044b\u043c\u0438 \u0443\u0437\u043b\u0430\u043c\u0438 \u0434\u0435\u0440\u0435\u0432\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u0441\u0440\u0430\u0437\u0443 \u0436\u0435 \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0435\u043d\u044b:<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w780q1\/getpro\/habr\/upload_files\/0c6\/afe\/989\/0c6afe989c69aa433c6da3bb84eb01b6.jpeg\" alt=\"VDOM-\u0434\u0435\u0440\u0435\u0432\u043e \u0441 host-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438\" title=\"VDOM-\u0434\u0435\u0440\u0435\u0432\u043e \u0441 host-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438\" width=\"500\" height=\"481\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/0c6\/afe\/989\/0c6afe989c69aa433c6da3bb84eb01b6.jpeg\" data-blurred=\"true\"\/><figcaption>VDOM-\u0434\u0435\u0440\u0435\u0432\u043e \u0441 host-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438<\/figcaption><\/figure>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c \u043a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode div \u0441\u0440\u0430\u0437\u0443 \u0436\u0435 \u00ab\u0437\u0430\u043f\u0443\u043b\u044c\u043d\u0435\u0442\u0441\u044f\u00bb \u0432 DOM-\u0434\u0435\u0440\u0435\u0432\u043e. \u041e\u0434\u043d\u0430\u043a\u043e \u0436\u0435 \u043e\u0441\u0442\u0430\u043b\u0438\u0441\u044c \u0435\u0449\u0435 \u0438 \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0435 vnode-\u0443\u0437\u043b\u044b.<\/p>\n<p>\u041a\u0430\u043a \u0438\u0434\u0442\u0438 \u043f\u043e \u043d\u0438\u043c, \u0434\u0430 \u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u043f\u043e VDOM? \u041a\u043e\u043d\u0435\u0447\u043d\u043e \u0436\u0435 \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u043e (react >= 16 \u0437\u0430\u0433\u0440\u0443\u0441\u0442\u0438\u043b). \u041e\u0442\u0441\u0442\u0430\u0432\u0438\u043c \u0432 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 react-\u0444\u043b\u044d\u0448\u0431\u044d\u043a\u0438 \u0438 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u044d\u0442\u0430\u043f \u2014 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 VDOM.<\/p>\n<h3>\u0420\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 VDOM<\/h3>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w780q1\/getpro\/habr\/upload_files\/07f\/f35\/956\/07ff35956748eb40decd6f57c2a5073a.jpeg\" alt=\"\u0420\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u044b\u0439 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 VDOM\" title=\"\u0420\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u044b\u0439 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 VDOM\" width=\"500\" height=\"460\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/07f\/f35\/956\/07ff35956748eb40decd6f57c2a5073a.jpeg\" data-blurred=\"true\"\/><figcaption>\u0420\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u044b\u0439 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 VDOM<\/figcaption><\/figure>\n<p>\u0412\u044b\u0437\u043e\u0432 patch \u0441 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0439 vnode \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u0442 \u043a \u0432\u044b\u0437\u043e\u0432\u0443 processElement:<\/p>\n<pre><code class=\"typescript\">const setupRenderEffect: SetupRenderEffectFn = () => {   const subtree = {     type: \"div\",     shapeFlag: 17,     patchFlag: 0,     children: [       \/\/ ...     ]   }    patch(     null,     subtree   )    \/\/ ... }<\/code><\/pre>\n<p>\u041a\u0430\u043a \u043f\u043e\u043c\u043d\u0438\u043c, \u044d\u0442\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f processElement, \u043a\u0430\u043a \u0438 \u0434\u0440\u0443\u0433\u0438\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438-\u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438, \u043c\u043e\u0433\u043b\u0430 \u0431\u044b \u0432\u044b\u0437\u0432\u0430\u0442\u044c update-\u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0434\u043b\u044f \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0435\u0442\u0430 vnode-\u0443\u0437\u043b\u0430, \u043d\u043e \u043f\u043e\u043a\u0430 \u0447\u0442\u043e \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c \u043d\u0435\u0447\u0435\u0433\u043e, \u0430 \u043f\u043e\u044d\u0442\u043e\u043c\u0443 vnode \u0441\u043c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u0432\u044b\u0437\u043e\u0432 mountElement \u0432 processElement:<\/p>\n<pre><code class=\"typescript\">const mountElement = (     vnode: VNode,     container: RendererElement, ) => {     let el: RendererElement      el = vnode.el = hostCreateElement(       vnode.type,     )      if (shapeFlag &amp; ShapeFlags.TEXT_CHILDREN) {       hostSetElementText(el, vnode.children as string)     } else if (shapeFlag &amp; ShapeFlags.ARRAY_CHILDREN) {       mountChildren(         vnode.children as VNodeArrayChildren,         el,       )     }  }<\/code><\/pre>\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0439 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 DOM-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430, \u0442\u043e \u0435\u0441\u0442\u044c HTMLDivElement:<\/p>\n<pre><code class=\"typescript\">const mountElement = (     vnode: VNode, \/\/ { type: \"div\", children: [...] }     container: RendererElement, ) => {     let el: RendererElement      el = vnode.el = hostCreateElement(       vnode.type,     )      \/\/ ... }<\/code><\/pre>\n<p>\u0414\u0430\u043b\u0435\u0435\u00a0 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0438\u043c\u0435\u0435\u0442 \u043b\u0438 \u0442\u0435\u043a\u0443\u0449\u0430\u044f vnode \u00ab\u0434\u0435\u0442\u0435\u0439\u00bb (\u043e\u0445, \u0438 \u0442\u0443\u0442 \u044f \u043f\u043e\u043d\u044f\u043b \u043d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u0442\u0440\u0430\u043d\u043d\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0442\u044c \u044d\u0442\u043e \u0441\u043b\u043e\u0432\u043e \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0435), \u0438\u043b\u0438 \u044d\u0442\u043e \u043a\u043e\u043d\u0435\u0447\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u0439 host-\u044d\u043b\u0435\u043c\u0435\u043d\u0442, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c:<\/p>\n<pre><code class=\"typescript\">const mountElement = (     vnode: VNode,     container: RendererElement, ) => {     let el: RendererElement      \/\/ ...      if (shapeFlag &amp; ShapeFlags.TEXT_CHILDREN) {       hostSetElementText(el, vnode.children as string)     } else if (shapeFlag &amp; ShapeFlags.ARRAY_CHILDREN) {       mountChildren(         vnode.children as VNodeArrayChildren,         el,       )     }  }<\/code><\/pre>\n<p>\u0412 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0442\u0435\u043a\u0443\u0449\u0430\u044f \u043a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode (\u00abdiv\u00bb) \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u00ab\u043c\u043d\u043e\u0433\u043e\u0434\u0435\u0442\u043d\u043e\u0439\u00bb (\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0441\u0442\u0440\u0430\u043d\u043d\u0435\u0435 \u0447\u0435\u043c \u00ab\u0434\u0435\u0442\u0438\u00bb vnode-\u044b \u043d\u0438\u0447\u0435\u0433\u043e  \u0431\u044b\u0442\u044c \u043d\u0435 \u043c\u043e\u0436\u0435\u0442), \u0430 \u0437\u043d\u0430\u0447\u0438\u0442 \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f mountChildren:<\/p>\n<pre><code class=\"typescript\">mountChildren(   vnode.children,   el )<\/code><\/pre>\n<p>mountChildren \u043f\u043e \u0441\u0443\u0442\u0438 \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442 \u043f\u0440\u043e\u0445\u043e\u0434 \u043f\u043e \u0432\u0441\u0435\u0445 \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u043c vnode-\u0430\u043c, \u0432\u044b\u0437\u044b\u0432\u0430\u044f patch \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0437 \u043d\u0438\u0445:<\/p>\n<pre><code class=\"typescript\">const mountChildren: MountChildrenFn = (   children,   container, ) => {   for (let i = start; i &lt; children.length; i++) {     const child = children[i]      patch(       null,       child,       container,     )   } }<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u0443 \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0445 \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0431\u0443\u0434\u0443\u0442 \u0442\u0430\u043a\u0436\u0435 children, \u0442\u043e \u0438 \u0434\u043b\u044f \u043d\u0438\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u044f patch \u0432\u044b\u0437\u043e\u0432\u0435\u0442 mountChildren, \u043d\u043e \u0432 \u043a\u0430\u0447-\u0432\u0435 container \u0443\u0436\u0435 \u0431\u0443\u0434\u0435\u0442 \u0443\u043a\u0430\u0437\u0430\u043d \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0438 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u044d\u0442\u0438 children.<\/p>\n<p>\u0421\u0445\u0435\u043c\u0430\u0442\u0438\u0447\u043d\u043e \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0442\u0430\u043a:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/00f\/38b\/274\/00f38b27476fd1589d566a0b1b17209c.png\" alt=\"\u0420\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 \u043a\u0430\u0436\u0434\u043e\u0439 vnode\" title=\"\u0420\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 \u043a\u0430\u0436\u0434\u043e\u0439 vnode\" width=\"1340\" height=\"835\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/00f\/38b\/274\/00f38b27476fd1589d566a0b1b17209c.png\"\/><figcaption>\u0420\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 \u043a\u0430\u0436\u0434\u043e\u0439 vnode<\/figcaption><\/figure>\n<p>\u0420\u0435\u0437\u044e\u043c\u0438\u0440\u0443\u0435\u043c<strong>, vnode root div<\/strong> \u2014 \u043a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode (\u0432\u044b\u0434\u0435\u043b\u0435\u043d\u0430 \u043a\u0440\u0430\u0441\u043d\u044b\u043c), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 children, \u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0432 DOM, \u0430 \u0434\u0430\u043b\u0435\u0435 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f mountChildren, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u0438\u043c\u0435\u0442 vnode root div \u0432 \u043a\u0430\u0447-\u0432\u0435 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430 \u0434\u043b\u044f children.<\/p>\n<p>\u0412 \u0432\u044b\u0437\u043e\u0432 patch \u0431\u0443\u0434\u0443\u0442 \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u044b vnode \u0438\u0437 children \u0438 vnode root div \u0438 patch \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442 \u043a\u0430\u0436\u0434\u0443\u044e \u0434\u043e\u0447\u0435\u0440\u043d\u044e\u044e vnode \u0432 vnode root div.<\/p>\n<p>\u0422\u0430\u043a, \u0440\u0430\u0437 \u0437\u0430 \u0440\u0430\u0437\u043e\u043c, \u0438\u0437 \u043a\u0430\u0436\u0434\u043e\u0439 vnode \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0437\u0434\u0430\u043d \u0441\u0432\u043e\u0439 DOM-\u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u0438 \u0432\u0441\u0442\u0430\u0432\u043b\u0435\u043d \u0432 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0439 DOM-\u044d\u043b\u0435\u043c\u0435\u043d\u0442 (\u0432\u044b\u0434\u0435\u043b\u0435\u043d\u044b \u0436\u0438\u0440\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438).<\/p>\n<p>\u0421\u0442\u043e\u0438\u0442 \u0437\u0430\u043c\u0435\u0442\u0438\u0442\u044c, \u0447\u0442\u043e \u0437\u0434\u0435\u0441\u044c \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u0430\u043c\u0430\u044f \u0431\u0430\u0437\u043e\u0432\u0430\u044f \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 vnode, \u043a\u043e\u0433\u0434\u0430 vnode-\u044b \u0438\u0437 children \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0445\u043e\u0441\u0442-\u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438.<\/p>\n<p>\u0418\u0442\u0430\u043a, \u0442\u0435\u043f\u0435\u0440\u044c \u043c\u044b \u0437\u043d\u0430\u0435\u043c (\u0445\u043e\u0442\u044c \u0438 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u043d\u043e, \u043d\u043e \u0432\u0441\u0435 \u0436\u0435) \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u044d\u0442\u043e\u0442 \u00ab\u0447\u0435\u0440\u043d\u044b\u0439 \u044f\u0449\u0438\u043a\u00bb \u043f\u043e\u0434 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435\u043c \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 \u0432\u043e Vue. \u0412 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043c\u044b \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0435\u0442\u0430 VDOM \u0432\u043e Vue.<\/p>\n<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"v-portal\" style=\"display:none;\"><\/div>\n<\/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\/company\/nordclan\/blog\/699356\/\"> https:\/\/habr.com\/ru\/company\/nordclan\/blog\/699356\/<\/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>\u0414\u043e\u0431\u0440\u044b\u0439 \u0434\u0435\u043d\u044c! \u041c\u0435\u043d\u044f \u0437\u043e\u0432\u0443\u0442 \u0410\u043b\u0435\u043a\u0441\u0430\u043d\u0434\u0440, \u044f \u0440\u0430\u0431\u043e\u0442\u0430\u044e frontend-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u043c \u0432 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 Nord Clan. \u0412 <a href=\"https:\/\/habr.com\/ru\/company\/nordclan\/blog\/690522\/\">\u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435<\/a> \u043c\u044b \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043b\u0438 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 Vue, \u0430 \u0442\u0435\u043f\u0435\u0440\u044c \u043d\u0430\u0434\u043e \u043a\u0430\u043a-\u0442\u043e \u00ab\u043f\u0440\u0438\u0441\u0442\u0440\u043e\u0438\u0442\u044c\u00bb \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u044d\u0442\u043e\u0439 \u0441\u0430\u043c\u043e\u0439 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430. \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0434\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u043c \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u043f\u0430\u043a\u0435\u0442\u044b:<\/p>\n<figure class=\"full-width\"><figcaption>\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0445 \u043f\u0430\u043a\u0435\u0442\u043e\u0432 Vue<\/figcaption><\/figure>\n<p>\u0412 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430 \u0431\u0443\u0434\u0443\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043f\u0430\u043a\u0435\u0442\u044b <strong>runtime-dom<\/strong> \u0438 <strong>runtime-core<\/strong>. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c, runtime-dom \u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u0440\u0430\u0449\u0430\u0442\u044c\u0441\u044f \u043a \u0441\u0432\u043e\u0435\u043c\u0443 \u0441\u0442\u0430\u0440\u0448\u0435\u043c\u0443 \u0431\u0440\u0430\u0442\u0443 runtime-core, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u043e\u043b\u0435\u0435 \u043c\u0443\u0434\u0440\u044b\u0439 \u0438 \u0437\u043d\u0430\u0435\u0442 \u043a\u0430\u043a, \u043a\u043e\u0433\u0434\u0430, \u0438 \u0433\u0434\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c api \u0438\u0437 runtime-dom.<\/p>\n<p>\u041d\u0430\u0447\u043d\u0435\u043c \u043a\u0430\u043a \u043e\u0431\u044b\u0447\u043d\u043e \u0438\u0437\u0434\u0430\u043b\u0435\u043a\u0430, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0431\u0443\u0434\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043d\u0430\u0431\u0440\u043e\u0441\u043a\u0438 \u0441\u0445\u0435\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430, \u0430 \u0434\u0430\u043b\u0435\u0435 \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u0442\u044c\u0441\u044f \u0432 \u043d\u0438\u0445.<\/p>\n<p>\u0421\u0442\u0440\u0435\u043b\u043a\u0438 \u0432 \u044d\u0442\u0438\u0445 \u0441\u0445\u0435\u043c\u0430\u0445 \u0431\u0443\u0434\u0443\u0442 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u043d\u0430 \u0432\u044b\u0437\u043e\u0432\u044b \u0434\u0440\u0443\u0433\u0438\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u0430 \u043f\u0443\u043d\u043a\u0442\u0438\u0440\u043d\u044b\u0435 \u043b\u0438\u043d\u0438\u0438 \u043d\u0430 \u043a\u043e\u0434, \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u043c\u044b\u0439 \u0432\u043d\u0443\u0442\u0440\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u0439. \u0421\u043a\u0430\u0436\u0435\u043c \u0442\u0430\u043a, \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u0434\u0436\u0443\u043c\u0430\u043d\u0434\u0436\u0438 \u0432 \u043c\u0438\u0440\u0430 \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434\u0430, \u0438 \u0434\u0436\u0443\u043d\u0433\u043b\u0438 \u043a\u043e\u0434\u0430 \u0431\u0443\u0434\u0443\u0442 \u0432\u0441\u0435 \u0433\u0443\u0449\u0435 \u0438 \u0433\u0443\u0449\u0435&#8230;<\/p>\n<h3>\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430<\/h3>\n<p>\u0412\u043e\u0437\u044c\u043c\u0435\u043c \u043c\u043e\u0449\u043d\u044b\u0439 \u043c\u0438\u043a\u0440\u043e\u0441\u043a\u043e\u043f \u0438 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0442\u043e, \u043a\u0430\u043a \u044d\u0442\u0438 \u043f\u0430\u043a\u0435\u0442\u044b (runtime-dom \u0438 runtime-core) \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0443\u044e\u0442 \u043c\u0435\u0436\u0434\u0443 \u0441\u043e\u0431\u043e\u0439 \u0441 \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043f\u043e\u0448\u0430\u0433\u043e\u0432\u044b\u043c \u0438 \u0434\u0435\u0442\u0430\u043b\u044c\u043d\u044b\u043c \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435\u043c \u0434\u0430\u043d\u043d\u043e\u0439 \u0441\u0445\u0435\u043c\u044b:<\/p>\n<figure class=\"full-width\"><figcaption>\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430<\/figcaption><\/figure>\n<p>\u041f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0438\u0437 app (\u0431\u0435\u0440\u0435\u043c \u043b\u044e\u0431\u043e\u0435 Vue-\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435) \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u044e createApp(), \u0438 \u043f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c \u0434\u0430\u043d\u043d\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 ensureRenderer:<\/p>\n<pre><code class=\"typescript\">export const createApp = (...args) => {   const app = ensureRenderer(); }<\/code><\/pre>\n<p>ensureRenderer \u043b\u0438\u0431\u043e \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u043d\u043e\u0432\u044b\u0439 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430, \u043b\u0438\u0431\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0443\u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0439:<\/p>\n<pre><code class=\"typescript\">function ensureRenderer() {   return (     renderer ||     (renderer = createRenderer(rendererOptions))   ) }<\/code><\/pre>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u044f createrRenderer \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0438\u0437 \u043f\u0430\u043a\u0435\u0442\u0430 runtime-core \u0438 \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442 \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430 \u043e\u0431\u044a\u0435\u043a\u0442 \u0441 \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 DOM (rendererOptions), \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0443\u0434\u0443\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u044b\u0445 \u043d\u043e\u0434 \u0432\u043d\u0443\u0442\u0440\u0438 runtime-core.<\/p>\n<p>\u0417\u0430\u043c\u0435\u0442\u0438\u043c, \u0447\u0442\u043e renderer \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u043d\u0435 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d, \u0442\u0430\u043a \u043a\u0430\u043a \u0442\u0438\u043f renderer \u043c\u043e\u0436\u0435\u0442 \u043e\u0442\u043b\u0438\u0447\u0430\u0442\u044c\u0441\u044f \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 \u0441\u0440\u0435\u0434 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043a\u043e\u0434\u0430:<\/p>\n<pre><code class=\"typescript\">let renderer: Renderer&lt;Element | ShadowRoot> | HydrationRenderer<\/code><\/pre>\n<p>\u0412 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f createRenderer, \u0442\u0430\u043a \u043a\u0430\u043a \u043f\u043e\u043a\u0430 \u0447\u0442\u043e \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e renderer \u0441\u043e\u0437\u0434\u0430\u043d\u043e \u043d\u0435 \u0431\u044b\u043b\u043e:<\/p>\n<pre><code class=\"typescript\">(renderer = createRenderer(rendererOptions))<\/code><\/pre>\n<p>\u042d\u0442\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u0432 \u0441\u0432\u043e\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c \u0432\u044b\u0437\u043e\u0432\u0435\u0442 baseCreateRenderer \u0438\u0437 \u043f\u0430\u043a\u0435\u0442\u0430 runtime-core, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0442\u0432\u0435\u0447\u0430\u0435\u0442 \u0437\u0430 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043d\u043e\u0432\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430.<\/p>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u0438 patch, render, mount \u0438 \u0442.\u0434. \u0431\u0443\u0434\u0443\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u044b\u0435 \u0438\u0437 runtime-dom \u043c\u0435\u0442\u043e\u0434\u044b (hostInsert, hostRemove \u0438 \u0442.\u0434):<\/p>\n<pre><code class=\"typescript\">function baseCreateRenderer(   options: RendererOptions, ) {   const {     insert: hostInsert,     remove: hostRemove,     createElement: hostCreateElement,     createText: hostCreateText,     \/\/ ...   } = options    const patch = () => {     \/\/ ...   }    const render = () => {     \/\/ ...   }    const mount = () => {     \/\/ ...   }    \/\/ ... }<\/code><\/pre>\n<p>\u041a\u043e\u043d\u0435\u0447\u043d\u043e \u00ab\u043f\u043e\u0440\u0442\u044f\u043d\u043a\u0430\u00bb \u043a\u043e\u0434\u0430 \u0432 \u044d\u0442\u043e\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u0431\u043e\u043b\u044c\u0448\u0435, \u043d\u043e \u043c\u043d\u0435 \u043d\u0435 \u043e\u0445\u043e\u0442\u0430 \u043f\u0443\u0433\u0430\u0442\u044c \u0432\u0430\u0441 \u0442\u0430\u043a \u0436\u0435, \u043a\u0430\u043a \u0438\u0441\u043f\u0443\u0433\u0430\u043b\u0441\u044f \u044f \u043f\u0440\u0438 \u0435\u0435 \u0432\u0438\u0434\u0435. \u041e\u0434\u043d\u0430\u043a\u043e \u0436\u0435, \u0438\u043c\u0435\u043d\u043d\u043e \u044d\u0442\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 <s>\u043e\u0431\u0443\u0447\u0438\u0442\u0441\u044f \u0448\u0430\u0431\u043b\u043e\u043d\u0430\u043c \u0440\u0435\u0444\u0430\u043a\u0442\u043e\u0440\u0438\u043d\u0433\u0430<\/s> \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0441\u0442\u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433.<\/p>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u044f baseCreateRenderer \u0432\u043e\u0437\u0432\u0440\u0430\u0442\u0438\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u0443\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e render, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u044e createAppAPI:<\/p>\n<pre><code class=\"typescript\">function baseCreateRenderer(   options: RendererOptions, ) {   \/\/ ...     return {     render,     createApp: createAppAPI(render)   } }<\/code><\/pre>\n<p>createAppAPI \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u044e, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438 \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u0438\u0442 \u043c\u0435\u0442\u043e\u0434\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0432 app, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, createApp().mount() \u0438\u043b\u0438 createApp().unmount():<\/p>\n<pre><code class=\"typescript\">export function createAppAPI&lt;HostElement>(   render: RootRenderFunction, ): CreateAppFunction&lt;HostElement> {   return function createApp(rootComponent) {     const app = {       mount() {         \/\/ ...       },       unmount() {         \/\/ ...       },     }      return app   } }<\/code><\/pre>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043a\u0430\u043a \u0440\u0430\u0437 \u0432\u044b\u0437\u043e\u0432\u0435\u0442 createApp, \u0430 \u0434\u0430\u043b\u0435\u0435 \u0441 \u0440\u0430\u0434\u043e\u0441\u0442\u044c\u044e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u043c\u0435\u0442\u043e\u0434 mount, \u0434\u0430\u0436\u0435 \u043d\u0435 \u043f\u043e\u0434\u043e\u0437\u0440\u0435\u0432\u0430\u044f \u043e \u0442\u0435\u0445 \u0441\u0442\u0440\u0430\u0448\u043d\u044b\u0445 \u0432\u0435\u0449\u0430\u0445, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0443\u0442 \u0432 \u00ab\u0447\u0435\u0440\u043d\u043e\u043c-\u0447\u0435\u0440\u043d\u043e\u043c \u044f\u0449\u0438\u043a\u0435\u00bb&#8230;<\/p>\n<p>\u0412\u043e\u0437\u044c\u043c\u0435\u043c \u0441\u0442\u0430\u0440\u044b\u0439 \u043f\u0440\u0438\u043c\u0435\u0440 \u0438\u0437 \u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438. \u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 rootComponent \u043f\u0435\u0440\u0435\u0434\u0430\u0434\u0438\u043c \u043b\u0438\u0442\u0435\u0440\u0430\u043b \u043e\u0431\u044a\u0435\u043a\u0442\u0430, \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0449\u0438\u0439 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u0438 \u043c\u0435\u0442\u043e\u0434\u044b \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0433\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430:<\/p>\n<pre><code class=\"typescript\">Vue   .createApp({     data: () => ({       dynamic: 1     }),     template: `       &lt;div>         &lt;div>foo&lt;\/div>         &lt;div>bar&lt;\/div>         &lt;div>{{ dynamic }}&lt;\/div>       &lt;\/div>     `,   })   .mount('#app')<\/code><\/pre>\n<p>\u0412\u0435\u0440\u043d\u0435\u043c\u0441\u044f \u043a \u0444\u0443\u043d\u043a\u0446\u0438\u0438 createApp. \u041a\u0430\u043a \u0440\u0430\u0437 \u043e\u043d\u0430 \u0438 \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 Vue.createApp, \u0430 \u0440\u0430\u043d\u0435\u0435 baseCreaterenderer (\u043f\u043e\u043c\u043d\u0438\u043c, \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f \u0432 ensureRenderer) \u0443\u0436\u0435 \u043b\u044e\u0431\u0435\u0437\u043d\u043e \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u0438\u043b \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0447\u0435\u0440\u0435\u0437 \u0432\u044b\u0437\u043e\u0432 createApp:<\/p>\n<pre><code class=\"typescript\">export const createApp = (...args) => {   const app = ensureRenderer().createApp(); }<\/code><\/pre>\n<p>\u0418\u0442\u0430\u043a, \u043f\u0435\u0440\u0432\u044b\u0439 \u044d\u0442\u0430\u043f \u043f\u0440\u043e\u0439\u0434\u0435\u043d, \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0441\u043e\u0437\u0434\u0430\u043d, \u043f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u043a \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c\u0443 \u044d\u0442\u0430\u043f\u0443 &#8212; \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e, <s>\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e \u0432\u0438\u0434\u0435\u043e\u043a\u0443\u0440\u0441\u0430<\/s> <s>\u043f\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044e \u0441\u0432\u043e\u0435\u0439 \u0440\u0435\u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438<\/s>.<\/p>\n<h3>\u041a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u0448\u0430\u0431\u043b\u043e\u043d\u0430, \u043a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode (\u0438\u043b\u0438 initialVNode) \u0438 patch-\u0444\u0443\u043d\u043a\u0446\u0438\u044f<\/h3>\n<figure class=\"full-width\"><figcaption>\u041c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430<\/figcaption><\/figure>\n<p>app.createApp() \u0443\u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u043b\u0430 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0438 \u0438\u043c\u0435\u0435\u0442 \u0432\u0441\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u043c\u0435\u0442\u043e\u0434\u044b \u0434\u043b\u044f \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0435\u043d\u0438\u044f \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e \u043c\u0435\u0442\u043e\u0434 mount, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0443\u0434\u0435\u0442 \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0438\u0441\u0430\u043d \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 runtime-dom:<\/p>\n<pre><code class=\"typescript\">export const createApp = (...args) => {   const app = ensureRenderer().createApp();    const { mount } = app    app.mount = (containerOrSelector: Element | ShadowRoot | string) => {     \/\/ \u0417\u0434\u0435\u0441\u044c \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 containerOrSelector \u043d\u0430 \u0432\u0430\u043b\u0438\u0434\u043d\u043e\u0441\u0442\u044c      const proxy = mount(containerOrSelector)      return proxy   } }<\/code><\/pre>\n<p>\u041c\u0435\u0442\u043e\u0434 mount \u0432\u044b\u0437\u043e\u0432\u0435\u0442 \u043a\u0430\u043a \u0440\u0430\u0437 \u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 \u043c\u0435\u0442\u043e\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0437\u0434\u0430\u043b createApp, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0438\u0437 baseCreateRenderer, \u043f\u0435\u0440\u0435\u0434\u0430\u0432 \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430 \u0441\u0435\u043b\u0435\u043a\u0442\u043e\u0440 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430 \u0438\u043b\u0438 \u0441\u0430\u043c \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440, \u043a\u0443\u0434\u0430 \u0431\u0443\u0434\u0435\u0442 \u0441\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043e Vue-\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435.<\/p>\n<p>\u041f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u0432 \u043c\u0435\u0442\u043e\u0434\u0443 mount, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b\u0441\u044f \u0432 createAppAPI. \u041c\u0435\u0442\u043e\u0434 mount \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u043a\u043e\u0440\u043d\u0435\u0432\u0443\u044e vnode \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u043e\u0433\u043e template, data \u0438 \u0442.\u0434.:<\/p>\n<pre><code class=\"typescript\">export function createAppAPI(   render: RootRenderFunction, ): CreateAppFunction {   return function createApp(rootComponent, rootProps = null) {      \/\/ ...      const app = {       mount(rootContainer) {         \/\/ \u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0439 vnode (initialVNode)         const vnode = createVNode(rootComponent)          render(vnode, rootContainer)       },     }      return app   } }<\/code><\/pre>\n<p>\u041a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a:<\/p>\n<pre><code class=\"typescript\">const vnode = {   dynamicChildren: null,   dynamicProps: null,   patchFlag: 0,   shapeFlag: 4,   data: () => ({ dynamic: 1 }),   template: `           \\n&lt;div>\\n               &lt;div>foo&lt;\/div>\\n       &lt;div>bar&lt;\/div>\\n               &lt;div>{{ dynamic }}&lt;\/div>\\n           &lt;\/div>\\n ` }<\/code><\/pre>\n<p>shapeFlag \u0441\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c \u00ab4\u00bb \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442 STATEFUL_COMPONENT. patchFlag \u0431\u0443\u0434\u0435\u0442 \u0442\u0430\u043a\u0436\u0435 \u043d\u0443\u0436\u0435\u043d \u0432 \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u043c \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0435\u0442\u0430. \u041f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u0434\u043b\u044f shapeFlag \u0438 patchFlag \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u044b \u0447\u0435\u0440\u0435\u0437 <a href=\"https:\/\/learn.javascript.ru\/bitwise-operators\"><u>\u043f\u043e\u0431\u0438\u0442\u043e\u0432\u0443\u044e \u043c\u0430\u0441\u043a\u0443<\/u><\/a> \u0434\u043b\u044f \u0443\u0434\u043e\u0431\u0441\u0442\u0432\u0430, \u043a\u0445\u043c, \u043f\u0440\u043e\u0441\u0442\u0438\u0442\u0435, \u043f\u0440\u043e\u0432\u0435\u0440\u043e\u043a \u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438.<\/p>\n<p>\u0412\u0435\u0440\u043d\u0435\u043c\u0441\u044f \u043a \u043c\u0435\u0442\u043e\u0434\u0443 mount, \u043f\u043e\u0434\u0441\u0442\u0430\u0432\u0438\u043c \u0441\u044e\u0434\u0430 \u044d\u0442\u0443 \u0441\u0430\u043c\u0443\u044e \u043a\u043e\u0440\u043d\u0435\u0432\u0443\u044e vnode:<\/p>\n<pre><code class=\"typescript\">mount(rootContainer) {   const vnode = {     dynamicChildren: null,     dynamicProps: null,     patchFlag: 0,     shapeFlag: 4,     data: () => ({ dynamic: 1 }),     template: `             \\n&lt;div>\\n                 &lt;div>foo&lt;\/div>\\n         &lt;div>bar&lt;\/div>\\n                 &lt;div>{{ dynamic }}&lt;\/div>\\n             &lt;\/div>\\n `   }    render(vnode, rootContainer) }<\/code><\/pre>\n<p>\u0424\u0443\u043d\u043a\u0446\u0438\u044f render, \u043a\u0430\u043a \u043f\u043e\u043c\u043d\u0438\u043c, \u0431\u044b\u043b\u0430 \u043e\u0431\u044a\u044f\u0432\u043b\u0435\u043d\u0430 \u0432 baseCreateRenderer. \u041e\u043d\u0430 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u00ab\u043f\u0430\u0442\u0447\u0438\u043d\u0433\u0430\u00bb \u043d\u043e\u0432\u043e\u0439 vnode \u0432 container (#app):<\/p>\n<pre><code class=\"typescript\">function baseCreateRenderer(   options: RendererOptions, ) {   const patch = () => {     \/\/ ...   }    const render = () => {     patch(container._vnode || null, vnode, container)   } }<\/code><\/pre>\n<p>\u041f\u043e\u0436\u0430\u043b\u0443\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u044f patch \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u043e\u0439 \u0438\u0437 \u0441\u0430\u043c\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0432\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, big boss \u0432 \u0441\u0432\u043e\u0435\u043c \u043f\u0430\u043a\u0435\u0442\u0435.<\/p>\n<p>\u042d\u0442\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u00ab\u043f\u0440\u043e\u043a\u0441\u0438\u0440\u0443\u0435\u0442\u00bb \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0442\u043e\u0439 \u0438\u043b\u0438 \u0438\u043d\u043e\u0439 vnode \u043d\u0443\u0436\u043d\u043e\u043c\u0443 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0443 (\u043f\u0430\u0440\u0434\u043e\u043d \u0437\u0430 \u0442\u0430\u0432\u0442\u043e\u043b\u043e\u0433\u0438\u044e), \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u044f \u0442\u0438\u043f vnode \u043f\u043e shapeFlag, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0442\u0438\u043f \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u043f\u043e patchFlag.<\/p>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c \u043e\u043d\u0430 \u043e\u0442\u0432\u0435\u0447\u0430\u0435\u0442 \u0437\u0430 \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0442\u0435\u043c, \u043a\u0430\u043a \u0442\u043e\u0442 \u0438\u043b\u0438 \u0443\u0437\u0435\u043b VDOM \u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u043d \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u043e\u0431\u0445\u043e\u0434\u0430 VDOM-\u0434\u0435\u0440\u0435\u0432\u0430:<\/p>\n<pre><code class=\"typescript\">const patch: PatchFn = (     n1,     n2,     container, ) => {     if (n1 === n2) {       \/\/ \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u043c\u0430\u044f \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u0430\u044f \u043d\u043e\u0434\u0430 n1 \u0438\u0434\u0435\u043d\u0442\u0438\u0447\u043d\u0430 \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u043e\u0439 \u043d\u043e\u0434\u0435 n2       \/\/ \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u0434\u0435\u043b\u0430\u0442\u044c     }      if (n1 &amp;&amp; !isSameVNodeType(n1, n2)) {       \/\/ \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u043c\u0430\u044f \u0432\u043d\u043e\u0434\u0430 n1 \u043d\u0435 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u0438\u043c \u0438 \u0442\u0435\u043c \u0442\u0438\u043f\u043e\u043c \u0441 n2       \/\/ \u0440\u0430\u0437\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432\u0435\u0441\u044c n1, \u0447\u0442\u043e\u0431\u044b \u0441\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u043d\u043e\u0432\u043e \u0431\u0435\u0437 \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0435\u0442\u0430     }      const { type, ref, shapeFlag } = n2      switch (type) {       default:         if (shapeFlag &amp; ShapeFlags.ELEMENT) {           \/\/ \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c n1 \u0432 n2 \u043a\u0430\u043a \u0435\u043b\u0435\u043c\u0435\u043d\u0442         } else if (shapeFlag &amp; ShapeFlags.COMPONENT) {           \/\/ \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c n1 \u0432 n2 \u043a\u0430\u043a \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442         }     } }<\/code><\/pre>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u043e\u043a \u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432 \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u0431\u043e\u043b\u044c\u0448\u0435, \u043d\u043e \u043b\u0443\u0447\u0448\u0435 \u0441\u0444\u043e\u043a\u0443\u0441\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u043c.<\/p>\n<p>\u041a\u0430\u043a \u043f\u043e\u043c\u043d\u0438\u043c, \u043d\u0430\u0448\u0430 \u043a\u043e\u0440\u043d\u0435\u0432\u0430\u044f vnode \u0438\u043c\u0435\u0435\u0442 shapeFlag \u0440\u0430\u0432\u043d\u044b\u0439 STATEFUL_COMPONENT, \u0430 \u0437\u043d\u0430\u0447\u0438\u0442 \u043f\u043e\u0440\u0430 \u0432\u044b\u0445\u043e\u0434\u0438\u0442\u044c \u043d\u0430 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0435 processComponent:<\/p>\n<pre><code class=\"typescript\">const patch: PatchFn = (     n1,     n2,     container,   ) => {     \/\/ ...      const { type, ref, shapeFlag } = n2      switch (type) {       \/\/ ...        default:         \/\/ ...          if (shapeFlag &amp; ShapeFlags.COMPONENT) {           processComponent(n1, n2, container)         }     } }<\/code><\/pre>\n<p>\u041b\u043e\u0433\u0438\u043a\u0430 \u0440\u0430\u0431\u043e\u0442\u044b \u0444\u0443\u043d\u043a\u0446\u0438\u0439-\u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432 \u043d\u0443\u0436\u043d\u043e\u0433\u043e \u0442\u0438\u043f\u0430 vnode \u0441\u0445\u043e\u0436\u0430 \u043c\u0435\u0436\u0434\u0443 \u0441\u043e\u0431\u043e\u0439, \u0431\u0443\u0434\u044c \u0442\u043e processComponent, processText, processElement \u0438 \u0442.\u0434. \u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u043d\u0430\u043b\u0438\u0447\u0438\u0435 n1 (\u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u0430\u044f vnode), \u0438 \u0435\u0441\u043b\u0438 \u043e\u043d\u0430 \u0435\u0441\u0442\u044c, \u0442\u043e \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043f\u0435\u0440\u0435\u0440\u0430\u0441\u0447\u0435\u0442\u0430, \u0430 \u0435\u0441\u043b\u0438 \u043d\u0435\u0442 \u2014 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f.<\/p>\n<p>\u0412 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u043e\u0435 \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u044b\u0437\u043e\u0432\u0435\u0442\u0441\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f mountComponent:<\/p>\n<pre><code class=\"typescript\">const processComponent = (     n1: VNode | null,     n2: VNode,     container: RendererElement, ) => {      \/\/ n1 \u0440\u0430\u0432\u043d\u044f\u0435\u0442\u0441\u044f null, \u0437\u043d\u0430\u0447\u0438\u0442 \u043c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442      if (n1 == null) {       mountComponent(         n2,         container,       )     } else {       updateComponent(n1, n2)     } }<\/code><\/pre>\n<p>\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u044f mountComponent? \u041e\u043d\u0430 \u0443\u0436\u0435 \u0431\u044b\u043b\u0430 \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u0430 \u0432 <a href=\"https:\/\/habr.com\/ru\/company\/nordclan\/blog\/690522\/\"><u>\u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0435<\/u><\/a> \u043f\u0440\u043e \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044e \u0432 Vue, \u0433\u0434\u0435 \u044d\u0442\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u043e\u043c\u043e\u0433\u0430\u0435\u0442 \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0441\u0442\u0438 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044e \u0448\u0430\u0431\u043b\u043e\u043d\u0430 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 \u0432 runtime, \u0430 \u043f\u043e\u0442\u043e\u043c \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438, \u043e\u0441\u0432\u0435\u0436\u0438\u043c \u043f\u0430\u043c\u044f\u0442\u044c:<\/p>\n<pre><code class=\"typescript\">const mountComponent: MountComponentFn = (   initialVNode,   container, ) => {   const instance: ComponentInternalInstance = (     initialVNode.component = createComponentInstance(initialVNode)       )      \/\/ \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u0438 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0435\u0442 \u0437\u0434\u0435\u0441\u044c   setupComponent(instance)     \/\/ \u0430 \u0437\u0434\u0435\u0441\u044c \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0435\u0442 \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433   setupRenderEffect(     instance,     container,   ) }<\/code><\/pre>\n<p>createComponentInstance<\/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-341432","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/341432","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=341432"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/341432\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=341432"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=341432"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=341432"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}