{"id":6571,"date":"2022-07-20T15:47:24","date_gmt":"2022-07-20T07:47:24","guid":{"rendered":"http:\/\/123.57.164.21\/?p=6571"},"modified":"2022-07-20T16:36:49","modified_gmt":"2022-07-20T08:36:49","slug":"js-%e8%99%9a%e6%8b%9fdom","status":"publish","type":"post","link":"https:\/\/92it.top\/?p=6571","title":{"rendered":"JS \u865a\u62dfdom"},"content":{"rendered":"\n<p><strong>1\u3001\u4ec0\u4e48\u662f\u865a\u62df DOM \uff08vdom\uff09<\/strong><\/p>\n\n\n\n<hr class=\"wp-block-separator\"\/>\n\n\n\n<ul><li><strong>\u8d77\u6e90<\/strong><\/li><\/ul>\n\n\n\n<p>\u865a\u62dfdom\u6700\u5148\u662f\u7531<strong>facebook\u56e2\u961f<\/strong>\u63d0\u51fa\u7684\uff0c\u6700\u5148\u8fd0\u7528\u5728<a rel=\"noreferrer noopener\" href=\"https:\/\/so.csdn.net\/so\/search?q=react&amp;spm=1001.2101.3001.7020\" target=\"_blank\">react<\/a>\u4e2d\uff0c\u4e4b\u540e\u5728vue2.0\u7248\u672c\u4e2d\u5f15\u5165\u4e86\u865a\u62dfDOM\u7684\u6982\u5ff5<\/p>\n\n\n\n<ul><li><strong>\u662f\u4ec0\u4e48<\/strong><\/li><\/ul>\n\n\n\n<p><strong>\u865a\u62df dom \u662f\u76f8\u5bf9\u4e8e\u6d4f\u89c8\u5668\u6240\u6e32\u67d3\u51fa\u6765\u7684\u771f\u5b9e dom \u7684\uff0c<\/strong><\/p>\n\n\n\n<p>\u4ee5\u5f80\uff0c\u6211\u4eec\u6539\u53d8\u66f4\u65b0\u9875\u9762\uff0c\u53ea\u80fd\u901a\u8fc7\u9996\u5148\u67e5\u627edom\u5bf9\u8c61\uff0c\u518d\u8fdb\u884c\u4fee\u6539dom\u7684\u65b9\u5f0f\u6765\u8fbe\u5230\u76ee\u7684\u3002 \u4f46<strong>\u8fd9\u79cd\u65b9\u5f0f\u76f8\u5f53\u6d88\u8017\u8ba1\u7b97\u8d44\u6e90\uff0c<\/strong> <code>\u56e0\u4e3a\u6bcf\u6b21\u67e5\u8be2 dom \uff0c\u90fd\u9700\u8981\u904d\u5386\u6574\u9897 dom \u6811\u3002<\/code><\/p>\n\n\n\n<p>\u73b0\u5728\uff0c\u6211\u4eec\u7528\u5bf9\u8c61\u7684\u65b9\u5f0f\u6765\u63cf\u8ff0\u771f\u5b9e\u7684 dom\uff0c\u5e76\u4e14\u901a\u8fc7\u5bf9\u8c61\u4e0e\u771f\u5b9edom\u5efa\u7acb\u4e86\u4e00\u4e00\u5bf9\u5e94\u7684\u5173\u7cfb\uff0c\u90a3\u4e48\u6bcf\u6b21 dom \u7684\u66f4\u6539\uff0c\u6211\u901a\u8fc7\u627e\u5230\u76f8\u5e94\u5bf9\u8c61\uff0c\u4e5f\u5c31\u627e\u5230\u4e86\u76f8\u5e94\u7684dom\u8282\u70b9\uff0c\u518d\u5bf9\u5176\u8fdb\u884c\u66f4\u65b0\u3002\u8fd9\u6837\u7684\u8bdd\uff0c\u5c31\u80fd\u8282\u7701\u6027\u80fd\uff0c\u56e0\u4e3a<strong>js \u5bf9\u8c61\u7684\u67e5\u8be2\uff0c\u6bd4\u5bf9\u6574\u4e2adom \u6811\u7684\u67e5\u8be2\uff0c\u6240\u6d88\u8017\u7684\u6027\u80fd\u8981\u5c11\u3002<\/strong><\/p>\n\n\n\n<ul><li><strong>\u672c\u8d28<\/strong><\/li><\/ul>\n\n\n\n<p>Vnode\u7684\u672c\u8d28\u5c31\u662f\u7528\u6811\u578b\u7ed3\u6784\u7684JS\u5bf9\u8c61\u6765\u63cf\u8ff0\u771f\u5b9e\u7684DOM\u7ed3\u6784\u7684\u4fe1\u606f\uff0c\u8fd9\u4e2a\u6811\u7ed3\u6784\u7684JS\u5bf9\u8c61\u5305\u542b\u4e86\u6574\u4e2aDOM\u7ed3\u6784\u7684\u4fe1\u606f.\u3002<\/p>\n\n\n\n<div class=\"wp-block-image\"><figure class=\"aligncenter size-full is-resized\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/123.57.164.21\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-220.png\" alt=\"\" class=\"wp-image-6572\" width=\"459\" height=\"256\" srcset=\"https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-220.png 892w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-220-300x168.png 300w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-220-768x430.png 768w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-220-830x465.png 830w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-220-230x129.png 230w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-220-350x196.png 350w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-220-480x269.png 480w\" sizes=\"(max-width: 459px) 100vw, 459px\" \/><\/figure><\/div>\n\n\n\n<p>\u53ef\u89c1\u5de6\u8fb9\u7684DOM\u7ed3\u6784\uff0c\u4e0d\u8bba\u662f\u6807\u7b7e\u540d\u79f0\u8fd8\u662f\u6807\u7b7e\u7684\u5c5e\u6027\u6216\u6807\u7b7e\u7684\u5b50\u96c6\uff0c\u90fd\u4f1a\u5bf9\u5e94\u5728\u53f3\u8fb9\u7684\u6811\u7ed3\u6784\u91cc\u3002<\/p>\n\n\n\n<p><strong>2\u3001\u865a\u62df DOM \u7684\u4f18\u7f3a\u70b9<\/strong><\/p>\n\n\n\n<hr class=\"wp-block-separator\"\/>\n\n\n\n<p><strong>\u4f18\u70b9\uff1a<\/strong><\/p>\n\n\n\n<ul><li><code>\u964d\u4f4e\u6d4f\u89c8\u5668\u6027\u80fd\u6d88\u8017<\/code><\/li><\/ul>\n\n\n\n<p>\u56e0\u4e3a<strong>Javascript\u7684\u8fd0\u7b97\u901f\u5ea6\u8fdc\u5927\u4e8eDOM\u64cd\u4f5c\u7684\u6267\u884c\u901f\u5ea6<\/strong>\uff0c\u56e0\u6b64\uff0c\u8fd0\u7528patching\u7b97\u6cd5\u6765\u8ba1\u7b97\u51fa\u771f\u6b63\u9700\u8981\u66f4\u65b0\u7684\u8282\u70b9\uff0c\u6700\u5927\u9650\u5ea6\u5730\u51cf\u5c11DOM\u64cd\u4f5c\uff0c\u4ece\u800c\u63d0\u9ad8\u6027\u80fd\u3002<\/p>\n\n\n\n<p>\u5728vnode\u6280\u672f\u51fa\u73b0\u4e4b\u524d\uff0c\u6211\u4eec\u8981\u6539\u53d8\u9875\u9762\u5c55\u793a\u7684\u5185\u5bb9\u53ea\u80fd\u901a\u8fc7\u904d\u5386\u67e5\u8be2 dom \u6811\u7684\u65b9\u5f0f\u627e\u5230\u9700\u8981\u4fee\u6539\u7684 dom\uff0c\u7136\u540e\u4fee\u6539\u6837\u5f0f\u884c\u4e3a\u6216\u8005\u7ed3\u6784\uff0c\u6765\u8fbe\u5230\u66f4\u65b0 ui \u7684\u76ee\u7684\u3002\u8fd9\u79cd\u65b9\u5f0f\u76f8\u5f53\u6d88\u8017\u8ba1\u7b97\u8d44\u6e90\uff0c\u56e0\u4e3a\u6bcf\u6b21\u67e5\u8be2 dom \u51e0\u4e4e\u90fd\u9700\u8981\u904d\u5386\u6574\u9897 dom\u6811\u3002<\/p>\n\n\n\n<p>\u5728vnode\u6280\u672f\u51fa\u73b0\u4e4b\u540e\uff0c\u6211\u4eec\u5efa\u7acb\u4e00\u4e2a\u865a\u62df dom \u5bf9\u8c61\u6765\u5bf9\u5e94\u771f\u5b9e\u7684 dom \u6811\uff0c\u90a3\u4e48\u6bcf\u6b21 dom \u7684\u66f4\u6539\u5c31\u53d8\u6210\u4e86 js \u5bf9\u8c61\u7684\u5c5e\u6027\u7684\u66f4\u6539 \uff0c\u8fd9\u6837\u4e00\u6765\u5c31\u80fd\u67e5\u627e js \u5bf9\u8c61\u7684\u5c5e\u6027\u53d8\u5316\u8981\u6bd4\u67e5\u8be2 dom \u6811\u7684 \u6027\u80fd\u5f00\u9500\u5c0f\u3002<\/p>\n\n\n\n<ul><li><code>diff\u7b97\u6cd5,\u51cf\u5c11\u56de\u6d41\u548c\u91cd\u7ed8<\/code><\/li><\/ul>\n\n\n\n<p>\u901a\u8fc7diff\u7b97\u6cd5\uff0c\u4f18\u5316\u904d\u5386\uff0c\u5bf9\u771f\u5b9edom\u8fdb\u884c\u6253\u8865\u4e01\u5f0f\u7684\u65b0\u589e\u3001\u4fee\u6539\u3001\u5220\u9664\uff0c\u5b9e\u73b0\u5c40\u90e8\u66f4\u65b0\uff0c\u51cf\u5c11\u56de\u6d41\u548c\u91cd\u7ed8\u3002<\/p>\n\n\n\n<p>vnode\u4f18\u5316\u6027\u80fd\u6838\u5fc3\u601d\u60f3\uff0c\u5c31\u662f\u6bcf\u6b21\u66f4\u65b0 dom \u90fd\u5c3d\u91cf\u907f\u514d\u5237\u65b0\u6574\u4e2a\u9875\u9762\uff0c\u800c\u662f\u6709\u9488\u5bf9\u6027\u7684 \u53bb\u5237\u65b0\u90a3\u88ab\u66f4\u6539\u7684\u4e00\u90e8\u5206 \uff0c\u6765\u91ca\u653e\u6389\u88ab\u65e0\u6548\u6e32\u67d3\u5360\u7528\u7684 gpu\uff0ccup\u6027\u80fd\u3002\u540c\u65f6\uff0c\u4e5f\u51cf\u5c11\u4e86\u5927\u91cf\u7684dom\u64cd\u4f5c\uff0c\u51cf\u5c11\u4e86\u6d4f\u89c8\u5668\u7684\u56de\u6d41\u548c\u91cd\u7ed8\u3002<\/p>\n\n\n\n<ul><li><code><strong>\u8de8\u5e73\u53f0<\/strong><\/code><\/li><\/ul>\n\n\n\n<p>\u865a\u62df DOM \u672c\u8d28\u4e0a\u662f JavaScript \u5bf9\u8c61\uff0c\u800c DOM \u4e0e\u5e73\u53f0\u5f3a\u76f8\u5173\uff0c\u76f8\u6bd4\u4e4b\u4e0b\u865a\u62df DOM \uff0c\u53ef\u4ee5\u8fdb\u884c\u66f4\u65b9\u4fbf\u5730\u8de8\u5e73\u53f0\u64cd\u4f5c\uff0c\u4f8b\u5982\uff1a\u670d\u52a1\u5668\u6e32\u67d3\u3001weex \u5f00\u53d1\u7b49\u7b49<\/p>\n\n\n\n<p><strong>\u7f3a\u70b9<\/strong>:<\/p>\n\n\n\n<ul><li><code>\u9996\u6b21\u663e\u793a\u8981\u6162\u4e9b<\/code><strong>:<\/strong><\/li><\/ul>\n\n\n\n<p>\u9996\u6b21\u6e32\u67d3\u5927\u91cfDOM\u65f6\uff0c\u7531\u4e8e\u591a\u4e86\u4e00\u5c42\u865a\u62dfDOM\u7684\u8ba1\u7b97, \u4f1a\u6bd4innerHTML\u63d2\u5165\u6162<\/p>\n\n\n\n<ul><li><code>\u65e0\u6cd5\u8fdb\u884c\u6781\u81f4\u4f18\u5316<\/code>\uff1a<\/li><\/ul>\n\n\n\n<p>\u867d\u7136\u865a\u62df DOM + \u5408\u7406\u7684\u4f18\u5316\uff0c\u8db3\u4ee5\u5e94\u5bf9\u7edd\u5927\u90e8\u5206\u5e94\u7528\u7684\u6027\u80fd\u9700\u6c42\uff0c\u4f46\u5728\u4e00\u4e9b\u6027\u80fd\u8981\u6c42\u6781\u9ad8\u7684\u5e94\u7528\u4e2d \u65e0\u6cd5\u8fdb\u884c\u9488\u5bf9\u6027\u7684\u6781\u81f4\u4f18\u5316\u3002<\/p>\n\n\n\n<p><strong>3\u3001\u7b80\u8ff0\u865a\u62df DOM \u5b9e\u73b0\u539f\u7406<\/strong><\/p>\n\n\n\n<hr class=\"wp-block-separator\"\/>\n\n\n\n<p>\u865a\u62df dom \u76f8\u5f53\u4e8e<strong>\u5728 js \u548c\u771f\u5b9e dom \u4e2d\u95f4\u52a0\u4e86\u4e00\u4e2a\u7f13\u5b58<\/strong>\uff0c\u5229\u7528 dom diff \u7b97\u6cd5\u907f\u514d\u4e86\u6ca1\u6709\u5fc5\u8981 \u7684 dom \u64cd\u4f5c\uff0c\u4ece\u800c\u63d0\u9ad8\u6027\u80fd\u3002<\/p>\n\n\n\n<p>\u5177\u4f53\u5b9e\u73b0\u6b65\u9aa4\u5982\u4e0b\uff1a<\/p>\n\n\n\n<ul><li>\u7528 JavaScript \u5bf9\u8c61\u7ed3\u6784\u8868\u793a DOM \u6811\u7684\u7ed3\u6784\uff1b\u7136\u540e\u7528\u8fd9\u4e2a\u6811\u6784\u5efa\u4e00\u4e2a\u771f\u6b63\u7684 DOM \u6811\uff0c \u63d2\u5230\u6587\u6863\u5f53\u4e2d\uff1b<\/li><li>\u5f53\u72b6\u6001\u53d8\u66f4\u7684\u65f6\u5019\uff0c\u91cd\u65b0\u6784\u9020\u4e00\u68f5\u65b0\u7684\u5bf9\u8c61\u6811\u3002\u901a\u8fc7diff \u7b97\u6cd5\uff0c\u6bd4\u8f83\u65b0\u65e7\u865a\u62df DOM \u6811\u7684\u5dee\u5f02\u3002<\/li><li>\u6839\u636e\u5dee\u5f02\uff0c\u5bf9\u771f\u6b63\u7684 DOM \u6811\u8fdb\u884c\u589e\u3001\u5220\u3001\u6539\u3002<\/li><\/ul>\n\n\n\n<p><strong>4\u3001\u865a\u62dfDOM\u7684\u903b\u8f91\uff08React\u865a\u62dfdom\u5230\u771f\u5b9edom\u53d1\u751f\u4e86\u4ec0\u4e48\uff09<\/strong><\/p>\n\n\n\n<hr class=\"wp-block-separator\"\/>\n\n\n\n<div class=\"wp-block-image\"><figure class=\"aligncenter size-large is-resized\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/123.57.164.21\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-221-1024x554.png\" alt=\"\" class=\"wp-image-6573\" width=\"578\" height=\"312\" srcset=\"https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-221-1024x554.png 1024w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-221-300x162.png 300w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-221-768x415.png 768w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-221-830x449.png 830w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-221-230x124.png 230w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-221-350x189.png 350w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-221-480x260.png 480w, https:\/\/92it.top\/wp-content\/uploads\/2022\/07\/\u56fe\u7247-221.png 1128w\" sizes=\"(max-width: 578px) 100vw, 578px\" \/><\/figure><\/div>\n","protected":false},"excerpt":{"rendered":"<p>1\u3001\u4ec0\u4e48\u662f\u865a\u62df DOM \uff08vdom\uff09 \u8d77\u6e90 \u865a\u62dfdom\u6700\u5148\u662f\u7531facebook\u56e2\u961f\u63d0\u51fa\u7684\uff0c\u6700\u5148\u8fd0\u7528\u5728react [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[24],"tags":[],"_links":{"self":[{"href":"https:\/\/92it.top\/index.php?rest_route=\/wp\/v2\/posts\/6571"}],"collection":[{"href":"https:\/\/92it.top\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/92it.top\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/92it.top\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/92it.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=6571"}],"version-history":[{"count":2,"href":"https:\/\/92it.top\/index.php?rest_route=\/wp\/v2\/posts\/6571\/revisions"}],"predecessor-version":[{"id":6575,"href":"https:\/\/92it.top\/index.php?rest_route=\/wp\/v2\/posts\/6571\/revisions\/6575"}],"wp:attachment":[{"href":"https:\/\/92it.top\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=6571"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/92it.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=6571"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/92it.top\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=6571"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}