{"id":38214,"date":"2025-05-20T01:04:23","date_gmt":"2025-05-19T17:04:23","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/38214.html"},"modified":"2025-05-20T01:04:23","modified_gmt":"2025-05-19T17:04:23","slug":"%e5%89%8d%e7%ab%af%e9%9d%a2%e7%bb%8f-webpack%e7%af%87-%e5%ae%9a%e4%b9%89%e3%80%81%e9%85%8d%e7%bd%ae%e3%80%81%e6%9e%84%e5%bb%ba%e6%b5%81%e7%a8%8b%e3%80%81-loader%e3%80%81tree-shaking%e3%80%81%e6%87%92","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/38214.html","title":{"rendered":"\u524d\u7aef\u9762\u7ecf-webpack\u7bc7--\u5b9a\u4e49\u3001\u914d\u7f6e\u3001\u6784\u5efa\u6d41\u7a0b\u3001 Loader\u3001Tree Shaking\u3001\u61d2\u52a0\u8f7d\u4e0e\u9884\u52a0\u8f7d\u3001\u4ee3\u7801\u5206\u5272\u3001 Plugin \u673a\u5236"},"content":{"rendered":"<p style=\"background-color:transparent\">\u770b\u5b8c\u672c\u7bc7\u4f60\u5c06\u57fa\u672c\u4e86\u89e3webpack&#xff01;&#xff01;&#xff01;<\/p>\n<p id=\"main-toc\">\u76ee\u5f55<\/p>\n<p id=\"%E4%B8%80%E3%80%81Webpack%20%E7%9A%84%E4%BD%9C%E7%94%A8-toc\" style=\"margin-left:40px\">\u4e00\u3001Webpack \u7684\u4f5c\u7528<\/p>\n<p id=\"%C2%A0%C2%A01%E3%80%81%E5%9F%BA%E6%9C%AC%E9%85%8D%E7%BD%AE%E7%BB%93%E6%9E%84-toc\" style=\"margin-left:40px\">\u00a0\u00a01\u3001\u57fa\u672c\u914d\u7f6e\u7ed3\u6784<\/p>\n<p id=\"2%E3%80%81%E9%85%8D%E7%BD%AE%E9%A1%B9%E8%AF%A6%E8%A7%A3-toc\" style=\"margin-left:40px\">2\u3001\u914d\u7f6e\u9879\u8be6\u89e3<\/p>\n<p id=\"1.%20entry%20%E2%80%94%E2%80%94%20%E6%9E%84%E5%BB%BA%E5%85%A5%E5%8F%A3-toc\" style=\"margin-left:80px\">1. entry \u2014\u2014 \u6784\u5efa\u5165\u53e3<\/p>\n<p id=\"2.%20output%20%E2%80%94%E2%80%94%20%E8%BE%93%E5%87%BA%E9%85%8D%E7%BD%AE-toc\" style=\"margin-left:80px\">2. output \u2014\u2014 \u8f93\u51fa\u914d\u7f6e<\/p>\n<p id=\"3.%20mode%EF%BC%9A%E6%A8%A1%E5%BC%8F%E8%AE%BE%E7%BD%AE-toc\" style=\"margin-left:80px\">3. mode&#xff1a;\u6a21\u5f0f\u8bbe\u7f6e<\/p>\n<p id=\"%C2%A04.%20module%EF%BC%9A%E6%A8%A1%E5%9D%97%E8%A7%84%E5%88%99-toc\" style=\"margin-left:80px\">\u00a04. module&#xff1a;\u6a21\u5757\u89c4\u5219<\/p>\n<p id=\"%C2%A0%C2%A05.%20plugins%EF%BC%9A%E6%8F%92%E4%BB%B6%E6%9C%BA%E5%88%B6-toc\" style=\"margin-left:80px\">\u00a0\u00a05. plugins&#xff1a;\u63d2\u4ef6\u673a\u5236<\/p>\n<p id=\"%C2%A06.%20resolve%EF%BC%9A%E6%A8%A1%E5%9D%97%E8%A7%A3%E6%9E%90%E9%85%8D%E7%BD%AE%EF%BC%88%E5%8F%AF%E9%80%89%EF%BC%89-toc\" style=\"margin-left:80px\">\u00a06. resolve&#xff1a;\u6a21\u5757\u89e3\u6790\u914d\u7f6e&#xff08;\u53ef\u9009&#xff09;<\/p>\n<p id=\"%C2%A07.%20devServer%EF%BC%9A%E5%BC%80%E5%8F%91%E6%9C%8D%E5%8A%A1%E5%99%A8%EF%BC%88%E5%8F%AF%E9%80%89%EF%BC%89-toc\" style=\"margin-left:80px\">\u00a07. devServer&#xff1a;\u5f00\u53d1\u670d\u52a1\u5668&#xff08;\u53ef\u9009&#xff09;<\/p>\n<p id=\"8.%20devtool%EF%BC%9A%E8%B0%83%E8%AF%95%E5%B7%A5%E5%85%B7%EF%BC%88%E5%8F%AF%E9%80%89%EF%BC%89-toc\" style=\"margin-left:80px\">8. devtool&#xff1a;\u8c03\u8bd5\u5de5\u5177&#xff08;\u53ef\u9009&#xff09;<\/p>\n<p id=\"%C2%A09.%20target%EF%BC%9A%E7%9B%AE%E6%A0%87%E5%B9%B3%E5%8F%B0%EF%BC%88%E5%8F%AF%E9%80%89%EF%BC%89-toc\" style=\"margin-left:80px\">\u00a09. target&#xff1a;\u76ee\u6807\u5e73\u53f0&#xff08;\u53ef\u9009&#xff09;<\/p>\n<p id=\"%E4%BA%8C%E3%80%81%E6%9E%84%E5%BB%BA%E6%B5%81%E7%A8%8B-toc\" style=\"margin-left:0px\">\u4e8c\u3001\u6784\u5efa\u6d41\u7a0b<\/p>\n<p id=\"1.%20%E5%88%9D%E5%A7%8B%E5%8C%96%EF%BC%88Initialization%EF%BC%89-toc\" style=\"margin-left:40px\">1. \u521d\u59cb\u5316&#xff08;Initialization&#xff09;<\/p>\n<p id=\"1.%20%E8%AF%BB%E5%8F%96%E9%85%8D%E7%BD%AE%E6%96%87%E4%BB%B6-toc\" style=\"margin-left:80px\">1. \u8bfb\u53d6\u914d\u7f6e\u6587\u4ef6<\/p>\n<p id=\"2.%20%E5%88%9D%E5%A7%8B%E5%8C%96%20Compiler%20%E5%AF%B9%E8%B1%A1-toc\" style=\"margin-left:80px\">2. \u521d\u59cb\u5316 Compiler \u5bf9\u8c61<\/p>\n<p id=\"%C2%A03.%20%E6%B3%A8%E5%86%8C%E6%89%80%E6%9C%89%E6%8F%92%E4%BB%B6%EF%BC%88Plugin%20%E6%B3%A8%E5%86%8C%E9%98%B6%E6%AE%B5%EF%BC%89-toc\" style=\"margin-left:80px\">\u00a03. \u6ce8\u518c\u6240\u6709\u63d2\u4ef6&#xff08;Plugin \u6ce8\u518c\u9636\u6bb5&#xff09;<\/p>\n<p id=\"%C2%A02.%20%E6%9E%84%E5%BB%BA%E6%A8%A1%E5%9D%97%E5%9B%BE%EF%BC%88Build%20Dependency%20Graph%EF%BC%89-toc\" style=\"margin-left:40px\">\u00a02. \u6784\u5efa\u6a21\u5757\u56fe&#xff08;Build Dependency Graph&#xff09;<\/p>\n<p id=\"%C2%A03.%20%E6%A8%A1%E5%9D%97%E8%BD%AC%E6%8D%A2%E4%B8%8E%E8%A7%A3%E6%9E%90-toc\" style=\"margin-left:40px\">\u00a03. \u6a21\u5757\u8f6c\u6362\u4e0e\u89e3\u6790<\/p>\n<p id=\"%E7%A4%BA%E4%BE%8B%201%EF%BC%9AJS%20%E6%96%87%E4%BB%B6%EF%BC%88%E5%8F%AF%E8%83%BD%E5%90%AB%20ES6%E3%80%81TS%EF%BC%89-toc\" style=\"margin-left:120px\">\u793a\u4f8b 1&#xff1a;JS \u6587\u4ef6&#xff08;\u53ef\u80fd\u542b ES6\u3001TS&#xff09;<\/p>\n<p id=\"%E7%A4%BA%E4%BE%8B%202%EF%BC%9ACSS%20%E6%96%87%E4%BB%B6-toc\" style=\"margin-left:120px\">\u793a\u4f8b 2&#xff1a;CSS \u6587\u4ef6<\/p>\n<p id=\"%E7%A4%BA%E4%BE%8B%203%EF%BC%9A%E5%9B%BE%E7%89%87%E6%96%87%E4%BB%B6-toc\" style=\"margin-left:120px\">\u793a\u4f8b 3&#xff1a;\u56fe\u7247\u6587\u4ef6<\/p>\n<p id=\"%C2%A04.%20%E7%94%9F%E6%88%90%E4%BB%A3%E7%A0%81%E5%9D%97%EF%BC%88Chunk%EF%BC%89%E4%B8%8E%E6%96%87%E4%BB%B6%EF%BC%88Asset%EF%BC%89-toc\" style=\"margin-left:40px\">\u00a04. \u751f\u6210\u4ee3\u7801\u5757&#xff08;Chunk&#xff09;\u4e0e\u6587\u4ef6&#xff08;Asset&#xff09;<\/p>\n<p id=\"1%E3%80%81%20Chunk%EF%BC%88%E4%BB%A3%E7%A0%81%E5%9D%97%EF%BC%89-toc\" style=\"margin-left:80px\">1\u3001 Chunk&#xff08;\u4ee3\u7801\u5757&#xff09;<\/p>\n<p id=\"%E5%B8%B8%E8%A7%81%E7%9A%84%20Chunk%20%E7%B1%BB%E5%9E%8B%EF%BC%9A-toc\" style=\"margin-left:120px\">\u5e38\u89c1\u7684 Chunk \u7c7b\u578b&#xff1a;<\/p>\n<p id=\"%C2%A0%F0%9F%94%81%20%E4%B8%BE%E4%B8%AA%E4%BE%8B%E5%AD%90-toc\" style=\"margin-left:120px\">\u00a0&#x1f501; \u4e3e\u4e2a\u4f8b\u5b50<\/p>\n<p id=\"%E4%B8%BA%E4%BB%80%E4%B9%88%E8%A6%81%E6%8A%8A%E4%BB%A3%E7%A0%81%E5%88%86%E6%88%90%E5%A4%9A%E4%B8%AA%20chunk%EF%BC%9F-toc\" style=\"margin-left:120px\">\u4e3a\u4ec0\u4e48\u8981\u628a\u4ee3\u7801\u5206\u6210\u591a\u4e2a chunk&#xff1f;<\/p>\n<p id=\"1.%20%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%EF%BC%9A-toc\" style=\"margin-left:160px\">1. \u6027\u80fd\u4f18\u5316&#xff1a;<\/p>\n<p id=\"2.%20%E7%BC%93%E5%AD%98%E4%BC%98%E5%8C%96%EF%BC%9A-toc\" style=\"margin-left:160px\">2. \u7f13\u5b58\u4f18\u5316&#xff1a;<\/p>\n<p id=\"%C2%A02%E3%80%81Asset%EF%BC%88%E6%9C%80%E7%BB%88%E4%BA%A7%E5%87%BA%E8%B5%84%E6%BA%90%E6%96%87%E4%BB%B6%EF%BC%89-toc\" style=\"margin-left:80px\">\u00a02\u3001Asset&#xff08;\u6700\u7ec8\u4ea7\u51fa\u8d44\u6e90\u6587\u4ef6&#xff09;<\/p>\n<p id=\"3.%20Chunk%20%E8%BD%AC%E6%8D%A2%E4%B8%BA%20Asset%EF%BC%88%C2%A0%20bundle%EF%BC%89-toc\" style=\"margin-left:80px\">3. Chunk \u8f6c\u6362\u4e3a Asset&#xff08;\u00a0 bundle&#xff09;<\/p>\n<p id=\"4.%20%E8%BE%93%E5%87%BA%20Asset%20%E5%88%B0%20output.path-toc\" style=\"margin-left:80px\">4. \u8f93\u51fa Asset \u5230 output.path<\/p>\n<p id=\"5.%20%E8%BE%93%E5%87%BA%E9%98%B6%E6%AE%B5%EF%BC%88Emit%EF%BC%89-toc\" style=\"margin-left:40px\">5. \u8f93\u51fa\u9636\u6bb5&#xff08;Emit&#xff09;<\/p>\n<p id=\"%E4%B8%89%E3%80%81%E6%8F%92%E4%BB%B6%E6%9C%BA%E5%88%B6-toc\" style=\"margin-left:0px\">\u4e09\u3001\u63d2\u4ef6\u673a\u5236<\/p>\n<p id=\"1%E3%80%81%E6%8F%92%E4%BB%B6%E2%80%9C%E6%B3%A8%E5%86%8C%E2%80%9D%E5%8F%91%E7%94%9F%E5%9C%A8%20%E2%80%94%E2%80%94%20%E2%9C%85%20%E5%88%9D%E5%A7%8B%E5%8C%96%E9%98%B6%E6%AE%B5%EF%BC%88Initialization%EF%BC%89-toc\" style=\"margin-left:40px\">1\u3001\u63d2\u4ef6\u201c\u6ce8\u518c\u201d\u53d1\u751f\u5728 \u2014\u2014 \u2705 \u521d\u59cb\u5316\u9636\u6bb5&#xff08;Initialization&#xff09;<\/p>\n<p id=\"2%E3%80%81%E6%8F%92%E4%BB%B6%E2%80%9C%E6%89%A7%E8%A1%8C%E2%80%9D%E5%8F%91%E7%94%9F%E5%9C%A8%20%E2%80%94%E2%80%94%20%E2%9C%85%20%E6%9E%84%E5%BB%BA%E8%BF%87%E7%A8%8B%E7%9A%84%E6%AF%8F%E4%B8%80%E4%B8%AA%E9%98%B6%E6%AE%B5%EF%BC%88Build%20Lifecycle%EF%BC%89-toc\" style=\"margin-left:40px\">2\u3001\u63d2\u4ef6\u201c\u6267\u884c\u201d\u53d1\u751f\u5728 \u2014\u2014 \u2705 \u6784\u5efa\u8fc7\u7a0b\u7684\u6bcf\u4e00\u4e2a\u9636\u6bb5&#xff08;Build Lifecycle&#xff09;<\/p>\n<p id=\"3%E3%80%81compilation-toc\" style=\"margin-left:40px\">3\u3001compilation<\/p>\n<p id=\"1.%20%E6%A8%A1%E5%9D%97%E7%9A%84%E7%AE%A1%E7%90%86-toc\" style=\"margin-left:80px\">1. \u6a21\u5757\u7684\u7ba1\u7406<\/p>\n<p id=\"2.%20%E6%9E%84%E5%BB%BA%20Chunk-toc\" style=\"margin-left:80px\">2. \u6784\u5efa Chunk<\/p>\n<p id=\"3.%20%E7%94%9F%E6%88%90%20Asset%EF%BC%88%E8%BE%93%E5%87%BA%E8%B5%84%E6%BA%90%EF%BC%89-toc\" style=\"margin-left:80px\">3. \u751f\u6210 Asset&#xff08;\u8f93\u51fa\u8d44\u6e90&#xff09;<\/p>\n<p id=\"4.%20Plugin%20%E7%9A%84%E7%94%9F%E5%91%BD%E5%91%A8%E6%9C%9F%E9%92%A9%E5%AD%90-toc\" style=\"margin-left:80px\">4. Plugin \u7684\u751f\u547d\u5468\u671f\u94a9\u5b50<\/p>\n<p id=\"%E5%9B%9B%E3%80%81%E9%85%8D%E7%BD%AE%E9%A1%B9%E4%B9%8B%E9%97%B4%E7%9A%84%E7%9B%B8%E4%BA%92%E5%85%B3%E7%B3%BB-toc\" style=\"margin-left:0px\">\u56db\u3001\u914d\u7f6e\u9879\u4e4b\u95f4\u7684\u76f8\u4e92\u5173\u7cfb<\/p>\n<p id=\"1.%20entry%20%E4%B8%8E%20module.rules-toc\" style=\"margin-left:40px\">1. entry \u4e0e module.rules<\/p>\n<p id=\"2.%20entry%20%E4%B8%8E%20output-toc\" style=\"margin-left:40px\">2. entry \u4e0e output<\/p>\n<p id=\"3.%20module.rules%20%E4%B8%8E%20plugins-toc\" style=\"margin-left:40px\">3. module.rules \u4e0e plugins<\/p>\n<p id=\"4.%20mode%20%E4%B8%8E%E5%85%B6%E4%BB%96%E6%89%80%E6%9C%89%E9%85%8D%E7%BD%AE%E9%A1%B9-toc\" style=\"margin-left:40px\">4. mode \u4e0e\u5176\u4ed6\u6240\u6709\u914d\u7f6e\u9879<\/p>\n<p id=\"5.%20devServer%20%E4%B8%8E%20output-toc\" style=\"margin-left:40px\">5. devServer \u4e0e output<\/p>\n<p id=\"6.%20plugins%20%E4%B8%8E%20output-toc\" style=\"margin-left:40px\">6. plugins \u4e0e output<\/p>\n<p id=\"%E4%BA%94%E3%80%81%20Loader-toc\" style=\"margin-left:0px\">\u4e94\u3001 Loader<\/p>\n<p id=\"1%E3%80%81%E4%BB%80%E4%B9%88%E6%98%AF%20Loader%EF%BC%9F-toc\" style=\"margin-left:40px\">1\u3001\u4ec0\u4e48\u662f Loader&#xff1f;<\/p>\n<p id=\"2%E3%80%81%E4%B8%BA%E4%BB%80%E4%B9%88%E9%9C%80%E8%A6%81%20Loader%EF%BC%9F-toc\" style=\"margin-left:40px\">2\u3001\u4e3a\u4ec0\u4e48\u9700\u8981 Loader&#xff1f;<\/p>\n<p id=\"3%E3%80%81%E5%B8%B8%E8%A7%81%20Loader%20%E7%B1%BB%E5%9E%8B-toc\" style=\"margin-left:40px\">3\u3001\u5e38\u89c1 Loader \u7c7b\u578b<\/p>\n<p id=\"%C2%A0%E4%BB%80%E4%B9%88%E6%98%AF%20babel-loader%EF%BC%9F-toc\" style=\"margin-left:120px\">1\u3001 \u4ec0\u4e48\u662f babel-loader&#xff1f;<\/p>\n<p id=\"%E4%BD%A0%E4%B8%BA%E4%BB%80%E4%B9%88%E9%9C%80%E8%A6%81%20babel-loader%EF%BC%9F-toc\" style=\"margin-left:120px\">2\u3001\u4f60\u4e3a\u4ec0\u4e48\u9700\u8981 babel-loader&#xff1f;<\/p>\n<p id=\"3%E3%80%81%E6%A0%B8%E5%BF%83%E6%A6%82%E5%BF%B5%E8%AF%B4%E6%98%8E-toc\" style=\"margin-left:120px\">3\u3001\u6838\u5fc3\u6982\u5ff5\u8bf4\u660e<\/p>\n<p id=\"4%E3%80%81%E5%B8%B8%E8%A7%81%E7%94%A8%E9%80%94-toc\" style=\"margin-left:120px\">4\u3001\u5e38\u89c1\u7528\u9014<\/p>\n<p id=\"4%E3%80%81Webpack%20%E5%A6%82%E4%BD%95%E8%B0%83%E7%94%A8%20Loader%EF%BC%9F-toc\" style=\"margin-left:40px\">4\u3001Webpack \u5982\u4f55\u8c03\u7528 Loader&#xff1f;<\/p>\n<p id=\"%C2%A0%E5%85%AD%E3%80%81%E6%9E%84%E5%BB%BA%E4%BC%98%E5%8C%96%E4%B8%8E%E9%AB%98%E7%BA%A7%E5%8A%9F%E8%83%BD-toc\" style=\"margin-left:0px\">\u00a0\u516d\u3001\u6784\u5efa\u4f18\u5316\u4e0e\u9ad8\u7ea7\u529f\u80fd<\/p>\n<p id=\"1.%20%E4%BB%A3%E7%A0%81%E5%88%86%E5%89%B2%EF%BC%88Code%20Splitting%EF%BC%89-toc\" style=\"margin-left:40px\">1. \u4ee3\u7801\u5206\u5272&#xff08;Code Splitting&#xff09;<\/p>\n<p id=\"2.%20Tree%20Shaking-toc\" style=\"margin-left:40px\">2. Tree Shaking<\/p>\n<p id=\"Tree%20Shaking%20%E7%9A%84%E5%9F%BA%E6%9C%AC%E5%8E%9F%E7%90%86-toc\" style=\"margin-left:80px\">Tree Shaking \u7684\u57fa\u672c\u539f\u7406<\/p>\n<p id=\"3.%20%E6%87%92%E5%8A%A0%E8%BD%BD%EF%BC%88Lazy%20Loading%EF%BC%89%E4%B8%8E%E9%A2%84%E5%8A%A0%E8%BD%BD-toc\" style=\"margin-left:40px\">3. \u61d2\u52a0\u8f7d&#xff08;Lazy Loading&#xff09;\u4e0e\u9884\u52a0\u8f7d<\/p>\n<p id=\"1%E3%80%81%E4%BB%80%E4%B9%88%E6%98%AF%E6%87%92%E5%8A%A0%E8%BD%BD%EF%BC%88Lazy%20Loading%EF%BC%89%EF%BC%9F-toc\" style=\"margin-left:80px\">1\u3001\u4ec0\u4e48\u662f\u61d2\u52a0\u8f7d&#xff08;Lazy Loading&#xff09;&#xff1f;<\/p>\n<p id=\"Webpack%20%E5%A6%82%E4%BD%95%E5%AE%9E%E7%8E%B0%E6%87%92%E5%8A%A0%E8%BD%BD%EF%BC%9F-toc\" style=\"margin-left:120px\">Webpack \u5982\u4f55\u5b9e\u73b0\u61d2\u52a0\u8f7d&#xff1f;<\/p>\n<p id=\"2%E3%80%81%E4%BB%80%E4%B9%88%E6%98%AF%E9%A2%84%E5%8A%A0%E8%BD%BD%EF%BC%88Preload%EF%BC%89%E5%92%8C%E9%A2%84%E5%8F%96%EF%BC%88Prefetch%EF%BC%89%EF%BC%9F-toc\" style=\"margin-left:80px\">2\u3001\u4ec0\u4e48\u662f\u9884\u52a0\u8f7d&#xff08;Preload&#xff09;\u548c\u9884\u53d6&#xff08;Prefetch&#xff09;&#xff1f;<\/p>\n<p id=\"1.%20webpackPrefetch%3A%20true%20%E2%86%92%20%E6%B5%8F%E8%A7%88%E5%99%A8%E7%A9%BA%E9%97%B2%E6%97%B6%E5%8A%A0%E8%BD%BD%C2%A0-toc\" style=\"margin-left:120px\">1. webpackPrefetch: true \u2192 \u6d4f\u89c8\u5668\u7a7a\u95f2\u65f6\u52a0\u8f7d\u00a0<\/p>\n<p id=\"2.%20webpackPreload%3A%20true%20%E2%86%92%20%E5%BD%93%E5%89%8D%E5%B8%A7%E5%B0%B1%E5%8A%A0%E8%BD%BD%C2%A0-toc\" style=\"margin-left:120px\">2. webpackPreload: true \u2192 \u5f53\u524d\u5e27\u5c31\u52a0\u8f7d\u00a0<\/p>\n<hr id=\"hr-toc\" \/>\n<h3 id=\"%E4%B8%80%E3%80%81Webpack%20%E7%9A%84%E4%BD%9C%E7%94%A8\">\u4e00\u3001Webpack \u7684\u4f5c\u7528<\/h3>\n<p>Webpack \u7684\u4e3b\u8981\u4f5c\u7528\u662f&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u6a21\u5757\u6253\u5305&#xff1a;\u5c06\u591a\u4e2a\u6a21\u5757&#xff08;JS\u3001CSS\u3001\u56fe\u7247\u7b49&#xff09;\u6253\u5305\u6210\u4e00\u4e2a\u6216\u591a\u4e2a\u6587\u4ef6\u3002<\/p>\n<\/li>\n<li>\n<p>\u4ee3\u7801\u62c6\u5206&#xff08;Code Splitting&#xff09;&#xff1a;\u6839\u636e\u9700\u8981\u62c6\u5206\u4ee3\u7801&#xff0c;\u63d0\u9ad8\u9996\u5c4f\u52a0\u8f7d\u901f\u5ea6\u3002<\/p>\n<\/li>\n<li>\n<p>\u8d44\u6e90\u5904\u7406&#xff1a;\u5904\u7406 JS \u4e4b\u5916\u7684\u8d44\u6e90&#xff0c;\u5982 CSS\u3001LESS\u3001SASS\u3001\u56fe\u7247\u3001\u5b57\u4f53\u7b49\u3002<\/p>\n<\/li>\n<li>\n<p>\u5f00\u53d1\u5de5\u5177\u652f\u6301&#xff1a;\u63d0\u4f9b\u5f00\u53d1\u670d\u52a1\u5668\u3001\u70ed\u66f4\u65b0&#xff08;HMR&#xff09;\u3001\u8c03\u8bd5\u7b49\u529f\u80fd\u3002<\/p>\n<\/li>\n<li>\n<p>\u4f18\u5316\u6027\u80fd&#xff1a;\u538b\u7f29\u4ee3\u7801\u3001Tree Shaking&#xff08;\u53bb\u9664\u65e0\u7528\u4ee3\u7801&#xff09;\u3001\u61d2\u52a0\u8f7d\u7b49\u3002<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"%C2%A0%C2%A01%E3%80%81%E5%9F%BA%E6%9C%AC%E9%85%8D%E7%BD%AE%E7%BB%93%E6%9E%84\">\u00a0\u00a01\u3001\u57fa\u672c\u914d\u7f6e\u7ed3\u6784<\/h3>\n<p>\/\/ webpack.config.js<br \/>\nconst path &#061; require(&#039;path&#039;);<\/p>\n<p>module.exports &#061; {<br \/>\n  entry: &#039;.\/src\/index.js&#039;,            \/\/ \u5165\u53e3<br \/>\n  output: {                           \/\/ \u8f93\u51fa<br \/>\n    filename: &#039;bundle.js&#039;,            \/\/ \u8f93\u51fa\u6587\u4ef6\u540d<br \/>\n    path: path.resolve(__dirname, &#039;dist&#039;) \/\/ \u8f93\u51fa\u76ee\u5f55&#xff08;\u5fc5\u987b\u662f\u7edd\u5bf9\u8def\u5f84&#xff09;<br \/>\n  },<br \/>\n  module: {                           \/\/ \u6a21\u5757\u5904\u7406\u89c4\u5219<br \/>\n    rules: [<br \/>\n      {<br \/>\n        test: \/\\\\.css$\/,               \/\/ \u6b63\u5219\u5339\u914d .css \u6587\u4ef6<br \/>\n        use: [&#039;style-loader&#039;, &#039;css-loader&#039;] \/\/ \u4f7f\u7528\u7684 loader&#xff0c;\u4ece\u53f3\u5411\u5de6\u6267\u884c<br \/>\n      }<br \/>\n    ]<br \/>\n  },<br \/>\n  plugins: [],                        \/\/ \u63d2\u4ef6\u5217\u8868<br \/>\n  mode: &#039;development&#039;                 \/\/ \u6784\u5efa\u6a21\u5f0f&#xff1a;development | production<br \/>\n};<\/p>\n<p>\u5728\u4e86\u89e3 Webpack \u539f\u7406\u524d&#xff0c;\u6211\u4eec\u9700\u8981\u5148\u4e86\u89e3\u51e0\u4e2a\u6838\u5fc3\u540d\u8bcd\u7684\u6982\u5ff5&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u5165\u53e3&#xff08;Entry&#xff09;&#xff1a;\u6784\u5efa\u7684\u8d77\u70b9\u3002Webpack \u4ece\u8fd9\u91cc\u5f00\u59cb\u6267\u884c\u6784\u5efa\u3002\u901a\u8fc7 Entry \u914d\u7f6e\u80fd\u591f\u786e\u5b9a\u54ea\u4e2a\u6587\u4ef6\u4f5c\u4e3a\u6784\u5efa\u8fc7\u7a0b\u7684\u5f00\u59cb&#xff0c;\u8fdb\u800c\u8bc6\u522b\u51fa\u5e94\u7528\u7a0b\u5e8f\u7684\u4f9d\u8d56\u56fe\u8c31\u3002<\/p>\n<\/li>\n<li>\n<p>\u6a21\u5757&#xff08;Module&#xff09;&#xff1a;\u6784\u6210\u5e94\u7528\u7684\u5355\u5143\u3002\u5728 Webpack \u7684\u89c6\u89d2\u4e2d&#xff0c;\u4e00\u5207\u6587\u4ef6\u7686\u53ef\u89c6\u4e3a\u6a21\u5757&#xff0c;\u5305\u62ec JavaScript\u3001CSS\u3001\u56fe\u7247\u6216\u8005\u662f\u5176\u4ed6\u7c7b\u578b\u7684\u6587\u4ef6\u3002Webpack \u4ece Entry \u51fa\u53d1&#xff0c;\u9012\u5f52\u5730\u6784\u5efa\u51fa\u4e00\u4e2a\u5305\u542b\u6240\u6709\u4f9d\u8d56\u6587\u4ef6\u7684\u6a21\u5757\u7f51\u7edc\u3002<\/p>\n<\/li>\n<li>\n<p>\u4ee3\u7801\u5757&#xff08;Chunk&#xff09;&#xff1a;\u4ee3\u7801\u7684\u96c6\u5408\u4f53\u3002Chunk \u7531\u6a21\u5757\u5408\u5e76\u800c\u6210&#xff0c;\u88ab\u7528\u6765\u4f18\u5316\u8f93\u51fa\u6587\u4ef6\u7684\u7ed3\u6784\u3002Chunk \u4f7f\u5f97 Webpack \u80fd\u591f\u66f4\u7075\u6d3b\u5730\u7ec4\u7ec7\u548c\u5206\u5272\u4ee3\u7801&#xff0c;\u652f\u6301\u4ee3\u7801\u7684\u61d2\u52a0\u8f7d\u3001\u62c6\u5206\u7b49\u9ad8\u7ea7\u529f\u80fd\u3002<\/p>\n<\/li>\n<li>\n<p>\u52a0\u8f7d\u5668&#xff08;Loader&#xff09;&#xff1a;\u6a21\u5757\u7684\u8f6c\u6362\u5668\u3002Loader \u8ba9 Webpack \u6709\u80fd\u529b\u53bb\u5904\u7406\u90a3\u4e9b\u975e JavaScript \u6587\u4ef6&#xff08;Webpack \u672c\u8eab\u53ea\u7406\u89e3 JavaScript&#xff09;\u3002\u901a\u8fc7 Loader&#xff0c;\u5404\u79cd\u8d44\u6e90\u6587\u4ef6\u53ef\u4ee5\u88ab\u8f6c\u6362\u4e3a Webpack \u80fd\u591f\u5904\u7406\u7684\u6a21\u5757&#xff0c;\u5982\u5c06 CSS \u8f6c\u6362\u4e3a JS \u6a21\u5757&#xff0c;\u6216\u8005\u5c06\u9ad8\u7248\u672c\u7684 JavaScript \u8f6c\u6362\u4e3a\u517c\u5bb9\u6027\u66f4\u597d\u7684\u5f62\u5f0f&#xff08;\u964d\u7ea7&#xff09;\u3002<\/p>\n<\/li>\n<li>\n<p>\u63d2\u4ef6&#xff08;Plugin&#xff09;&#xff1a;\u6784\u5efa\u6d41\u7a0b\u7684\u53c2\u4e0e\u8005\u3002Webpack \u7684\u6784\u5efa\u6d41\u7a0b\u4e2d\u5b58\u5728\u4f17\u591a\u7684\u4e8b\u4ef6\u94a9\u5b50&#xff08;hooks&#xff09;&#xff0c;Plugin \u53ef\u4ee5\u76d1\u542c\u8fd9\u4e9b\u4e8b\u4ef6\u7684\u89e6\u53d1&#xff0c;\u5728\u89e6\u53d1\u65f6\u52a0\u5165\u81ea\u5b9a\u4e49\u7684\u6784\u5efa\u884c\u4e3a&#xff0c;\u5982\u81ea\u52a8\u538b\u7f29\u6253\u5305\u540e\u7684\u6587\u4ef6\u3001\u751f\u6210\u5e94\u7528\u6240\u9700\u7684 HTML \u6587\u4ef6\u7b49\u3002<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"2%E3%80%81%E9%85%8D%E7%BD%AE%E9%A1%B9%E8%AF%A6%E8%A7%A3\">2\u3001\u914d\u7f6e\u9879\u8be6\u89e3<\/h3>\n<h4 id=\"1.%20entry%20%E2%80%94%E2%80%94%20%E6%9E%84%E5%BB%BA%E5%85%A5%E5%8F%A3\">1. entry \u2014\u2014 \u6784\u5efa\u5165\u53e3<\/h4>\n<p>\u6307\u5b9a Webpack \u6784\u5efa\u7684\u8d77\u70b9&#xff0c;\u652f\u6301\u591a\u5165\u53e3\u914d\u7f6e\u3002<\/p>\n<p>\u00a0entry: &#039;.\/src\/index.js&#039;<\/p>\n<p>\u4f5c\u7528&#xff1a;\u6307\u5b9a Webpack \u6784\u5efa\u7684\u8d77\u70b9\u6587\u4ef6&#xff0c;\u4ece\u8fd9\u4e2a\u6587\u4ef6\u51fa\u53d1\u9012\u5f52\u5206\u6790\u6240\u6709\u4f9d\u8d56\u3002<\/p>\n<ul>\n<li>\n<p>\u9ed8\u8ba4\u503c\u662f &#039;.\/src\/index.js&#039;\u3002<\/p>\n<\/li>\n<li>\n<p>\u652f\u6301\u5355\u5165\u53e3&#xff08;\u5b57\u7b26\u4e32&#xff09;\u548c\u591a\u5165\u53e3&#xff08;\u5bf9\u8c61\u5f62\u5f0f&#xff09;\u3002<\/p>\n<\/li>\n<\/ul>\n<p>\u591a\u5165\u53e3\u793a\u4f8b&#xff1a;<\/p>\n<p>entry: { \u00a0 app: &#039;.\/src\/app.js&#039;, \u00a0 admin: &#039;.\/src\/admin.js&#039; }<\/p>\n<p>&#x1f501; Webpack \u4f1a\u4e3a\u6bcf\u4e2a\u5165\u53e3\u5206\u522b\u6253\u5305\u751f\u6210\u8f93\u51fa\u6587\u4ef6\u3002\u00a0<\/p>\n<h4 id=\"2.%20output%20%E2%80%94%E2%80%94%20%E8%BE%93%E5%87%BA%E9%85%8D%E7%BD%AE\">2. output \u2014\u2014 \u8f93\u51fa\u914d\u7f6e<\/h4>\n<p>\u63a7\u5236\u6253\u5305\u540e\u7684\u6587\u4ef6\u540d\u79f0\u548c\u8def\u5f84\u3002<\/p>\n<p>\u4f5c\u7528&#xff1a;\u6307\u5b9a\u6253\u5305\u540e\u6587\u4ef6\u7684\u5b58\u50a8\u4f4d\u7f6e\u548c\u547d\u540d\u89c4\u5219\u3002<\/p>\n<ul>\n<li>\n<p>filename&#xff1a;\u8f93\u51fa\u6587\u4ef6\u540d&#xff0c;\u53ef\u5305\u542b\u5360\u4f4d\u7b26&#xff08;\u5982 [name], [contenthash]&#xff09;<\/p>\n<\/li>\n<li>\n<p>path&#xff1a;\u8f93\u51fa\u76ee\u5f55&#xff0c;\u5fc5\u987b\u662f\u7edd\u5bf9\u8def\u5f84<\/p>\n<\/li>\n<\/ul>\n<p>output: { \u00a0 filename: &#039;bundle.js&#039;, \/\/ \u8f93\u51fa\u7684\u6587\u4ef6\u540d \u00a0 path: path.resolve(__dirname, &#039;dist&#039;) \/\/ \u7edd\u5bf9\u8def\u5f84 } \u00a0\u52a8\u6001\u547d\u540d&#xff08;\u7528\u4e8e\u591a\u5165\u53e3&#xff09;&#xff1a;filename: &#039;[name].[contenthash].js&#039;<\/p>\n<h4 id=\"3.%20mode%EF%BC%9A%E6%A8%A1%E5%BC%8F%E8%AE%BE%E7%BD%AE\">3. mode&#xff1a;\u6a21\u5f0f\u8bbe\u7f6e<\/h4>\n<p>\u00a0mode: &#039;development&#039; \/\/ \u6216 &#039;production&#039;<\/p>\n<p>\u4f5c\u7528&#xff1a;\u6307\u5b9a\u6253\u5305\u6a21\u5f0f&#xff0c;Webpack \u4f1a\u81ea\u52a8\u542f\u7528\u5bf9\u5e94\u7684\u4f18\u5316\u3002<\/p>\n<ul>\n<li>\n<p>development&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u5f00\u542f\u8c03\u8bd5&#xff08;source map&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u4e0d\u538b\u7f29\u4ee3\u7801<\/p>\n<\/li>\n<li>\n<p>\u63d0\u9ad8\u6784\u5efa\u901f\u5ea6<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>production&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u81ea\u52a8\u538b\u7f29 JavaScript\/CSS<\/p>\n<\/li>\n<li>\n<p>\u542f\u7528 Tree Shaking&#xff08;\u79fb\u9664\u672a\u4f7f\u7528\u4ee3\u7801&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u66f4\u5c0f\u4f53\u79ef\u3001\u9002\u5408\u4e0a\u7ebf<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h4 id=\"%C2%A04.%20module%EF%BC%9A%E6%A8%A1%E5%9D%97%E8%A7%84%E5%88%99\">\u00a04. module&#xff1a;\u6a21\u5757\u89c4\u5219<\/h4>\n<p>\u00a0module: { \u00a0 rules: [&#8230;] }<\/p>\n<p>\u4f5c\u7528&#xff1a;\u5b9a\u4e49\u5bf9\u4e0d\u540c\u6a21\u5757&#xff08;\u5982 CSS\u3001JS\u3001\u56fe\u7247\u7b49&#xff09;\u7684\u5904\u7406\u89c4\u5219&#xff0c;\u6838\u5fc3\u7531 rules \u6570\u7ec4\u7ec4\u6210\u3002<\/p>\n<p>\u6bcf\u6761\u89c4\u5219\u683c\u5f0f\u5982\u4e0b&#xff1a;<\/p>\n<p>{ \u00a0 test: \/\\\\.css$\/, \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u6b63\u5219\u5339\u914d\u9700\u8981\u5904\u7406\u7684\u6587\u4ef6\u7c7b\u578b \u00a0 use: [&#039;style-loader&#039;, &#039;css-loader&#039;] \u00a0\/\/ \u4f7f\u7528\u7684 loader&#xff08;\u4ece\u53f3\u5230\u5de6\u6267\u884c&#xff09; }<\/p>\n<p>&#x1f4cc; \u5e38\u89c1 Loader&#xff1a;<\/p>\n<table>\n<tr>\u6587\u4ef6\u7c7b\u578bLoader \u793a\u4f8b<\/tr>\n<tbody>\n<tr>\n<td>JS<\/td>\n<td>babel-loader<\/td>\n<\/tr>\n<tr>\n<td>CSS<\/td>\n<td>css-loader\u3001style-loader<\/td>\n<\/tr>\n<tr>\n<td>\u56fe\u7247<\/td>\n<td>file-loader\u3001url-loader<\/td>\n<\/tr>\n<tr>\n<td>\u5b57\u4f53<\/td>\n<td>file-loader<\/td>\n<\/tr>\n<tr>\n<td>Vue<\/td>\n<td>vue-loader<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h4 id=\"%C2%A0%C2%A05.%20plugins%EF%BC%9A%E6%8F%92%E4%BB%B6%E6%9C%BA%E5%88%B6\">\u00a0\u00a05. plugins&#xff1a;\u63d2\u4ef6\u673a\u5236<\/h4>\n<p>plugins: [<br \/>\n  new HtmlWebpackPlugin({<br \/>\n    template: &#039;.\/src\/index.html&#039;<br \/>\n  })<br \/>\n]<\/p>\n<p>\u00a0\u4f5c\u7528&#xff1a;\u6269\u5c55 Webpack \u7684\u529f\u80fd&#xff0c;\u7528\u4e8e\u6267\u884c\u66f4\u590d\u6742\u7684\u6784\u5efa\u4efb\u52a1\u3002<\/p>\n<p>&#x1f4cc; \u5e38\u7528\u63d2\u4ef6\u53ca\u4f5c\u7528&#xff1a;<\/p>\n<table>\n<tr>\u63d2\u4ef6\u540d\u4f5c\u7528<\/tr>\n<tbody>\n<tr>\n<td>HtmlWebpackPlugin<\/td>\n<td>\u81ea\u52a8\u751f\u6210 HTML \u6587\u4ef6\u5e76\u6ce8\u5165\u6253\u5305\u8d44\u6e90<\/td>\n<\/tr>\n<tr>\n<td>CleanWebpackPlugin<\/td>\n<td>\u6784\u5efa\u524d\u81ea\u52a8\u6e05\u7a7a\u8f93\u51fa\u76ee\u5f55<\/td>\n<\/tr>\n<tr>\n<td>MiniCssExtractPlugin<\/td>\n<td>\u63d0\u53d6 CSS \u5230\u5355\u72ec\u6587\u4ef6<\/td>\n<\/tr>\n<tr>\n<td>DefinePlugin<\/td>\n<td>\u5b9a\u4e49\u73af\u5883\u53d8\u91cf<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h4 id=\"%C2%A06.%20resolve%EF%BC%9A%E6%A8%A1%E5%9D%97%E8%A7%A3%E6%9E%90%E9%85%8D%E7%BD%AE%EF%BC%88%E5%8F%AF%E9%80%89%EF%BC%89\">\u00a06. resolve&#xff1a;\u6a21\u5757\u89e3\u6790\u914d\u7f6e&#xff08;\u53ef\u9009&#xff09;<\/h4>\n<p>resolve: {<br \/>\n  extensions: [&#039;.js&#039;, &#039;.jsx&#039;, &#039;.json&#039;]<br \/>\n}<\/p>\n<p>\u00a0\u4f5c\u7528&#xff1a;\u6307\u5b9a\u5728\u5bfc\u5165\u6a21\u5757\u65f6\u53ef\u7701\u7565\u7684\u6587\u4ef6\u6269\u5c55\u540d&#xff0c;\u63d0\u9ad8\u6a21\u5757\u67e5\u627e\u6548\u7387\u3002<\/p>\n<p>\u00a0&#x1f4cc; \u4f8b\u5982&#xff1a;import App from &#039;.\/App&#039; \/\/ \u5b9e\u9645\u67e5\u627e&#xff1a;.\/App.js -&gt; .\/App.jsx -&gt; .\/App.json<\/p>\n<h4 id=\"%C2%A07.%20devServer%EF%BC%9A%E5%BC%80%E5%8F%91%E6%9C%8D%E5%8A%A1%E5%99%A8%EF%BC%88%E5%8F%AF%E9%80%89%EF%BC%89\">\u00a07. devServer&#xff1a;\u5f00\u53d1\u670d\u52a1\u5668&#xff08;\u53ef\u9009&#xff09;<\/h4>\n<p>devServer: {<br \/>\n  static: &#039;.\/dist&#039;,<br \/>\n  port: 3000,<br \/>\n  hot: true<br \/>\n}<\/p>\n<p>\u4f5c\u7528&#xff1a;\u542f\u52a8\u672c\u5730\u5f00\u53d1\u670d\u52a1\u5668&#xff0c;\u652f\u6301\u70ed\u66f4\u65b0&#xff08;HMR&#xff09;&#xff0c;\u63d0\u5347\u5f00\u53d1\u6548\u7387\u3002<\/p>\n<p>HMR&#xff08;Hot Module Replacement&#xff09;\u662f Webpack \u5728\u5f00\u53d1\u73af\u5883\u4e0b\u7684\u4e00\u79cd\u201c\u70ed\u66f4\u65b0\u201d\u529f\u80fd&#xff0c;\u5141\u8bb8\u4f60\u5728\u4e0d\u5237\u65b0\u9875\u9762\u7684\u60c5\u51b5\u4e0b\u66ff\u6362\u3001\u66f4\u65b0\u6a21\u5757\u7684\u5185\u5bb9\u3002<\/p>\n<p>\u914d\u7f6e\u8bf4\u660e&#xff1a;<\/p>\n<ul>\n<li>\n<p>static: \u63d0\u4f9b\u9759\u6001\u6587\u4ef6\u76ee\u5f55<\/p>\n<\/li>\n<li>\n<p>port: \u8bbe\u7f6e\u8bbf\u95ee\u7aef\u53e3<\/p>\n<\/li>\n<li>\n<p>hot: \u542f\u7528\u70ed\u66f4\u65b0\u529f\u80fd&#xff08;\u65e0\u9700\u5237\u65b0\u9875\u9762\u5373\u53ef\u5e94\u7528\u66f4\u6539&#xff09;<\/p>\n<\/li>\n<\/ul>\n<h4 id=\"8.%20devtool%EF%BC%9A%E8%B0%83%E8%AF%95%E5%B7%A5%E5%85%B7%EF%BC%88%E5%8F%AF%E9%80%89%EF%BC%89\" style=\"background-color:transparent\">8. devtool&#xff1a;\u8c03\u8bd5\u5de5\u5177&#xff08;\u53ef\u9009&#xff09;<\/h4>\n<p>devtool: &#039;source-map&#039;<\/p>\n<p>\u4f5c\u7528&#xff1a;\u751f\u6210 source map&#xff0c;\u5e2e\u52a9\u8c03\u8bd5\u4ee3\u7801\u65f6\u6620\u5c04\u5230\u6e90\u7801\u4f4d\u7f6e\u3002<\/p>\n<p>\u5e38\u7528\u9009\u9879&#xff1a;<\/p>\n<ul>\n<li>\n<p>source-map&#xff1a;\u5b8c\u6574 source map&#xff0c;\u6700\u8be6\u7ec6&#xff08;\u7528\u4e8e\u751f\u4ea7&#xff09;<\/p>\n<\/li>\n<li>\n<p>eval-source-map&#xff1a;\u5feb\u4e14\u53ef\u8c03\u8bd5&#xff08;\u7528\u4e8e\u5f00\u53d1&#xff09;<\/p>\n<\/li>\n<li>\n<p>none&#xff1a;\u5173\u95ed source map<\/p>\n<\/li>\n<\/ul>\n<h4 id=\"%C2%A09.%20target%EF%BC%9A%E7%9B%AE%E6%A0%87%E5%B9%B3%E5%8F%B0%EF%BC%88%E5%8F%AF%E9%80%89%EF%BC%89\">\u00a09. target&#xff1a;\u76ee\u6807\u5e73\u53f0&#xff08;\u53ef\u9009&#xff09;<\/h4>\n<p>\u00a0\u4f5c\u7528&#xff1a;\u6307\u5b9a\u6784\u5efa\u76ee\u6807\u73af\u5883&#xff08;\u6d4f\u89c8\u5668 \/ Node.js&#xff09;<\/p>\n<p>target: &#039;web&#039; \/\/ \u6216 &#039;node&#039; <\/p>\n<h2 id=\"%E4%BA%8C%E3%80%81%E6%9E%84%E5%BB%BA%E6%B5%81%E7%A8%8B\" style=\"background-color:transparent\">\u4e8c\u3001\u6784\u5efa\u6d41\u7a0b<\/h2>\n<h3 id=\"1.%20%E5%88%9D%E5%A7%8B%E5%8C%96%EF%BC%88Initialization%EF%BC%89\" style=\"background-color:transparent\">1. \u521d\u59cb\u5316&#xff08;Initialization&#xff09;<\/h3>\n<ul>\n<li>\n<p>\u8bfb\u53d6\u914d\u7f6e\u6587\u4ef6&#xff08;webpack.config.js&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u521d\u59cb\u5316 Compiler&#xff08;\u6838\u5fc3\u5bf9\u8c61&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u6ce8\u518c\u6240\u6709 plugin&#xff0c;\u8fdb\u5165\u751f\u547d\u5468\u671f\u94a9\u5b50&#xff08;\u57fa\u4e8e Tapable&#xff09;<\/p>\n<\/li>\n<\/ul>\n<p id=\"%E5%9C%A8%20Webpack%20%E4%B8%AD%EF%BC%8C%E5%AD%98%E5%9C%A8%E4%B8%A4%E4%B8%AA%E9%9D%9E%E5%B8%B8%E9%87%8D%E8%A6%81%E7%9A%84%E6%A0%B8%E5%BF%83%E5%AF%B9%E8%B1%A1%EF%BC%9Acompiler%E3%80%81compilation%EF%BC%8C%E5%AE%83%E4%BB%AC%E7%9A%84%E4%BD%9C%E7%94%A8%E5%A6%82%E4%B8%8B%EF%BC%9A\" style=\"background-color:transparent\"><span style=\"color:#4d4d4d;font-size:16px;font-weight:normal\">\u5728 Webpack \u4e2d&#xff0c;\u5b58\u5728\u4e24\u4e2a\u975e\u5e38\u91cd\u8981\u7684\u6838\u5fc3\u5bf9\u8c61&#xff1a;<\/span>compiler<span style=\"color:#4d4d4d;font-size:16px;font-weight:normal\">\u3001<\/span>compilation<span style=\"color:#4d4d4d;font-size:16px;font-weight:normal\">&#xff0c;\u5b83\u4eec\u7684\u4f5c\u7528\u5982\u4e0b&#xff1a;<\/span><\/p>\n<ul>\n<li>Compiler&#xff1a;Webpack \u7684\u6838\u5fc3&#xff0c;\u8d2f\u7a7f\u4e8e\u6574\u4e2a\u6784\u5efa\u5468\u671f\u3002Compiler \u5c01\u88c5\u4e86 Webpack \u73af\u5883\u7684\u5168\u5c40\u914d\u7f6e&#xff0c;\u5305\u62ec\u4f46\u4e0d\u9650\u4e8e\u914d\u7f6e\u4fe1\u606f\u3001\u8f93\u51fa\u8def\u5f84\u7b49\u3002<\/li>\n<li>Compilation&#xff1a;\u8868\u793a\u5355\u6b21\u7684\u6784\u5efa\u8fc7\u7a0b\u53ca\u5176\u4ea7\u51fa\u3002\u4e0e Compiler \u4e0d\u540c&#xff0c;Compilation \u5bf9\u8c61\u5728\u6bcf\u6b21\u6784\u5efa\u4e2d\u90fd\u662f\u65b0\u521b\u5efa\u7684&#xff0c;\u63cf\u8ff0\u4e86\u6784\u5efa\u7684\u5177\u4f53\u8fc7\u7a0b&#xff0c;\u5305\u62ec\u6a21\u5757\u8d44\u6e90\u3001\u7f16\u8bd1\u540e\u7684\u4ea7\u51fa\u8d44\u6e90\u3001\u6587\u4ef6\u7684\u53d8\u5316&#xff0c;\u4ee5\u53ca\u4f9d\u8d56\u5173\u7cfb\u7684\u72b6\u6001\u3002\u5728watch mode \u4e0b&#xff0c;\u6bcf\u5f53\u6587\u4ef6\u53d8\u5316\u89e6\u53d1\u91cd\u65b0\u6784\u5efa\u65f6&#xff0c;\u90fd\u4f1a\u751f\u6210\u4e00\u4e2a\u65b0\u7684 Compilation \u5b9e\u4f8b\u3002<\/li>\n<\/ul>\n<p>Compiler \u662f\u4e00\u4e2a\u957f\u671f\u5b58\u5728\u7684\u73af\u5883\u63cf\u8ff0&#xff0c;\u8d2f\u7a7f\u6574\u4e2a Webpack \u8fd0\u884c\u5468\u671f&#xff1b;\u800c Compilation \u662f\u5bf9\u5355\u6b21\u6784\u5efa\u7684\u5177\u4f53\u63cf\u8ff0&#xff0c;\u6bcf\u4e00\u6b21\u6784\u5efa\u8fc7\u7a0b\u90fd\u53ef\u80fd\u6709\u6240\u4e0d\u540c\u3002<\/p>\n<h4 id=\"1.%20%E8%AF%BB%E5%8F%96%E9%85%8D%E7%BD%AE%E6%96%87%E4%BB%B6\">1. \u8bfb\u53d6\u914d\u7f6e\u6587\u4ef6<\/h4>\n<p>Webpack \u542f\u52a8\u65f6\u4f1a\u67e5\u627e\u914d\u7f6e\u6587\u4ef6&#xff08;\u9ed8\u8ba4\u662f webpack.config.js&#xff09;&#xff0c;\u5e76\u52a0\u8f7d\u5b83\u3002<\/p>\n<p>\u652f\u6301\u7684\u6587\u4ef6\u683c\u5f0f\u5305\u62ec&#xff1a;<\/p>\n<ul>\n<li>\n<p>JavaScript (webpack.config.js)<\/p>\n<\/li>\n<li>\n<p>TypeScript (webpack.config.ts)<\/p>\n<\/li>\n<li>\n<p>JSON&#xff08;\u90e8\u5206\u5b57\u6bb5&#xff09;<\/p>\n<\/li>\n<\/ul>\n<p>Webpack \u4f1a\u6267\u884c\u914d\u7f6e\u6587\u4ef6\u7684\u5185\u5bb9&#xff0c;\u8bfb\u53d6\u5176\u4e2d\u7684&#xff1a;<\/p>\n<ul>\n<li>\n<p>entry, output<\/p>\n<\/li>\n<li>\n<p>module.rules<\/p>\n<\/li>\n<li>\n<p>plugins<\/p>\n<\/li>\n<li>\n<p>mode, devtool, resolve, \u7b49\u7b49<\/p>\n<\/li>\n<\/ul>\n<p>&#x1f4cc; \u6ce8\u610f&#xff1a;Webpack \u672c\u8d28\u4e0a\u4f1a\u6267\u884c require(&#039;.\/webpack.config.js&#039;)&#xff0c;\u6240\u4ee5\u4f60\u751a\u81f3\u53ef\u4ee5\u5728\u91cc\u9762\u5199 JS \u903b\u8f91&#xff08;\u4f8b\u5982\u6839\u636e\u73af\u5883\u52a8\u6001\u8fd4\u56de\u4e0d\u540c\u914d\u7f6e&#xff09;\u3002<\/p>\n<h4 id=\"2.%20%E5%88%9D%E5%A7%8B%E5%8C%96%20Compiler%20%E5%AF%B9%E8%B1%A1\">2. \u521d\u59cb\u5316 Compiler \u5bf9\u8c61<\/h4>\n<p>Webpack \u5185\u90e8\u4f1a\u6784\u9020\u51fa\u4e00\u4e2a\u6838\u5fc3\u5bf9\u8c61&#xff1a;\u00a0\u00a0Compiler:const compiler &#061; new Compiler(options);<\/p>\n<p>\u8fd9\u4e2a\u5bf9\u8c61\u662f\u6574\u4e2a\u6784\u5efa\u7cfb\u7edf\u7684\u201c\u5927\u8111\u201d&#xff0c;\u5305\u542b&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u6240\u6709\u7528\u6237\u914d\u7f6e<\/p>\n<\/li>\n<li>\n<p>\u6240\u6709\u6784\u5efa\u72b6\u6001<\/p>\n<\/li>\n<li>\n<p>\u6240\u6709\u94a9\u5b50&#xff08;\u4e8b\u4ef6\u7cfb\u7edf&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u6240\u6709\u6a21\u5757\u3001chunk\u3001asset \u7684\u6570\u636e\u7ed3\u6784<\/p>\n<\/li>\n<\/ul>\n<p>&#x1f4cc; Compiler \u4e0d\u662f\u968f\u4fbf\u4e00\u4e2a\u7c7b&#xff0c;\u5b83\u7ee7\u627f\u4e86 Tapable \u7c7b&#xff0c;\u5185\u7f6e\u4e86\u5f88\u591a\u201c\u751f\u547d\u5468\u671f\u94a9\u5b50\u201d\u3002<\/p>\n<p>\u4f8b\u5982&#xff1a;<\/p>\n<p>compiler.hooks.run.tap(&#8230;)<br \/>\ncompiler.hooks.emit.tap(&#8230;)<br \/>\ncompiler.hooks.done.tap(&#8230;)<\/p>\n<h4 id=\"%C2%A03.%20%E6%B3%A8%E5%86%8C%E6%89%80%E6%9C%89%E6%8F%92%E4%BB%B6%EF%BC%88Plugin%20%E6%B3%A8%E5%86%8C%E9%98%B6%E6%AE%B5%EF%BC%89\">\u00a03. \u6ce8\u518c\u6240\u6709\u63d2\u4ef6&#xff08;Plugin \u6ce8\u518c\u9636\u6bb5&#xff09;<\/h4>\n<p>Webpack \u6267\u884c plugins \u6570\u7ec4\u4e2d\u6bcf\u4e00\u4e2a\u63d2\u4ef6\u7684 .apply() \u65b9\u6cd5&#xff0c;\u628a\u63d2\u4ef6\u201c\u6302\u8f7d\u201d\u5230 compiler \u4e0a\u3002<\/p>\n<p>const HtmlWebpackPlugin &#061; require(&#039;html-webpack-plugin&#039;);<\/p>\n<p>module.exports &#061; {<br \/>\n  plugins: [<br \/>\n    new HtmlWebpackPlugin({ template: &#039;.\/index.html&#039; })<br \/>\n  ]<br \/>\n}<\/p>\n<p>\u00a0HtmlWebpackPlugin \u5185\u90e8\u4f1a\u6267\u884c&#xff1a;<\/p>\n<p>apply(compiler) {<br \/>\n  compiler.hooks.emit.tap(&#039;HtmlWebpackPlugin&#039;, compilation &#061;&gt; {<br \/>\n    \/\/ \u63d2\u4ef6\u903b\u8f91<br \/>\n  });<br \/>\n}<\/p>\n<p>\u00a0&#x1f4cc; \u8fd9\u76f8\u5f53\u4e8e\u5728\u6784\u5efa\u201c\u8fd8\u6ca1\u5f00\u59cb\u524d\u201d&#xff0c;\u5c31\u51c6\u5907\u597d\u4e86\u63d2\u4ef6\u7684\u76d1\u542c\u4e8b\u4ef6&#xff0c;\u8ba9\u63d2\u4ef6\u5728\u9002\u5f53\u65f6\u673a\u4ecb\u5165\u6784\u5efa\u6d41\u7a0b\u3002<\/p>\n<p>\u521d\u59cb\u5316\u9636\u6bb5\u7684\u5185\u90e8\u673a\u5236&#xff1a;Tapable \u7cfb\u7edf<\/p>\n<p>Webpack \u7684\u63d2\u4ef6\u673a\u5236\u57fa\u4e8e\u4e00\u4e2a\u5e93&#xff1a;Tapable\u3002<\/p>\n<p>\u4f60\u53ef\u4ee5\u628a\u5b83\u60f3\u8c61\u6210\u201c\u4e8b\u4ef6\u53d1\u5e03\/\u8ba2\u9605\u7cfb\u7edf\u201d&#xff1a;<\/p>\n<ul>\n<li>\n<p>Webpack \u751f\u547d\u5468\u671f\u4e2d\u5404\u4e2a\u9636\u6bb5\u90fd\u4f1a\u89e6\u53d1\u94a9\u5b50<\/p>\n<\/li>\n<li>\n<p>\u63d2\u4ef6\u4f1a\u63d0\u524d\u901a\u8fc7 .tap() \u6ce8\u518c\u51fd\u6570<\/p>\n<\/li>\n<li>\n<p>\u7b49\u6784\u5efa\u8fdb\u884c\u5230\u67d0\u4e00\u9636\u6bb5\u65f6&#xff0c;\u5c31\u4f1a\u6267\u884c\u5bf9\u5e94\u94a9\u5b50\u4e2d\u7684\u63d2\u4ef6\u903b\u8f91<\/p>\n<\/li>\n<\/ul>\n<p>\u5e38\u89c1\u7684 Hook&#xff1a;<\/p>\n<table>\n<tr>Hook \u540d\u79f0\u89e6\u53d1\u65f6\u673a<\/tr>\n<tbody>\n<tr>\n<td>run<\/td>\n<td>\u6784\u5efa\u5f00\u59cb\u65f6<\/td>\n<\/tr>\n<tr>\n<td>compile<\/td>\n<td>\u4f9d\u8d56\u56fe\u6784\u5efa\u524d<\/td>\n<\/tr>\n<tr>\n<td>compilation<\/td>\n<td>\u521b\u5efa Compilation \u5bf9\u8c61\u65f6<\/td>\n<\/tr>\n<tr>\n<td>emit<\/td>\n<td>\u8f93\u51fa\u8d44\u6e90\u524d<\/td>\n<\/tr>\n<tr>\n<td>done<\/td>\n<td>\u6784\u5efa\u7ed3\u675f\u65f6<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u00a0\u521d\u59cb\u5316\u9636\u6bb5\u540e\u7684\u51c6\u5907\u7ed3\u679c\u662f\u4ec0\u4e48&#xff1f;<\/p>\n<ul>\n<li>\n<p>\u6240\u6709\u914d\u7f6e\u4fe1\u606f\u90fd\u5df2\u89e3\u6790<\/p>\n<\/li>\n<li>\n<p>\u6240\u6709\u63d2\u4ef6\u90fd\u5df2\u6ce8\u518c\u5230\u5408\u9002\u7684\u751f\u547d\u5468\u671f\u94a9\u5b50<\/p>\n<\/li>\n<li>\n<p>\u6784\u5efa\u72b6\u6001\u5bf9\u8c61 compiler \u6784\u5efa\u5b8c\u6210<\/p>\n<\/li>\n<\/ul>\n<p>\u27a1\ufe0f \u73b0\u5728&#xff0c;\u53ea\u7b49\u4e0b\u4e00\u6b65\u5f00\u59cb\u6b63\u5f0f\u6784\u5efa\u4e86&#xff08;\u6784\u5efa\u4f9d\u8d56\u56fe\u3001\u8f6c\u6362\u6a21\u5757\u3001\u751f\u6210 chunk&#xff09;\u3002<\/p>\n<h3 id=\"%C2%A02.%20%E6%9E%84%E5%BB%BA%E6%A8%A1%E5%9D%97%E5%9B%BE%EF%BC%88Build%20Dependency%20Graph%EF%BC%89\">\u00a02. \u6784\u5efa\u6a21\u5757\u56fe&#xff08;Build Dependency Graph&#xff09;<\/h3>\n<p>\u4ece entry \u5f00\u59cb\u9012\u5f52\u5206\u6790&#xff1a;<\/p>\n<li>\n<p>\u8bfb\u53d6\u5165\u53e3\u6587\u4ef6<\/p>\n<\/li>\n<li>\n<p>\u8bc6\u522b\u5bfc\u5165\u7684\u6a21\u5757&#xff08;import \/ require&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u901a\u8fc7 module.rules \u9009\u62e9\u5408\u9002\u7684 loader \u8fdb\u884c\u8f6c\u6362<\/p>\n<\/li>\n<li>\n<p>\u7ee7\u7eed\u9012\u5f52\u8bfb\u53d6\u4f9d\u8d56&#xff0c;\u76f4\u5230\u6ca1\u6709\u65b0\u4f9d\u8d56\u4e3a\u6b62<\/p>\n<\/li>\n<li>\n<p>\u5efa\u7acb\u4e00\u4e2a \u6a21\u5757\u4f9d\u8d56\u56fe&#xff08;Module Graph&#xff09;<\/p>\n<\/li>\n<p>\u00a0\u6a21\u5757\u56fe\u662f\u4e00\u4e2a DAG&#xff08;\u6709\u5411\u65e0\u73af\u56fe&#xff09;&#xff0c;\u8868\u793a\u6a21\u5757\u95f4\u7684\u5f15\u7528\u5173\u7cfb\u3002<\/p>\n<p>\u5047\u8bbe\u4f60\u6709\u8fd9\u6837\u7684\u6587\u4ef6\u7ed3\u6784&#xff1a;\u00a0<\/p>\n<p>src\/<br \/>\n\u251c\u2500\u2500 index.js<br \/>\n\u251c\u2500\u2500 utils.js<br \/>\n\u251c\u2500\u2500 style.css<br \/>\n\u2514\u2500\u2500 logo.png<\/p>\n<p>index.js \u5185\u5bb9\u5982\u4e0b&#xff1a;<\/p>\n<p>import &#039;.\/style.css&#039;;<br \/>\nimport { add } from &#039;.\/utils.js&#039;;<br \/>\nimport logo from &#039;.\/logo.png&#039;;<\/p>\n<p>utils.js \u5185\u5bb9&#xff1a;<\/p>\n<p>export function add(a, b) {<br \/>\n  return a &#043; b;<br \/>\n}<\/p>\n<p>\u00a0Webpack \u4f1a\u751f\u6210\u7684\u4f9d\u8d56\u56fe\u5982\u4e0b&#xff1a;<\/p>\n<p>            [index.js]<br \/>\n           \/    |     \\\\<br \/>\n          \u2193     \u2193      \u2193<br \/>\n    [style.css][utils.js][logo.png]<\/p>\n<ul>\n<li>\n<p>index.js \u662f\u5165\u53e3<\/p>\n<\/li>\n<li>\n<p>\u5b83\u4f9d\u8d56\u4e86\u4e09\u4e2a\u6a21\u5757&#xff1a;<\/p>\n<ul>\n<li>\n<p>style.css \u2192 \u7531 css-loader \u548c style-loader \u5904\u7406<\/p>\n<\/li>\n<li>\n<p>utils.js \u2192 \u6b63\u5e38 JS \u6a21\u5757<\/p>\n<\/li>\n<li>\n<p>logo.png \u2192 \u88ab file-loader \u6216 url-loader \u8f6c\u6362\u6210\u94fe\u63a5<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<p>\u00a0\u8fd9\u4e2a\u56fe\u5c31\u662f\u6a21\u5757\u4f9d\u8d56\u56fe\u3002Webpack \u4f1a\u6839\u636e\u5b83\u6253\u5305\u65f6\u51b3\u5b9a\u6587\u4ef6\u7684\u7ec4\u7ec7\u987a\u5e8f\u3001\u662f\u5426\u5408\u5e76\u3001\u662f\u5426\u62c6\u5206\u3001\u662f\u5426\u4f18\u5316\u7b49\u3002<\/p>\n<p>\u5982\u679c\u4f60\u5e0c\u671b\u770b\u5230\u4f60\u7684\u9879\u76ee\u771f\u5b9e\u7684\u6a21\u5757\u4f9d\u8d56\u56fe&#xff0c;\u53ef\u4ee5\u4f7f\u7528\u4ee5\u4e0b\u5de5\u5177&#xff1a;webpack-bundle-analyzer<\/p>\n<p>const { BundleAnalyzerPlugin } &#061; require(&#039;webpack-bundle-analyzer&#039;);<br \/>\nplugins: [<br \/>\n  new BundleAnalyzerPlugin()<br \/>\n]<\/p>\n<p>\u5b83\u4f1a\u751f\u6210\u4e00\u4e2a\u4ea4\u4e92\u5f0f\u7f51\u9875&#xff0c;\u5c55\u793a\u6a21\u5757\u7ed3\u6784\u56fe&#xff0c;\u5305\u62ec\u6587\u4ef6\u5927\u5c0f\u3001\u4f9d\u8d56\u5173\u7cfb\u7b49\u3002<\/p>\n<h3 id=\"%C2%A03.%20%E6%A8%A1%E5%9D%97%E8%BD%AC%E6%8D%A2%E4%B8%8E%E8%A7%A3%E6%9E%90\">\u00a03. \u6a21\u5757\u8f6c\u6362\u4e0e\u89e3\u6790<\/h3>\n<ul>\n<li>\n<p>JS \u6587\u4ef6 \u2192 Babel \u8f6c\u8bd1<\/p>\n<\/li>\n<li>\n<p>CSS \u6587\u4ef6 \u2192 CSS loader \u8f6c\u6362\u4e3a JS \u6a21\u5757<\/p>\n<\/li>\n<li>\n<p>\u56fe\u7247 \u2192 file-loader \/ url-loader \u751f\u6210\u53ef\u5bfc\u5165\u7684 URL<\/p>\n<\/li>\n<li>\n<p>\u6bcf\u4e00\u4e2a\u6a21\u5757\u6700\u7ec8\u90fd\u4f1a\u88ab\u8f6c\u6362\u4e3a JS \u51fd\u6570\u6216\u5bf9\u8c61<\/p>\n<\/li>\n<\/ul>\n<p>\u00a0Webpack \u4f1a\u5728\u201c\u6784\u5efa\u6a21\u5757\u56fe\u201d\u7684\u540c\u65f6&#xff0c;\u5bf9\u6bcf\u4e2a\u6a21\u5757\u7acb\u5373\u8fdb\u884c\u201c\u6a21\u5757\u89e3\u6790\u4e0e\u8f6c\u6362\u201d&#xff0c;\u8fd9\u662f\u4e00\u4e2a\u201c\u8fb9\u8d70\u8fb9\u5904\u7406\u201d\u7684\u8fc7\u7a0b\u3002\u7ed3\u5408\u7b2c\u4e8c\u9636\u6bb5<\/p>\n<p>1. \u5165\u53e3 index.js 2. \u8bc6\u522b\u5176\u4f9d\u8d56 [&#039;.\/a.js&#039;, &#039;.\/style.css&#039;] 3. \u89e3\u6790 index.js \u2192 \u4f20\u7ed9 babel-loader \u8f6c\u6362 4. \u8fdb\u5165 a.js&#xff0c;\u627e\u4f9d\u8d56\u5e76\u8f6c\u6362 5. \u8fdb\u5165 style.css \u2192 css-loader \u2192 style-loader 6. \u6784\u5efa\u51fa\u6a21\u5757\u56fe &#043; \u5f97\u5230\u8f6c\u6362\u540e\u7684\u6a21\u5757\u5185\u5bb9<\/p>\n<p>\u00a0\u6240\u4ee5\u5f53 Webpack \u627e\u5230\u4e00\u4e2a\u6a21\u5757\u4e4b\u540e&#xff08;\u5982 style.css\u3001image.png\u3001index.jsx&#xff09;&#xff0c;\u5b83\u8fd8\u4e0d\u80fd\u76f4\u63a5\u6253\u5305\u8fdb JS\u3002Webpack \u5fc5\u987b&#xff1a;\u00a0\u7528 Loader \u8f6c\u6362\u4e3a JS \u6a21\u5757\u683c\u5f0f\u00a0<\/p>\n<p>\u8fd9\u4e00\u6b65\u662f\u771f\u6b63\u201c\u5904\u7406\u6587\u4ef6\u5185\u5bb9\u201d\u7684\u9636\u6bb5\u3002<\/p>\n<h5 id=\"%E7%A4%BA%E4%BE%8B%201%EF%BC%9AJS%20%E6%96%87%E4%BB%B6%EF%BC%88%E5%8F%AF%E8%83%BD%E5%90%AB%20ES6%E3%80%81TS%EF%BC%89\">\u793a\u4f8b 1&#xff1a;JS \u6587\u4ef6&#xff08;\u53ef\u80fd\u542b ES6\u3001TS&#xff09;<\/h5>\n<p>\/\/ \u539f\u59cb\u4ee3\u7801<br \/>\nconst fn &#061; () &#061;&gt; console.log(&#039;hi&#039;);<br \/>\n\/\/ \u7ecf\u8fc7 babel-loader \u8f6c\u6362\u4e3a&#xff1a;<br \/>\nvar fn &#061; function() { return console.log(&#034;hi&#034;); }<\/p>\n<h5 id=\"%E7%A4%BA%E4%BE%8B%202%EF%BC%9ACSS%20%E6%96%87%E4%BB%B6\">\u793a\u4f8b 2&#xff1a;CSS \u6587\u4ef6<\/h5>\n<p>body { color: red; }<\/p>\n<p>\/* css-loader \u8f6c\u6362\u4e3a *\/<br \/>\nmodule.exports &#061; &#034;body { color: red; }&#034;;<\/p>\n<p>\/* style-loader \u518d\u628a\u8fd9\u6bb5 CSS \u63d2\u5165\u5230 &lt;style&gt; \u6807\u7b7e\u4e2d *\/<\/p>\n<h5 id=\"%E7%A4%BA%E4%BE%8B%203%EF%BC%9A%E5%9B%BE%E7%89%87%E6%96%87%E4%BB%B6\">\u793a\u4f8b 3&#xff1a;\u56fe\u7247\u6587\u4ef6<\/h5>\n<p>import img from &#039;.\/logo.png&#039;;<\/p>\n<p>\/* file-loader \u8f6c\u6362\u4e3a *\/<br \/>\nmodule.exports &#061; &#034;2025-05-20sw3sdnwt2a5.png&#034;; <\/p>\n<p>\u00a0&#x1f4cc; Loader \u8d1f\u8d23\u628a\u201c\u975e JS \u6587\u4ef6\u201d\u53d8\u6210 JS \u6a21\u5757&#xff0c;\u6216\u8005\u628a JS \u65b0\u8bed\u6cd5\u53d8\u65e7\u8bed\u6cd5\u3002<\/p>\n<h3 id=\"%C2%A04.%20%E7%94%9F%E6%88%90%E4%BB%A3%E7%A0%81%E5%9D%97%EF%BC%88Chunk%EF%BC%89%E4%B8%8E%E6%96%87%E4%BB%B6%EF%BC%88Asset%EF%BC%89\">\u00a04. \u751f\u6210\u4ee3\u7801\u5757&#xff08;Chunk&#xff09;\u4e0e\u6587\u4ef6&#xff08;Asset&#xff09;<\/h3>\n<ul>\n<li>\n<p>Chunk&#xff1a;\u662f Webpack \u5185\u90e8\u6784\u5efa\u4ea7\u7269&#xff0c;\u5bf9\u5e94\u4e00\u7ec4\u6a21\u5757\u96c6\u5408&#xff08;\u53ef\u7528\u4e8e\u4ee3\u7801\u5206\u5272&#xff09;\u3002<\/p>\n<\/li>\n<li>\n<p>Asset&#xff1a;\u662f\u6700\u7ec8\u751f\u6210\u7684\u6587\u4ef6&#xff0c;\u4f8b\u5982 bundle.js\u3001main.css\u3001\u56fe\u7247\u7b49\u3002<\/p>\n<\/li>\n<\/ul>\n<h4 id=\"1%E3%80%81%20Chunk%EF%BC%88%E4%BB%A3%E7%A0%81%E5%9D%97%EF%BC%89\">1\u3001 Chunk&#xff08;\u4ee3\u7801\u5757&#xff09;<\/h4>\n<ul>\n<li>\n<p>Chunk \u662f Webpack \u6784\u5efa\u4ea7\u7269\u7684\u903b\u8f91\u5355\u5143&#xff0c;\u4ee3\u8868\u4e00\u4e2a\u6216\u4e00\u7ec4\u6a21\u5757\u7684\u96c6\u5408\u3002<\/p>\n<\/li>\n<li>\n<p>\u6bcf\u4e2a\u5165\u53e3\u6587\u4ef6\u3001\u5f02\u6b65\u6a21\u5757\u3001\u88ab\u5171\u4eab\u7684\u6a21\u5757\u90fd\u4f1a\u751f\u6210\u4e00\u4e2a chunk\u3002<\/p>\n<\/li>\n<li>\n<p>Chunk \u672c\u8d28\u4e0a\u662f\u201c\u6a21\u5757\u6253\u5305\u4e2d\u95f4\u7ed3\u679c\u201d&#xff0c;\u6700\u7ec8\u4f1a\u8f6c\u5316\u4e3a\u4e00\u4e2a\u6216\u591a\u4e2a Asset \u6587\u4ef6\u3002<\/p>\n<\/li>\n<\/ul>\n<h5 id=\"%E5%B8%B8%E8%A7%81%E7%9A%84%20Chunk%20%E7%B1%BB%E5%9E%8B%EF%BC%9A\">\u5e38\u89c1\u7684 Chunk \u7c7b\u578b&#xff1a;<\/h5>\n<table>\n<tr>\u7c7b\u578b\u793a\u4f8b<\/tr>\n<tbody>\n<tr>\n<td>Entry Chunk<\/td>\n<td>\u5165\u53e3\u6587\u4ef6\u6784\u5efa\u7684 chunk&#xff08;\u5982 main.js&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>Lazy Chunk<\/td>\n<td>\u52a8\u6001\u5bfc\u5165\u7684\u6a21\u5757&#xff08;\u5982 import(&#039;.\/modal&#039;)&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>Vendor Chunk<\/td>\n<td>\u88ab\u591a\u4e2a\u5165\u53e3\u5171\u4eab\u7684\u7b2c\u4e09\u65b9\u5e93&#xff08;\u5982 react, lodash&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>Runtime Chunk<\/td>\n<td>Webpack \u8fd0\u884c\u65f6\u4ee3\u7801&#xff08;\u5982 webpackRuntime.js&#xff09;<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u00a0Chunk \u662f\u6a21\u5757\u7684\u96c6\u5408&#xff0c;\u8fd9\u4e9b\u6a21\u5757\u6709\u201c\u67d0\u79cd\u5173\u7cfb\u201d&#xff0c;\u6240\u4ee5\u88ab\u6253\u6210\u4e00\u5757\u513f&#xff0c;\u751f\u6210\u4e00\u4e2a JS \u6587\u4ef6&#xff08;\u6216 CSS \u6587\u4ef6&#xff09;\u3002<\/p>\n<p>\u60f3\u8c61\u4f60\u5728\u6253\u5305\u642c\u5bb6&#xff0c;\u6709\u5f88\u591a\u5c0f\u7269\u54c1&#xff08;\u6a21\u5757&#xff09;&#xff0c;\u4f60\u4e0d\u53ef\u80fd\u4e00\u4e2a\u4e00\u4e2a\u5e26&#xff0c;\u800c\u662f&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u628a\u76f8\u5173\u7684\u4e1c\u897f\u6253\u8fdb\u4e00\u4e2a\u7bb1\u5b50&#xff08;chunk&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u6bcf\u4e2a\u7bb1\u5b50\u8d34\u4e00\u4e2a\u6807\u7b7e&#xff08;chunk \u540d\u5b57&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u6700\u540e\u5c01\u7bb1\u3001\u6253\u5305&#xff08;\u751f\u6210 asset \u6587\u4ef6&#xff09;<\/p>\n<\/li>\n<\/ul>\n<p>Webpack \u5c31\u662f\u5728\u6253\u5305\u9879\u76ee\u7684\u6a21\u5757&#xff0c;\u5b83\u6839\u636e**\u201c\u6a21\u5757\u4e4b\u95f4\u7684\u5f15\u7528\u5173\u7cfb\u201d**\u6765\u51b3\u5b9a\u54ea\u4e9b\u6a21\u5757\u4e00\u8d77\u653e\u8fdb\u540c\u4e00\u4e2a\u7bb1\u5b50&#xff08;chunk&#xff09;&#xff0c;\u518d\u628a\u8fd9\u4e9b\u7bb1\u5b50\u8f93\u51fa\u6210 .js\u3001.css \u6587\u4ef6\u7b49\u3002<\/p>\n<h5 id=\"%C2%A0%F0%9F%94%81%20%E4%B8%BE%E4%B8%AA%E4%BE%8B%E5%AD%90\">\u00a0&#x1f501; \u4e3e\u4e2a\u4f8b\u5b50<\/h5>\n<p>src\/<br \/>\n\u251c\u2500\u2500 index.js          \/\/ \u5165\u53e3<br \/>\n\u251c\u2500\u2500 a.js<br \/>\n\u251c\u2500\u2500 b.js<br \/>\n\u2514\u2500\u2500 c.js<\/p>\n<p>\u00a0index.js<\/p>\n<p>import &#039;.\/a.js&#039;;<br \/>\nimport(&#039;.\/b.js&#039;); \/\/ \u52a8\u6001\u5bfc\u5165<\/p>\n<p>a.js<\/p>\n<p>console.log(&#039;a&#039;); <\/p>\n<p>\u00a0b.js<\/p>\n<p>import &#039;.\/c.js&#039;;<br \/>\nconsole.log(&#039;b&#039;);<\/p>\n<p>\u00a0Webpack \u6253\u5305\u65f6\u4f1a\u600e\u4e48\u5904\u7406&#xff1f;<\/p>\n<p>index.js \u662f\u5165\u53e3 \u2192 \u5b83\u4f1a\u751f\u6210\u4e00\u4e2a \u5165\u53e3 Chunk&#xff0c;\u6211\u4eec\u53eb\u5b83 main\u3002<\/p>\n<p>\u5b83\u5305\u542b&#xff1a;&#xff08;\u56e0\u4e3a a.js \u662f\u540c\u6b65\u5bfc\u5165\u7684&#xff09;<\/p>\n<p>main chunk: &#8211; index.js &#8211; a.js<\/p>\n<p>b.js \u662f\u52a8\u6001\u5bfc\u5165&#xff08;import()&#xff09; \u2192 \u5b83\u4f1a\u751f\u6210\u4e00\u4e2a \u61d2\u52a0\u8f7d Chunk&#xff0c;\u5355\u72ec\u6253\u5305\u3002<\/p>\n<p>\u00a0chunk-b: &#8211; b.js &#8211; c.js<\/p>\n<p>&#xff08;\u56e0\u4e3a b.js \u548c c.js \u662f\u4e00\u8d77\u7684\u3001\u5728\u88ab\u70b9\u51fb\u65f6\u4e00\u8d77\u52a0\u8f7d&#xff09;<\/p>\n<p>&#x1f3af; \u6253\u5305\u540e\u4f1a\u751f\u6210\u54ea\u4e9b\u6587\u4ef6&#xff08;Asset&#xff09;&#xff1f;<\/p>\n<p>\u6700\u7ec8\u8f93\u51fa&#xff1a;<\/p>\n<p>\/dist \u251c\u2500\u2500 main.[hash].js \u00a0 \u00a0 \u2190 \u5165\u53e3 chunk&#xff0c;\u5bf9\u5e94 index &#043; a \u251c\u2500\u2500 chunk-b.[hash].js \u00a0\u2190 \u52a8\u6001 chunk&#xff0c;\u5bf9\u5e94 b &#043; c<\/p>\n<h5 id=\"%E4%B8%BA%E4%BB%80%E4%B9%88%E8%A6%81%E6%8A%8A%E4%BB%A3%E7%A0%81%E5%88%86%E6%88%90%E5%A4%9A%E4%B8%AA%20chunk%EF%BC%9F\">\u4e3a\u4ec0\u4e48\u8981\u628a\u4ee3\u7801\u5206\u6210\u591a\u4e2a chunk&#xff1f;<\/h5>\n<h6 id=\"1.%20%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%EF%BC%9A\">1. \u6027\u80fd\u4f18\u5316&#xff1a;<\/h6>\n<ul>\n<li>\n<p>\u9996\u9875\u52a0\u8f7d\u53ea\u52a0\u8f7d\u5fc5\u8981\u6a21\u5757&#xff08;index &#043; a&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u7528\u6237\u70b9\u51fb\u529f\u80fd\u65f6&#xff0c;\u518d\u61d2\u52a0\u8f7d&#xff08;b &#043; c&#xff09;<\/p>\n<\/li>\n<\/ul>\n<h6 id=\"2.%20%E7%BC%93%E5%AD%98%E4%BC%98%E5%8C%96%EF%BC%9A\">2. \u7f13\u5b58\u4f18\u5316&#xff1a;<\/h6>\n<ul>\n<li>\n<p>\u4e0d\u540c chunk \u5bf9\u5e94\u4e0d\u540c hash \u540d\u5b57<\/p>\n<\/li>\n<li>\n<p>\u4fee\u6539 b.js \u4e0d\u4f1a\u5f71\u54cd main.js \u7684\u7f13\u5b58<\/p>\n<\/li>\n<\/ul>\n<h4 id=\"%C2%A02%E3%80%81Asset%EF%BC%88%E6%9C%80%E7%BB%88%E4%BA%A7%E5%87%BA%E8%B5%84%E6%BA%90%E6%96%87%E4%BB%B6%EF%BC%89\" style=\"background-color:transparent\">\u00a02\u3001Asset&#xff08;\u6700\u7ec8\u4ea7\u51fa\u8d44\u6e90\u6587\u4ef6&#xff09;<\/h4>\n<ul>\n<li>\n<p>Asset \u662f Webpack \u8f93\u51fa\u5230\u78c1\u76d8\u7684\u6587\u4ef6&#xff1a;\u5982 bundle.js\u3001main.css\u3001logo.png<\/p>\n<\/li>\n<li>\n<p>\u5b83\u662f Chunk \u7684\u6700\u7ec8\u5f62\u6001&#xff08;\u7ecf\u8fc7 loader\/plugin \u5904\u7406\u540e\u7684\u6587\u4ef6\u7ed3\u679c&#xff09;<\/p>\n<\/li>\n<\/ul>\n<p>\u00a0\u6a21\u5757\u4f9d\u8d56\u56fe&#xff08;\u8c01\u4f9d\u8d56\u8c01&#xff09; \u00a0 \u00a0\u2193 \u6bcf\u4e2a\u6a21\u5757\u7528 loader \u8f6c\u6362 \u00a0 \u00a0\u2193 \u6a21\u5757\u88ab\u5206\u7ec4\u4e3a chunk&#xff08;\u6309\u7b56\u7565&#xff09; \u00a0 \u00a0\u2193 chunk \u8f6c\u6362\u4e3a asset&#xff08;\u6700\u7ec8\u8f93\u51fa\u6587\u4ef6&#xff09;<\/p>\n<p>\u00a0Webpack \u5982\u4f55\u751f\u6210 Chunk \u4e0e Asset&#xff1f;<\/p>\n<p>\u00a0\u6839\u636e Module Graph \u62c6\u5206 Chunk<\/p>\n<ul>\n<li>\n<p>Webpack \u4f1a\u904d\u5386\u6574\u4e2a\u6a21\u5757\u4f9d\u8d56\u56fe&#xff0c;\u786e\u5b9a\u54ea\u4e9b\u6a21\u5757\u5c5e\u4e8e\u54ea\u4e2a chunk\u3002<\/p>\n<\/li>\n<li>\n<p>\u5e94\u7528\u5206\u5305\u7b56\u7565&#xff08;SplitChunksPlugin\u3001\u52a8\u6001\u5bfc\u5165&#xff09;\u6765\u8fdb\u884c chunk \u62c6\u5206\u3002<\/p>\n<\/li>\n<li>\n<p>\u4e00\u822c\u6bcf\u4e2a\u5165\u53e3\u6216\u5f02\u6b65\u6a21\u5757\u4f1a\u751f\u6210\u4e00\u4e2a chunk\u3002<\/p>\n<\/li>\n<\/ul>\n<p>&#x1f4cc; \u4f60\u52a8\u6001\u5bfc\u5165\u6a21\u5757\u65f6&#xff0c;Webpack \u4f1a\u4e3a\u5176\u751f\u6210\u4e00\u4e2a\u5355\u72ec\u7684 chunk \u6587\u4ef6&#xff08;\u5b9e\u73b0\u61d2\u52a0\u8f7d&#xff09;\u3002<\/p>\n<h4 id=\"3.%20Chunk%20%E8%BD%AC%E6%8D%A2%E4%B8%BA%20Asset%EF%BC%88%C2%A0%20bundle%EF%BC%89\" style=\"background-color:transparent\">3. Chunk \u8f6c\u6362\u4e3a Asset&#xff08;\u00a0 bundle&#xff09;<\/h4>\n<ul>\n<li>\n<p>Chunk \u53ea\u662f\u201c\u903b\u8f91\u7ed3\u6784\u201d&#xff0c;Webpack \u9700\u8981\u5c06\u5b83\u4eec\u8f6c\u6362\u4e3a JS\/CSS\/\u8d44\u6e90\u6587\u4ef6&#xff08;Asset&#xff09;\u3002<\/p>\n<\/li>\n<li>\n<p>\u901a\u8fc7\u63d2\u4ef6&#xff08;\u5982 MiniCssExtractPlugin&#xff09;\u6216\u81ea\u8eab\u6a21\u677f\u7cfb\u7edf&#xff0c;Webpack \u5c06&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u5404 chunk \u5408\u5e76\u6210\u5b57\u7b26\u4e32\u5185\u5bb9<\/p>\n<\/li>\n<li>\n<p>\u8f93\u51fa JS \u6587\u4ef6&#xff08;\u5982 main.[hash].js&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u8f93\u51fa CSS \u6587\u4ef6&#xff08;\u5982 style.[contenthash].css&#xff09;<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h4 id=\"4.%20%E8%BE%93%E5%87%BA%20Asset%20%E5%88%B0%20output.path\" style=\"background-color:transparent\">4. \u8f93\u51fa Asset \u5230 output.path<\/h4>\n<p>\u6700\u7ec8\u6240\u6709 Asset \u6587\u4ef6\u5199\u5165\u786c\u76d8\u6216\u5f00\u53d1\u670d\u52a1\u5668\u7684\u5185\u5b58&#xff1a;<\/p>\n<p>output: {<br \/>\n  filename: &#039;[name].[contenthash].js&#039;,<br \/>\n  path: path.resolve(__dirname, &#039;dist&#039;)<br \/>\n}<\/p>\n<h3 id=\"5.%20%E8%BE%93%E5%87%BA%E9%98%B6%E6%AE%B5%EF%BC%88Emit%EF%BC%89\" style=\"background-color:transparent\">5. \u8f93\u51fa\u9636\u6bb5&#xff08;Emit&#xff09;<\/h3>\n<ul>\n<li>\n<p>\u6240\u6709\u7684 Asset \u6587\u4ef6\u5199\u5165\u5230\u914d\u7f6e\u7684 output.path \u76ee\u5f55\u4e2d<\/p>\n<\/li>\n<li>\n<p>\u63d2\u4ef6&#xff08;\u5982 HtmlWebpackPlugin&#xff09;\u53ef\u5728\u6b64\u9636\u6bb5\u4fee\u6539\/\u751f\u6210\u8d44\u6e90<\/p>\n<\/li>\n<\/ul>\n<p>\u6211\u4eec\u4e86\u89e3\u4e86webpack\u7684\u6784\u5efa\u8fc7\u7a0b\u4ee5\u540e&#xff0c;\u6211\u4eec\u8fd8\u8981\u4e86\u89e3\u4e00\u4e0bwebpack\u7684\u63d2\u4ef6\u673a\u5236<\/p>\n<h2 id=\"%E4%B8%89%E3%80%81%E6%8F%92%E4%BB%B6%E6%9C%BA%E5%88%B6\">\u4e09\u3001\u63d2\u4ef6\u673a\u5236<\/h2>\n<p>Webpack \u7684\u63d2\u4ef6\u673a\u5236\u8d2f\u7a7f\u6574\u4e2a\u6784\u5efa\u751f\u547d\u5468\u671f&#xff0c;\u4f46\u5b83\u7684\u201c\u6ce8\u518c\u201d\u548c\u201c\u6fc0\u6d3b\u201d\u5206\u522b\u53d1\u751f\u5728\u4e0d\u540c\u7684\u9636\u6bb5\u3002<\/p>\n<h3 id=\"1%E3%80%81%E6%8F%92%E4%BB%B6%E2%80%9C%E6%B3%A8%E5%86%8C%E2%80%9D%E5%8F%91%E7%94%9F%E5%9C%A8%20%E2%80%94%E2%80%94%20%E2%9C%85%20%E5%88%9D%E5%A7%8B%E5%8C%96%E9%98%B6%E6%AE%B5%EF%BC%88Initialization%EF%BC%89\">1\u3001\u63d2\u4ef6\u201c\u6ce8\u518c\u201d\u53d1\u751f\u5728 \u2014\u2014 \u2705 \u521d\u59cb\u5316\u9636\u6bb5&#xff08;Initialization&#xff09;<\/h3>\n<p>Webpack \u4f1a\u8bfb\u53d6 webpack.config.js \u91cc\u7684 plugins \u6570\u7ec4&#xff0c;\u5e76\u5bf9\u6bcf\u4e00\u4e2a\u63d2\u4ef6\u6267\u884c&#xff1a;<\/p>\n<p>plugin.apply(compiler);<\/p>\n<p>\u4e5f\u5c31\u662f\u8bf4&#xff0c;\u6bcf\u4e2a\u63d2\u4ef6\u901a\u8fc7 .apply(compiler) \u65b9\u6cd5\u6ce8\u518c\u5230 \u751f\u547d\u5468\u671f\u94a9\u5b50\u4e0a&#xff08;Hooks&#xff09;\u3002<\/p>\n<p>&#x1f527; \u8fd9\u4e9b\u94a9\u5b50\u90fd\u6302\u5728 Webpack \u7684 Compiler \u6216 Compilation \u5bf9\u8c61\u4e0a&#xff0c;\u7531 Tapable \u63d0\u4f9b\u4e8b\u4ef6\u53d1\u5e03\u8ba2\u9605\u673a\u5236\u3002<\/p>\n<p>&#x1f4cc; \u6240\u4ee5&#xff0c;\u201c\u63d2\u4ef6\u673a\u5236\u201d\u7684\u51c6\u5907\u9636\u6bb5\u5c31\u5728\u521d\u59cb\u5316\u9636\u6bb5\u5b8c\u6210\u4e86\u3002<\/p>\n<h3 id=\"2%E3%80%81%E6%8F%92%E4%BB%B6%E2%80%9C%E6%89%A7%E8%A1%8C%E2%80%9D%E5%8F%91%E7%94%9F%E5%9C%A8%20%E2%80%94%E2%80%94%20%E2%9C%85%20%E6%9E%84%E5%BB%BA%E8%BF%87%E7%A8%8B%E7%9A%84%E6%AF%8F%E4%B8%80%E4%B8%AA%E9%98%B6%E6%AE%B5%EF%BC%88Build%20Lifecycle%EF%BC%89\">2\u3001\u63d2\u4ef6\u201c\u6267\u884c\u201d\u53d1\u751f\u5728 \u2014\u2014 \u2705 \u6784\u5efa\u8fc7\u7a0b\u7684\u6bcf\u4e00\u4e2a\u9636\u6bb5&#xff08;Build Lifecycle&#xff09;<\/h3>\n<p>\u6ce8\u518c\u53ea\u662f\u5f00\u59cb&#xff0c;\u771f\u6b63\u8ba9\u63d2\u4ef6\u8d77\u4f5c\u7528&#xff0c;\u662f\u5f53 Webpack \u6784\u5efa\u6d41\u7a0b\u8fdb\u5165\u5177\u4f53\u67d0\u4e2a\u9636\u6bb5\u65f6&#xff0c;\u4f1a\u8c03\u7528\u5bf9\u5e94\u7684\u94a9\u5b50&#xff0c;\u63d2\u4ef6\u5c31\u201c\u88ab\u5524\u9192\u201d\u5e76\u6267\u884c\u5b83\u7684\u903b\u8f91\u3002<\/p>\n<p>\u00a0\u63d2\u4ef6\u53d1\u6325\u4f5c\u7528\u7684\u5178\u578b\u9636\u6bb5\u6709&#xff1a;<\/p>\n<table>\n<tr>\u6784\u5efa\u9636\u6bb5\u751f\u547d\u5468\u671f\u94a9\u5b50&#xff08;hook&#xff09;\u63d2\u4ef6\u53ef\u80fd\u505a\u7684\u4e8b\u60c5<\/tr>\n<tbody>\n<tr>\n<td>\u6784\u5efa\u542f\u52a8<\/td>\n<td>compiler.hooks.run<\/td>\n<td>\u6253\u5370\u5f00\u59cb\u6807\u5fd7<\/td>\n<\/tr>\n<tr>\n<td>\u7f16\u8bd1\u6a21\u5757\u56fe\u524d<\/td>\n<td>compiler.hooks.beforeCompile<\/td>\n<td>\u6ce8\u5165\u989d\u5916\u4f9d\u8d56<\/td>\n<\/tr>\n<tr>\n<td>\u521b\u5efa Compilation<\/td>\n<td>compiler.hooks.compilation<\/td>\n<td>\u64cd\u4f5c\u6a21\u5757\u5904\u7406\u903b\u8f91<\/td>\n<\/tr>\n<tr>\n<td>\u6a21\u5757\u751f\u6210\u5b8c\u6bd5<\/td>\n<td>compilation.hooks.buildModule<\/td>\n<td>\u4fee\u6539\u6a21\u5757\u6e90\u7801<\/td>\n<\/tr>\n<tr>\n<td>\u8d44\u6e90\u8f93\u51fa\u524d<\/td>\n<td>compilation.hooks.emit<\/td>\n<td>\u6dfb\u52a0\/\u4fee\u6539\u751f\u6210\u6587\u4ef6<\/td>\n<\/tr>\n<tr>\n<td>\u6784\u5efa\u7ed3\u675f<\/td>\n<td>compiler.hooks.done<\/td>\n<td>\u8f93\u51fa\u7edf\u8ba1\u4fe1\u606f\u6216\u6e05\u7406<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u6240\u4ee5\u63d2\u4ef6\u673a\u5236\u5728\u6784\u5efa\u671f\u95f4\u662f\u4e8b\u4ef6\u9a71\u52a8\u7684&#xff0c;\u6839\u636e\u6784\u5efa\u201c\u8d70\u5230\u54ea\u4e00\u6b65\u201d\u89e6\u53d1\u54ea\u4e2a\u63d2\u4ef6\u00a0<\/p>\n<p>\u793a\u4f8b&#xff1a;HtmlWebpackPlugin \u63d2\u4ef6\u5982\u4f55\u63a5\u5165\u673a\u5236&#xff1f;\u00a0<\/p>\n<p>plugins: [<br \/>\n  new HtmlWebpackPlugin({ template: &#039;.\/index.html&#039; })<br \/>\n] <\/p>\n<p>\u8fd9\u4e2a\u63d2\u4ef6\u4f1a&#xff1a;<\/p>\n<li>\n<p>\u5728 compiler.hooks.thisCompilation \u6ce8\u518c\u4e8b\u4ef6<\/p>\n<\/li>\n<li>\n<p>\u5728 compilation.hooks.processAssets \u9636\u6bb5&#xff0c;\u63d2\u5165\u4e00\u4e2a\u751f\u6210\u7684 HTML \u6587\u4ef6\u4f5c\u4e3a asset<\/p>\n<\/li>\n<p>\u00a0\u6240\u4ee5\u5b83\u6ce8\u518c\u5728\u521d\u59cb\u5316\u9636\u6bb5&#xff0c;\u88ab\u8c03\u7528\u5728\u8d44\u6e90\u751f\u6210\u9636\u6bb5&#xff08;emit \u524d&#xff09;\u3002<\/p>\n<p>compilation \u662f Webpack \u6bcf\u6b21\u6784\u5efa\u65f6\u7528\u6765 \u5904\u7406\u6a21\u5757\u3001\u751f\u6210 chunk\u3001\u8f93\u51fa\u6587\u4ef6&#xff08;asset&#xff09; \u7684\u5bf9\u8c61&#xff0c;\u5b83\u4ee3\u8868\u4e86\u4e00\u6b21\u201c\u6784\u5efa\u8d44\u6e90\u7684\u5177\u4f53\u8fc7\u7a0b\u201d\u3002<\/p>\n<p>\u4e0e compiler \u7684\u5173\u7cfb<\/p>\n<table>\n<tr>\u5bf9\u8c61\u63cf\u8ff0<\/tr>\n<tbody>\n<tr>\n<td>compiler<\/td>\n<td>\u5168\u5c40\u6784\u5efa\u5bf9\u8c61&#xff0c;\u8d2f\u7a7f\u6574\u4e2a\u6784\u5efa\u751f\u547d\u5468\u671f&#xff08;\u53ea\u521b\u5efa\u4e00\u6b21&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>compilation<\/td>\n<td>\u8868\u793a\u4e00\u6b21\u201c\u7f16\u8bd1\u8fc7\u7a0b\u201d&#xff0c;\u53ef\u80fd\u6709\u591a\u6b21&#xff08;\u5982\u76d1\u542c\u6a21\u5f0f\u4e2d\u6bcf\u6b21\u53d8\u5316\u90fd\u4f1a\u91cd\u65b0\u521b\u5efa&#xff09;<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>&#x1f4cc; \u6362\u53e5\u8bdd\u8bf4&#xff1a;<\/p>\n<ul>\n<li>\n<p>compiler \u662f\u6784\u5efa\u7ba1\u7406\u8005&#xff08;\u603b\u63a7&#xff09;<\/p>\n<\/li>\n<li>\n<p>compilation \u662f\u5b9e\u9645\u5e72\u6d3b\u7684\u5de5\u4eba&#xff08;\u8d1f\u8d23\u6a21\u5757\u3001chunk\u3001asset \u7684\u751f\u6210&#xff09;<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"3%E3%80%81compilation\">3\u3001compilation<\/h3>\n<p>compilation \u4e3b\u8981\u5305\u542b\u4ec0\u4e48\u529f\u80fd&#xff1f;<\/p>\n<p>Webpack \u4f1a\u4f7f\u7528 compilation \u505a\u4ee5\u4e0b\u4e8b\u60c5&#xff1a;<\/p>\n<h4 id=\"1.%20%E6%A8%A1%E5%9D%97%E7%9A%84%E7%AE%A1%E7%90%86\">1. \u6a21\u5757\u7684\u7ba1\u7406<\/h4>\n<ul>\n<li>\n<p>\u6240\u6709\u6a21\u5757\u90fd\u88ab\u5c01\u88c5\u4e3a Module \u5bf9\u8c61<\/p>\n<\/li>\n<li>\n<p>\u4fdd\u5b58\u5728 compilation.modules \u4e2d<\/p>\n<\/li>\n<\/ul>\n<h4 id=\"2.%20%E6%9E%84%E5%BB%BA%20Chunk\">2. \u6784\u5efa Chunk<\/h4>\n<ul>\n<li>\n<p>\u5c06\u6a21\u5757\u5206\u7ec4\u4e3a chunk&#xff08;\u5982\u5165\u53e3 chunk\u3001\u5f02\u6b65 chunk&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u4fdd\u5b58\u5728 compilation.chunks \u4e2d<\/p>\n<\/li>\n<\/ul>\n<h4 id=\"3.%20%E7%94%9F%E6%88%90%20Asset%EF%BC%88%E8%BE%93%E5%87%BA%E8%B5%84%E6%BA%90%EF%BC%89\">3. \u751f\u6210 Asset&#xff08;\u8f93\u51fa\u8d44\u6e90&#xff09;<\/h4>\n<ul>\n<li>\n<p>\u5c06 chunk \u8f6c\u6362\u4e3a\u6700\u7ec8\u8981\u8f93\u51fa\u7684 JS\/CSS\/Image \u7b49\u6587\u4ef6<\/p>\n<\/li>\n<li>\n<p>\u4fdd\u5b58\u5728 compilation.assets \u4e2d&#xff08;\u662f\u4e00\u4e2a\u5bf9\u8c61&#xff0c;\u952e\u662f\u6587\u4ef6\u540d&#xff0c;\u503c\u662f\u6587\u4ef6\u5185\u5bb9&#xff09;<\/p>\n<\/li>\n<\/ul>\n<h4 id=\"4.%20Plugin%20%E7%9A%84%E7%94%9F%E5%91%BD%E5%91%A8%E6%9C%9F%E9%92%A9%E5%AD%90\">4. Plugin \u7684\u751f\u547d\u5468\u671f\u94a9\u5b50<\/h4>\n<p>compilation \u81ea\u5df1\u4e5f\u6709\u4e00\u5957 hooks&#xff1a;<\/p>\n<table>\n<tr>Hook \u540d\u79f0\u63cf\u8ff0<\/tr>\n<tbody>\n<tr>\n<td>buildModule<\/td>\n<td>\u6784\u5efa\u6bcf\u4e2a\u6a21\u5757\u65f6\u89e6\u53d1<\/td>\n<\/tr>\n<tr>\n<td>optimizeChunks<\/td>\n<td>\u751f\u6210 chunk \u540e\u4f18\u5316\u65f6\u89e6\u53d1<\/td>\n<\/tr>\n<tr>\n<td>processAssets&#xff08;Webpack 5&#xff09;<\/td>\n<td>\u751f\u6210\u6700\u7ec8\u8d44\u6e90\u524d\u89e6\u53d1<\/td>\n<\/tr>\n<tr>\n<td>seal<\/td>\n<td>\u51c6\u5907\u6253\u5305\u6240\u6709\u6a21\u5757\u548c\u8d44\u6e90\u65f6\u89e6\u53d1<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h2 id=\"%E5%9B%9B%E3%80%81%E9%85%8D%E7%BD%AE%E9%A1%B9%E4%B9%8B%E9%97%B4%E7%9A%84%E7%9B%B8%E4%BA%92%E5%85%B3%E7%B3%BB\">\u56db\u3001\u914d\u7f6e\u9879\u4e4b\u95f4\u7684\u76f8\u4e92\u5173\u7cfb<\/h2>\n<p>\u4e86\u89e3\u4e86\u6784\u5efa\u6d41\u7a0b\u4ee5\u540e \u6211\u4eec\u770b\u770b\u914d\u7f6e\u9879\u4e4b\u95f4\u7684\u76f8\u4e92\u5173\u7cfb<\/p>\n<h3 id=\"1.%20entry%20%E4%B8%8E%20module.rules\">1. entry \u4e0e module.rules<\/h3>\n<ul>\n<li>\n<p>\u5173\u7cfb&#xff1a;Webpack \u4ece entry \u5f00\u59cb\u6784\u5efa\u4f9d\u8d56\u56fe&#xff0c;\u9047\u5230\u5404\u79cd\u7c7b\u578b\u7684\u6587\u4ef6&#xff08;.js, .css, .png&#xff09;\u65f6&#xff0c;\u4f1a\u67e5\u627e module.rules \u4e2d\u7684\u5339\u914d\u89c4\u5219\u3002<\/p>\n<\/li>\n<li>\n<p>\u5b9e\u9645\u6548\u679c&#xff1a;\u6bd4\u5982\u4f60\u5728 index.js \u4e2d\u5f15\u5165\u4e86 style.css&#xff0c;Webpack \u4f1a\u7528 css-loader \u548c style-loader \u6765\u5904\u7406\u5b83\u3002<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"2.%20entry%20%E4%B8%8E%20output\">2. entry \u4e0e output<\/h3>\n<ul>\n<li>\n<p>\u5173\u7cfb&#xff1a;entry \u51b3\u5b9a\u4e86\u6253\u5305\u7684\u8d77\u70b9&#xff1b;output \u51b3\u5b9a\u4e86\u6253\u5305\u7684\u7ec8\u70b9&#xff08;\u6587\u4ef6\u540d\u548c\u8def\u5f84&#xff09;\u3002<\/p>\n<\/li>\n<li>\n<p>\u5b9e\u9645\u6548\u679c&#xff1a;\u5982\u679c\u6709\u591a\u4e2a\u5165\u53e3&#xff0c;output.filename \u5e94\u4f7f\u7528\u5360\u4f4d\u7b26 [name].js \u6765\u5206\u522b\u751f\u6210\u6587\u4ef6\u3002<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"3.%20module.rules%20%E4%B8%8E%20plugins\">3. module.rules \u4e0e plugins<\/h3>\n<ul>\n<li>\n<p>\u5173\u7cfb&#xff1a;rules \u662f\u8d44\u6e90\u7684\u9884\u5904\u7406&#xff1b;plugins \u5219\u662f\u5728\u6574\u4e2a\u6784\u5efa\u8fc7\u7a0b\u4e2d\u63d2\u5165\u903b\u8f91\u6216\u4fee\u6539\u7ed3\u679c\u3002<\/p>\n<\/li>\n<li>\n<p>\u5b9e\u9645\u6548\u679c&#xff1a;\u6bd4\u5982\u901a\u8fc7 css-loader \u628a CSS \u6a21\u5757\u5316&#xff0c;\u7136\u540e\u4f7f\u7528 MiniCssExtractPlugin \u628a\u5b83\u63d0\u53d6\u4e3a\u72ec\u7acb\u6587\u4ef6\u3002<\/p>\n<\/li>\n<\/ul>\n<p>module: {<br \/>\n  rules: [<br \/>\n    { test: \/\\\\.css$\/, use: [MiniCssExtractPlugin.loader, &#039;css-loader&#039;] }<br \/>\n  ]<br \/>\n},<br \/>\nplugins: [<br \/>\n  new MiniCssExtractPlugin({ filename: &#039;[name].css&#039; })<br \/>\n]<\/p>\n<h3 id=\"4.%20mode%20%E4%B8%8E%E5%85%B6%E4%BB%96%E6%89%80%E6%9C%89%E9%85%8D%E7%BD%AE%E9%A1%B9\">4. mode \u4e0e\u5176\u4ed6\u6240\u6709\u914d\u7f6e\u9879<\/h3>\n<ul>\n<li>\n<p>\u5173\u7cfb&#xff1a;mode \u662f\u5168\u5c40\u884c\u4e3a\u5f00\u5173&#xff0c;\u4f1a\u5f71\u54cd&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u662f\u5426\u538b\u7f29\u4ee3\u7801&#xff08;output&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u662f\u5426\u542f\u7528 Tree Shaking&#xff08;module&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u662f\u5426\u663e\u793a SourceMap&#xff08;devtool&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u63d2\u4ef6\u884c\u4e3a&#xff08;\u5982\u4f18\u5316&#xff09;<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>mode \u4e3a &#039;production&#039; \u65f6&#xff0c;\u9ed8\u8ba4\u542f\u7528 TerserPlugin \u538b\u7f29 JS \u548c CssMinimizerPlugin \u538b\u7f29 CSS\u3002<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"5.%20devServer%20%E4%B8%8E%20output\">5. devServer \u4e0e output<\/h3>\n<ul>\n<li>\n<p>\u5173\u7cfb&#xff1a;devServer \u4e0d\u771f\u6b63\u5199\u5165 output.path&#xff0c;\u800c\u662f\u5728\u5185\u5b58\u4e2d\u751f\u6210\u5e76\u6258\u7ba1\u8f93\u51fa\u6587\u4ef6\u3002<\/p>\n<\/li>\n<li>\n<p>\u5b9e\u9645\u6548\u679c&#xff1a;\u66f4\u5feb\u7684\u70ed\u66f4\u65b0&#xff08;HMR&#xff09;&#xff0c;\u9875\u9762\u81ea\u52a8\u5237\u65b0\u3002<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"6.%20plugins%20%E4%B8%8E%20output\">6. plugins \u4e0e output<\/h3>\n<ul>\n<li>\n<p>\u6bd4\u5982 HtmlWebpackPlugin \u63d2\u4ef6\u4f1a\u5728 output \u4e2d\u81ea\u52a8\u6ce8\u5165\u6253\u5305\u540e\u7684\u6587\u4ef6\u8def\u5f84\u548c\u540d\u5b57&#xff08;\u5982 &lt;script src&#061;&#034;bundle.js&#034;&gt;&#xff09;\u3002<\/p>\n<\/li>\n<li>\n<p>\u6587\u4ef6\u540d\u5982\u679c\u5305\u542b hash&#xff0c;\u63d2\u4ef6\u4f1a\u81ea\u52a8\u5904\u7406\u3002<\/p>\n<\/li>\n<\/ul>\n<h2 id=\"%E4%BA%94%E3%80%81%20Loader\">\u4e94\u3001 Loader<\/h2>\n<h3 id=\"1%E3%80%81%E4%BB%80%E4%B9%88%E6%98%AF%20Loader%EF%BC%9F\">1\u3001\u4ec0\u4e48\u662f Loader&#xff1f;<\/h3>\n<p>Loader \u662f Webpack \u7684\u6a21\u5757\u8f6c\u6362\u5668&#xff0c;\u7528\u4e8e\u5c06\u5404\u79cd\u975e JavaScript \u6587\u4ef6\u8f6c\u6362\u4e3a Webpack \u53ef\u4ee5\u7406\u89e3\u7684\u6a21\u5757&#xff08;JavaScript \u6a21\u5757&#xff09;\u3002<\/p>\n<h3 id=\"2%E3%80%81%E4%B8%BA%E4%BB%80%E4%B9%88%E9%9C%80%E8%A6%81%20Loader%EF%BC%9F\">2\u3001\u4e3a\u4ec0\u4e48\u9700\u8981 Loader&#xff1f;<\/h3>\n<p>Webpack \u9ed8\u8ba4\u53ea\u61c2 .js \u548c .json&#xff0c;\u4f46\u9879\u76ee\u4e2d\u5e38\u5e38\u4f7f\u7528&#xff1a;<\/p>\n<ul>\n<li>\n<p>.css\u3001.scss<\/p>\n<\/li>\n<li>\n<p>.ts\u3001.vue<\/p>\n<\/li>\n<li>\n<p>\u56fe\u7247 .png\u3001\u5b57\u4f53 .woff \u7b49<\/p>\n<\/li>\n<\/ul>\n<p>Webpack \u65e0\u6cd5\u76f4\u63a5\u7406\u89e3\u8fd9\u4e9b\u6587\u4ef6&#xff0c;\u6240\u4ee5\u6211\u4eec\u7528 Loader \u6765\u9884\u5904\u7406\u5b83\u4eec \u2192 \u8f6c\u6362\u6210 JS \u6a21\u5757\u3002<\/p>\n<p>\u00a0Loader \u7684\u672c\u8d28&#xff1a;\u662f\u4e00\u4e2a\u51fd\u6570<\/p>\n<p>module.exports &#061; function(source) {<br \/>\n  \/\/ source \u662f\u6587\u4ef6\u539f\u59cb\u5185\u5bb9&#xff08;\u5b57\u7b26\u4e32&#xff09;<br \/>\n  return transformedCode;<br \/>\n}<\/p>\n<p>\u00a0Webpack \u8bfb\u53d6\u6587\u4ef6 \u2192 \u8c03\u7528 Loader \u2192 \u5f97\u5230\u8f6c\u6362\u540e\u7684 JS \u6a21\u5757<\/p>\n<p>\u00a0Loader \u7684\u6267\u884c\u8fc7\u7a0b&#xff08;\u4e32\u884c\u3001\u94fe\u5f0f&#xff09;<\/p>\n<p>\u591a\u4e2a Loader \u7ec4\u5408\u65f6&#xff0c;\u4ece \u53f3\u5230\u5de6&#xff08;\u4ece\u4e0b\u5230\u4e0a&#xff09; \u987a\u5e8f\u6267\u884c&#xff1a;<\/p>\n<p>module: { \u00a0 rules: [ \u00a0 \u00a0 { \u00a0 \u00a0 \u00a0 test: \/\\\\.css$\/, \u00a0 \u00a0 \u00a0 use: [&#039;style-loader&#039;, &#039;css-loader&#039;] \u00a0 \u00a0 } \u00a0 ] } \u6267\u884c\u987a\u5e8f\u662f&#xff1a;css-loader \u2192 style-loader&#061;<\/p>\n<p id=\"%E5%88%86%E5%B7%A5%EF%BC%9A\" style=\"background-color:transparent\">\u5206\u5de5&#xff1a;<\/p>\n<ul>\n<li>\n<p>css-loader&#xff1a;\u628a CSS \u8f6c\u6210 JS \u5b57\u7b26\u4e32\u6a21\u5757<\/p>\n<\/li>\n<li>\n<p>style-loader&#xff1a;\u628a\u5b57\u7b26\u4e32\u63d2\u5165\u5230\u9875\u9762 &lt;style&gt; \u6807\u7b7e\u4e2d<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"3%E3%80%81%E5%B8%B8%E8%A7%81%20Loader%20%E7%B1%BB%E5%9E%8B\" style=\"background-color:transparent\">3\u3001\u5e38\u89c1 Loader \u7c7b\u578b<\/h3>\n<table>\n<tr>\u7c7b\u578bLoader \u540d\u79f0\u529f\u80fd<\/tr>\n<tbody>\n<tr>\n<td>JS \u8f6c\u8bd1<\/td>\n<td>babel-loader<\/td>\n<td>\u8f6c\u6362 ES6\/TS \u7b49<\/td>\n<\/tr>\n<tr>\n<td>\u6837\u5f0f\u5904\u7406<\/td>\n<td>css-loader, style-loader, sass-loader<\/td>\n<td>\u652f\u6301 CSS\/SASS<\/td>\n<\/tr>\n<tr>\n<td>\u6587\u4ef6\u8d44\u6e90<\/td>\n<td>file-loader, url-loader, asset modules&#xff08;Webpack 5&#xff09;<\/td>\n<td>\u5904\u7406\u56fe\u7247\/\u5b57\u4f53<\/td>\n<\/tr>\n<tr>\n<td>Vue\/React<\/td>\n<td>vue-loader, &#064;svgr\/webpack<\/td>\n<td>\u652f\u6301\u6846\u67b6\u7ec4\u4ef6\u6587\u4ef6<\/td>\n<\/tr>\n<tr>\n<td>Markdown<\/td>\n<td>markdown-loader<\/td>\n<td>\u652f\u6301 md \u6587\u4ef6\u8f6c HTML<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h5 id=\"%C2%A0%E4%BB%80%E4%B9%88%E6%98%AF%20babel-loader%EF%BC%9F\" style=\"background-color:transparent\">1\u3001 \u4ec0\u4e48\u662f babel-loader&#xff1f;<\/h5>\n<p>babel-loader \u662f Webpack \u548c Babel \u7684\u6865\u6881&#xff0c;\u8ba9 Webpack \u53ef\u4ee5\u5728\u6253\u5305\u65f6\u8c03\u7528 Babel \u8fdb\u884c\u4ee3\u7801\u8f6c\u8bd1\u3002\u5b83\u672c\u8eab\u5e76\u4e0d\u6267\u884c\u8bed\u6cd5\u8f6c\u6362&#xff0c;\u800c\u662f\u5c06\u6587\u4ef6\u4f20\u9012\u7ed9 Babel&#xff0c;Babel \u518d\u901a\u8fc7\u914d\u7f6e&#xff08;\u5982 .babelrc&#xff09;\u5b8c\u6210\u771f\u6b63\u7684\u8f6c\u6362\u3002<\/p>\n<h5 id=\"%E4%BD%A0%E4%B8%BA%E4%BB%80%E4%B9%88%E9%9C%80%E8%A6%81%20babel-loader%EF%BC%9F\">2\u3001\u4f60\u4e3a\u4ec0\u4e48\u9700\u8981 babel-loader&#xff1f;<\/h5>\n<p>\u73b0\u4ee3\u524d\u7aef\u9879\u76ee\u901a\u5e38\u4f7f\u7528&#xff1a;<\/p>\n<ul>\n<li>\n<p>ES6&#043; \u65b0\u8bed\u6cd5&#xff08;\u5982\u7bad\u5934\u51fd\u6570\u3001\u7c7b\u3001\u6a21\u5757&#xff09;<\/p>\n<\/li>\n<li>\n<p>JSX&#xff08;React&#xff09;<\/p>\n<\/li>\n<li>\n<p>TypeScript&#xff08;\u7ed3\u5408 &#064;babel\/preset-typescript&#xff09;<\/p>\n<\/li>\n<\/ul>\n<p>\u8fd9\u4e9b\u8bed\u6cd5\u4e0d\u662f\u6240\u6709\u6d4f\u89c8\u5668\u90fd\u652f\u6301&#xff08;\u5c24\u5176\u662f IE \/ \u8001\u65e7 Android \u6d4f\u89c8\u5668&#xff09;\u3002\u6240\u4ee5\u6211\u4eec\u9700\u8981 Babel &#043; babel-loader \u6765 \u5411\u4e0b\u7f16\u8bd1&#xff0c;\u4ee5\u786e\u4fdd\u517c\u5bb9\u6027\u3002<\/p>\n<p>\u00a0\u5982\u4f55\u914d\u7f6e babel-loader&#xff1f;<\/p>\n<p>npm install babel-loader &#064;babel\/core &#064;babel\/preset-env &#8211;save-dev<br \/>\n\u5982\u679c\u4f60\u662f React \u9879\u76ee&#xff0c;\u8fd8\u9700\u8981&#xff1a;<br \/>\nnpm install &#064;babel\/preset-react &#8211;save-dev<br \/>\n\u5982\u679c\u662f TypeScript \u9879\u76ee&#xff0c;\u8fd8\u9700\u8981&#xff1a;<br \/>\nnpm install &#064;babel\/preset-typescript &#8211;save-dev <\/p>\n<p>\u00a0Webpack \u914d\u7f6e\u793a\u4f8b&#xff1a;<\/p>\n<p>module.exports &#061; {<br \/>\n  module: {<br \/>\n    rules: [<br \/>\n      {<br \/>\n        test: \/\\\\.js$\/,                \/\/ \u5339\u914d JS \u6587\u4ef6<br \/>\n        exclude: \/node_modules\/,      \/\/ \u4e0d\u5904\u7406\u4f9d\u8d56\u5e93<br \/>\n        use: {<br \/>\n          loader: &#039;babel-loader&#039;,<br \/>\n          options: {<br \/>\n            presets: [&#039;&#064;babel\/preset-env&#039;] \/\/ \u4f7f\u7528\u7684\u8f6c\u6362\u9884\u8bbe<br \/>\n          }<br \/>\n        }<br \/>\n      }<br \/>\n    ]<br \/>\n  }<br \/>\n};<\/p>\n<h5 id=\"3%E3%80%81%E6%A0%B8%E5%BF%83%E6%A6%82%E5%BF%B5%E8%AF%B4%E6%98%8E\" style=\"background-color:transparent\">3\u3001\u6838\u5fc3\u6982\u5ff5\u8bf4\u660e<\/h5>\n<table>\n<tr>\u6982\u5ff5\u542b\u4e49<\/tr>\n<tbody>\n<tr>\n<td>&#064;babel\/core<\/td>\n<td>Babel \u7684\u6838\u5fc3\u5e93&#xff0c;\u6267\u884c\u8f6c\u6362<\/td>\n<\/tr>\n<tr>\n<td>babel-loader<\/td>\n<td>Webpack \u7684\u6865\u63a5\u5668&#xff0c;\u8c03\u7528 Babel<\/td>\n<\/tr>\n<tr>\n<td>preset-env<\/td>\n<td>\u6839\u636e\u76ee\u6807\u6d4f\u89c8\u5668\u81ea\u52a8\u9009\u62e9\u8f6c\u6362\u63d2\u4ef6<\/td>\n<\/tr>\n<tr>\n<td>preset-react<\/td>\n<td>\u8f6c\u6362 React \u7684 JSX<\/td>\n<\/tr>\n<tr>\n<td>exclude: \/node_modules\/<\/td>\n<td>\u9632\u6b62 Babel \u8f6c\u6362\u7b2c\u4e09\u65b9\u5e93&#xff08;\u63d0\u9ad8\u6027\u80fd&#xff09;<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h5 id=\"4%E3%80%81%E5%B8%B8%E8%A7%81%E7%94%A8%E9%80%94\">4\u3001\u5e38\u89c1\u7528\u9014<\/h5>\n<table>\n<tr>\u4f7f\u7528\u573a\u666fBabel preset<\/tr>\n<tbody>\n<tr>\n<td>ES6&#043; \u8f6c ES5<\/td>\n<td>&#064;babel\/preset-env<\/td>\n<\/tr>\n<tr>\n<td>JSX \u8f6c\u4e49<\/td>\n<td>&#064;babel\/preset-react<\/td>\n<\/tr>\n<tr>\n<td>TypeScript<\/td>\n<td>&#064;babel\/preset-typescript<\/td>\n<\/tr>\n<tr>\n<td>Polyfill&#xff08;\u5982 Promise&#xff09;<\/td>\n<td>\u914d\u5408 &#064;babel\/polyfill \u6216 core-js<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h3 id=\"4%E3%80%81Webpack%20%E5%A6%82%E4%BD%95%E8%B0%83%E7%94%A8%20Loader%EF%BC%9F\" style=\"background-color:transparent\">4\u3001Webpack \u5982\u4f55\u8c03\u7528 Loader&#xff1f;<\/h3>\n<p>Webpack \u5185\u90e8\u4f1a\u505a\u8fd9\u6837\u7684\u4e8b\u60c5&#xff1a;<\/p>\n<li>\n<p>\u8bfb\u53d6\u8d44\u6e90\u5185\u5bb9&#xff08;\u5982 style.css&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u4f9d\u6b21\u8c03\u7528\u5339\u914d\u7684 loader<\/p>\n<\/li>\n<li>\n<p>\u628a\u8fd4\u56de\u7684\u5185\u5bb9\u4f5c\u4e3a\u6a21\u5757\u6253\u5305\u5165 bundle<\/p>\n<\/li>\n<h2 id=\"%C2%A0%E5%85%AD%E3%80%81%E6%9E%84%E5%BB%BA%E4%BC%98%E5%8C%96%E4%B8%8E%E9%AB%98%E7%BA%A7%E5%8A%9F%E8%83%BD\">\u00a0\u516d\u3001\u6784\u5efa\u4f18\u5316\u4e0e\u9ad8\u7ea7\u529f\u80fd<\/h2>\n<h3 id=\"1.%20%E4%BB%A3%E7%A0%81%E5%88%86%E5%89%B2%EF%BC%88Code%20Splitting%EF%BC%89\" style=\"background-color:transparent\">1. \u4ee3\u7801\u5206\u5272&#xff08;Code Splitting&#xff09;<\/h3>\n<ul>\n<li>\n<p>\u65b9\u5f0f\u4e00&#xff1a;entry \u591a\u5165\u53e3\u5206\u5272<\/p>\n<\/li>\n<li>\n<p>\u65b9\u5f0f\u4e8c&#xff1a;\u52a8\u6001\u5bfc\u5165&#xff08;\u5982 import()&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u65b9\u5f0f\u4e09&#xff1a;\u4f7f\u7528 SplitChunksPlugin \u81ea\u52a8\u63d0\u53d6\u516c\u5171\u4ee3\u7801<\/p>\n<\/li>\n<\/ul>\n<p>\u4ee3\u7801\u5206\u5272\u662f\u6307\u5c06\u9879\u76ee\u4ee3\u7801\u6253\u5305\u6210\u591a\u4e2a\u6587\u4ef6&#xff08;chunk&#xff09;&#xff0c;\u6309\u9700\u52a0\u8f7d&#xff0c;\u800c\u4e0d\u662f\u6253\u6210\u4e00\u4e2a\u5927\u6587\u4ef6\u3002<\/p>\n<p>&#x1f4cc; \u8fd9\u6837\u505a\u7684\u597d\u5904&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u51cf\u5c11\u9996\u6b21\u52a0\u8f7d\u65f6\u95f4&#xff08;\u53ea\u52a0\u8f7d\u5165\u53e3\u5fc5\u8981\u4ee3\u7801&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u5b9e\u73b0\u61d2\u52a0\u8f7d&#xff08;\u5982\u8def\u7531\u5207\u6362\u65f6\u624d\u52a0\u8f7d\u9875\u9762&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u63d0\u5347\u7f13\u5b58\u547d\u4e2d\u7387&#xff08;\u6bd4\u5982\u7b2c\u4e09\u65b9\u5e93\u63d0\u53d6\u4e3a\u72ec\u7acb\u6587\u4ef6&#xff09;<\/p>\n<\/li>\n<\/ul>\n<p>\u591a\u5165\u53e3&#xff08;entry&#xff09;\u5206\u5272<\/p>\n<p>\u5f53\u9879\u76ee\u6709\u591a\u4e2a\u5b8c\u5168\u72ec\u7acb\u7684\u5165\u53e3\u9875\u9762&#xff08;\u5982\u591a\u9875\u9762\u7f51\u7ad9 MPA&#xff09;\u3002<\/p>\n<p>module.exports &#061; {<br \/>\n  entry: {<br \/>\n    home: &#039;.\/src\/home.js&#039;,<br \/>\n    admin: &#039;.\/src\/admin.js&#039;<br \/>\n  },<br \/>\n  output: {<br \/>\n    filename: &#039;[name].bundle.js&#039;, \/\/ \u8f93\u51fa home.bundle.js \/ admin.bundle.js<br \/>\n    path: path.resolve(__dirname, &#039;dist&#039;)<br \/>\n  }<br \/>\n};<\/p>\n<table>\n<tr>\u4f18\u70b9\u7f3a\u70b9<\/tr>\n<tbody>\n<tr>\n<td>\u7b80\u5355\u76f4\u89c2<\/td>\n<td>\u4e0d\u9002\u5408\u7ec4\u4ef6\u5171\u4eab\u548c SPA<\/td>\n<\/tr>\n<tr>\n<td>\u9002\u5408\u591a\u9875\u9762\u7ad9\u70b9<\/td>\n<td>\u65e0\u6cd5\u81ea\u52a8\u62bd\u53d6\u516c\u5171\u4f9d\u8d56<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u4f7f\u7528 SplitChunksPlugin \u81ea\u52a8\u63d0\u53d6\u516c\u5171\u4ee3\u7801<\/p>\n<p>Webpack 4&#043; \u9ed8\u8ba4\u542f\u7528\u7684\u4f18\u5316\u63d2\u4ef6&#xff0c;\u7528\u4e8e\u81ea\u52a8\u5c06\u591a\u4e2a\u5165\u53e3\u4e4b\u95f4\u5171\u4eab\u7684\u4ee3\u7801\u62bd\u79bb\u6210\u5355\u72ec\u7684 chunk\u3002<\/p>\n<p>\u539f\u56e0&#xff1a;<\/p>\n<p>\u591a\u4e2a\u5165\u53e3\u6216\u5f02\u6b65\u6a21\u5757\u4e4b\u95f4&#xff0c;\u53ef\u80fd\u4f7f\u7528\u76f8\u540c\u4f9d\u8d56&#xff08;\u5982 React\u3001Lodash&#xff09;&#xff0c;\u5982\u679c\u4e0d\u5904\u7406&#xff0c;\u4f1a\u91cd\u590d\u6253\u5305\u3002<\/p>\n<p>\u5982\u4f55\u542f\u7528&#xff1f;<\/p>\n<p>Webpack 4 \u8d77\u5c31\u9ed8\u8ba4\u5f00\u542f\u4e86 SplitChunksPlugin&#xff0c;\u4f60\u4e5f\u53ef\u4ee5\u624b\u52a8\u914d\u7f6e\u5b83&#xff1a;<\/p>\n<p>module.exports &#061; {<br \/>\n  optimization: {<br \/>\n    splitChunks: {<br \/>\n      chunks: &#039;all&#039;, \/\/ \u9ed8\u8ba4\u53ea\u5206 async&#xff0c;\u6539\u4e3a all \u8868\u793a\u540c\u6b65\u548c\u5f02\u6b65\u90fd\u63d0\u53d6<br \/>\n      minSize: 20000, \/\/ \u6700\u5c0f\u5206\u5272\u4f53\u79ef&#xff08;\u5355\u4f4d&#xff1a;\u5b57\u8282&#xff09;<br \/>\n      cacheGroups: {<br \/>\n        vendor: {<br \/>\n          test: \/[\\\\\\\\\/]node_modules[\\\\\\\\\/]\/,<br \/>\n          name: &#039;vendors&#039;,<br \/>\n          chunks: &#039;all&#039;<br \/>\n        }<br \/>\n      }<br \/>\n    }<br \/>\n  }<br \/>\n};<\/p>\n<p>\u6253\u5305\u7ed3\u679c&#xff1a;<\/p>\n<ul>\n<li>\n<p>main.bundle.js \u2192 \u4e3b\u4ee3\u7801<\/p>\n<\/li>\n<li>\n<p>vendors.js \u2192 \u7b2c\u4e09\u65b9\u5e93<\/p>\n<\/li>\n<li>\n<p>common.js \u2192 \u591a\u4e2a\u6a21\u5757\u90fd\u7528\u5230\u7684\u516c\u5171\u4ee3\u7801<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"2.%20Tree%20Shaking\">2. Tree Shaking<\/h3>\n<ul>\n<li>\n<p>\u79fb\u9664\u672a\u4f7f\u7528\u4ee3\u7801&#xff08;\u53ea\u9002\u7528\u4e8e ES Module&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u8981\u542f\u7528&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u4f7f\u7528 ES6 \u6a21\u5757\u8bed\u6cd5<\/p>\n<\/li>\n<li>\n<p>mode: production \u6216\u624b\u52a8\u542f\u7528 sideEffects: false<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<p>\u00a0Tree Shaking \u662f\u4e00\u79cd\u201c\u9759\u6001\u5206\u6790 &#043; \u5254\u9664\u65e0\u7528\u4ee3\u7801\u201d\u7684\u673a\u5236&#xff0c;\u53ef\u4ee5\u5728\u6784\u5efa\u8fc7\u7a0b\u4e2d\u79fb\u9664\u672a\u88ab\u4f7f\u7528&#xff08;import&#xff09;\u7684\u4ee3\u7801&#xff0c;\u4ece\u800c\u51cf\u5c0f\u6700\u7ec8\u7684 Bundle \u4f53\u79ef\u3002<\/p>\n<p>\u00a0&#x1f4cc; \u901a\u4fd7\u8bf4&#xff1a;\u5c31\u50cf\u628a\u4e00\u4e2a\u5927\u6811\u7684\u67af\u679d\u526a\u6389&#xff0c;\u53ea\u7559\u4e0b\u4f60\u7528\u5230\u7684\u201c\u679d\u5e72\u201d\u3002<\/p>\n<h4 id=\"Tree%20Shaking%20%E7%9A%84%E5%9F%BA%E6%9C%AC%E5%8E%9F%E7%90%86\">Tree Shaking \u7684\u57fa\u672c\u539f\u7406<\/h4>\n<ul>\n<li>\n<p>\u57fa\u4e8e\u9759\u6001 ES6 Module \u5206\u6790\u6a21\u5757\u4f9d\u8d56&#xff08;\u5373 import \/ export&#xff09;<\/p>\n<\/li>\n<li>\n<p>Webpack \u5728\u6784\u5efa\u65f6\u6807\u8bb0\u54ea\u4e9b\u5bfc\u51fa\u88ab\u4f7f\u7528&#xff0c;\u54ea\u4e9b\u6ca1\u6709<\/p>\n<\/li>\n<li>\n<p>\u5728\u538b\u7f29\u9636\u6bb5&#xff08;\u5982\u4f7f\u7528 TerserPlugin&#xff09;&#xff0c;\u79fb\u9664\u672a\u4f7f\u7528\u7684\u5bfc\u51fa\u51fd\u6570\u6216\u53d8\u91cf<\/p>\n<\/li>\n<\/ul>\n<p>\u00a0\u542f\u7528 Tree Shaking \u7684\u524d\u63d0\u6761\u4ef6<\/p>\n<table>\n<tr>\u6761\u4ef6\u8bf4\u660e<\/tr>\n<tbody>\n<tr>\n<td>\u2705 \u4f7f\u7528 ES Module&#xff08;ES6 import \/ export&#xff09;<\/td>\n<td>CommonJS&#xff08;require \/ module.exports&#xff09;\u4e0d\u652f\u6301<\/td>\n<\/tr>\n<tr>\n<td>\u2705 Webpack \u8fd0\u884c\u5728 production \u6a21\u5f0f\u4e0b<\/td>\n<td>\u6216\u663e\u5f0f\u914d\u7f6e\u538b\u7f29\u63d2\u4ef6<\/td>\n<\/tr>\n<tr>\n<td>\u2705 package.json \u4e2d\u8bbe\u7f6e &#034;sideEffects&#034;: false<\/td>\n<td>\u6216\u5355\u72ec\u6807\u8bb0\u67d0\u4e9b\u6587\u4ef6\u6709\u526f\u4f5c\u7528<\/td>\n<\/tr>\n<tr>\n<td>\u2705 \u6ca1\u6709\u526f\u4f5c\u7528\u7684\u4ee3\u7801<\/td>\n<td>\u7eaf\u51fd\u6570 \/ \u7eaf\u6a21\u5757\u66f4\u5bb9\u6613\u88ab\u5254\u9664<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h3 id=\"3.%20%E6%87%92%E5%8A%A0%E8%BD%BD%EF%BC%88Lazy%20Loading%EF%BC%89%E4%B8%8E%E9%A2%84%E5%8A%A0%E8%BD%BD\">3. \u61d2\u52a0\u8f7d&#xff08;Lazy Loading&#xff09;\u4e0e\u9884\u52a0\u8f7d<\/h3>\n<ul>\n<li>\n<p>\u4f7f\u7528 import() &#043; \u52a8\u6001\u8def\u7531\u5b9e\u73b0\u9875\u9762\u7ea7\u61d2\u52a0\u8f7d<\/p>\n<\/li>\n<li>\n<p>webpackPrefetch\u3001webpackPreload \u6ce8\u91ca\u6765\u4f18\u5316\u52a0\u8f7d\u65f6\u673a<\/p>\n<\/li>\n<\/ul>\n<h4 id=\"1%E3%80%81%E4%BB%80%E4%B9%88%E6%98%AF%E6%87%92%E5%8A%A0%E8%BD%BD%EF%BC%88Lazy%20Loading%EF%BC%89%EF%BC%9F\">1\u3001\u4ec0\u4e48\u662f\u61d2\u52a0\u8f7d&#xff08;Lazy Loading&#xff09;&#xff1f;<\/h4>\n<p>\u61d2\u52a0\u8f7d \u662f\u6307\u5c06\u6a21\u5757\u5ef6\u8fdf\u52a0\u8f7d\u2014\u2014\u4e0d\u662f\u5728\u9996\u9875\u5c31\u52a0\u8f7d&#xff0c;\u800c\u662f\u5728\u7528\u6237\u9700\u8981\u5b83\u7684\u65f6\u5019\u518d\u53bb\u52a0\u8f7d\u5bf9\u5e94\u8d44\u6e90&#xff08;chunk&#xff09;\u3002<\/p>\n<h5 id=\"Webpack%20%E5%A6%82%E4%BD%95%E5%AE%9E%E7%8E%B0%E6%87%92%E5%8A%A0%E8%BD%BD%EF%BC%9F\">Webpack \u5982\u4f55\u5b9e\u73b0\u61d2\u52a0\u8f7d&#xff1f;<\/h5>\n<p>\u4f7f\u7528 import() \u52a8\u6001\u5bfc\u5165\u8bed\u6cd5&#xff0c;Webpack \u4f1a\u81ea\u52a8\u628a\u88ab\u52a8\u6001\u5bfc\u5165\u7684\u6a21\u5757\u6253\u5305\u6210\u5355\u72ec\u7684 Chunk \u6587\u4ef6&#xff0c;\u5b9e\u73b0\u6309\u9700\u52a0\u8f7d\u3002<\/p>\n<h4 id=\"2%E3%80%81%E4%BB%80%E4%B9%88%E6%98%AF%E9%A2%84%E5%8A%A0%E8%BD%BD%EF%BC%88Preload%EF%BC%89%E5%92%8C%E9%A2%84%E5%8F%96%EF%BC%88Prefetch%EF%BC%89%EF%BC%9F\">2\u3001\u4ec0\u4e48\u662f\u9884\u52a0\u8f7d&#xff08;Preload&#xff09;\u548c\u9884\u53d6&#xff08;Prefetch&#xff09;&#xff1f;<\/h4>\n<p>Webpack \u63d0\u4f9b\u4e86\u4e24\u79cd\u6ce8\u91ca\u9b54\u6cd5\u6307\u4ee4&#xff0c;\u6765\u63a7\u5236\u52a8\u6001\u6a21\u5757\u7684\u201c\u63d0\u524d\u52a0\u8f7d\u884c\u4e3a\u201d&#xff1a;<\/p>\n<h5 id=\"1.%20webpackPrefetch%3A%20true%20%E2%86%92%20%E6%B5%8F%E8%A7%88%E5%99%A8%E7%A9%BA%E9%97%B2%E6%97%B6%E5%8A%A0%E8%BD%BD%C2%A0\">1. webpackPrefetch: true \u2192 \u6d4f\u89c8\u5668\u7a7a\u95f2\u65f6\u52a0\u8f7d\u00a0<\/h5>\n<p>\u00a0import(\/* webpackPrefetch: true *\/ &#039;.\/math.js&#039;);<\/p>\n<p>\u4f7f\u7528\u65f6\u673a&#xff1a;\u4f60\u5e0c\u671b \u6a21\u5757\u7a0d\u540e\u4f1a\u7528\u5230&#xff0c;\u53ef\u4ee5\u8ba9\u6d4f\u89c8\u5668\u5728\u7a7a\u95f2\u65f6\u5077\u5077\u4e0b\u8f7d\u5b83\u3002<\/p>\n<p>&#x1f539; \u793a\u4f8b&#xff1a;\u9875\u9762 A \u52a0\u8f7d\u540e\u5c31\u5f00\u59cb\u201c\u9884\u53d6\u201d\u9875\u9762 B \u7684\u4ee3\u7801&#xff0c;\u7b49\u7528\u6237\u70b9\u51fb\u9875\u9762 B \u65f6\u77ac\u95f4\u6253\u5f00\u3002<\/p>\n<h5 id=\"2.%20webpackPreload%3A%20true%20%E2%86%92%20%E5%BD%93%E5%89%8D%E5%B8%A7%E5%B0%B1%E5%8A%A0%E8%BD%BD%C2%A0\">2. webpackPreload: true \u2192 \u5f53\u524d\u5e27\u5c31\u52a0\u8f7d\u00a0<\/h5>\n<p>import(\/* webpackPreload: true *\/ &#039;.\/utils.js&#039;);\u00a0<\/p>\n<p>&#x1f539; \u4f7f\u7528\u65f6\u673a&#xff1a;\u4f60\u5e0c\u671b\u6a21\u5757\u5c3d\u5feb\u52a0\u8f7d&#xff0c;\u4f46\u53c8\u4e0d\u60f3\u5f71\u54cd\u4e3b chunk&#xff08;\u6bd4\u5982\u5927\u56fe\u3001\u5b57\u4f53\u7b49\u8d44\u6e90&#xff09;\u3002\u00a0<\/p>\n<table>\n<tr>\u573a\u666f\u4f7f\u7528\u65b9\u5f0f\u52a0\u8f7d\u65f6\u673a\u9002\u7528\u5bf9\u8c61<\/tr>\n<tbody>\n<tr>\n<td>\u61d2\u52a0\u8f7d<\/td>\n<td>import()<\/td>\n<td>\u4e8b\u4ef6\u89e6\u53d1\u52a0\u8f7d<\/td>\n<td>\u9875\u9762\u3001\u7ec4\u4ef6\u3001\u6a21\u5757<\/td>\n<\/tr>\n<tr>\n<td>\u9884\u53d6 Prefetch<\/td>\n<td>import(\/* webpackPrefetch *\/)<\/td>\n<td>\u6d4f\u89c8\u5668\u7a7a\u95f2<\/td>\n<td>\u9875\u9762\u8df3\u8f6c\u63d0\u524d\u52a0\u8f7d<\/td>\n<\/tr>\n<tr>\n<td>\u9884\u52a0\u8f7d Preload<\/td>\n<td>import(\/* webpackPreload *\/)<\/td>\n<td>\u5f53\u524d\u5e27\u52a0\u8f7d<\/td>\n<td>\u9ad8\u4f18\u5148\u7ea7\u8d44\u6e90\u52a0\u8f7d<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u7ed3\u5408\u4f7f\u7528\u793a\u4f8b<\/p>\n<p>\/\/ \u5f53\u524d\u4e0d\u52a0\u8f7d&#xff0c;\u7b49\u7528\u6237\u70b9\u51fb\u518d\u52a0\u8f7d<br \/>\ndocument.getElementById(&#039;btn&#039;).onclick &#061; () &#061;&gt; {<br \/>\n  import(\/* webpackChunkName: &#034;math&#034; *\/ &#039;.\/math.js&#039;).then(({ add }) &#061;&gt; {<br \/>\n    console.log(add(2, 3));<br \/>\n  });<br \/>\n};<\/p>\n<p>\/\/ \u9884\u52a0\u8f7d\u67d0\u4e2a chunk&#xff08;\u7acb\u5373\u52a0\u8f7d&#xff0c;\u4f46\u4e0d\u5f71\u54cd\u4e3b\u7ebf\u7a0b&#xff09;<br \/>\nimport(\/* webpackPreload: true *\/ &#039;.\/preload-heavy.js&#039;);<\/p>\n<p>\/\/ \u9884\u53d6\u67d0\u4e2a\u6a21\u5757&#xff08;\u6d4f\u89c8\u5668\u7a7a\u95f2\u65f6\u52a0\u8f7d&#xff09;<br \/>\nimport(\/* webpackPrefetch: true *\/ &#039;.\/about.js&#039;);<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb1.2k\u6b21\uff0c\u70b9\u8d5e22\u6b21\uff0c\u6536\u85cf14\u6b21\u3002Loader \u662f Webpack \u7684\u6a21\u5757\u8f6c\u6362\u5668\uff0c\u7528\u4e8e\u5c06\u5404\u79cd\u975e JavaScript \u6587\u4ef6\u8f6c\u6362\u4e3a Webpack \u53ef\u4ee5\u7406\u89e3\u7684\u6a21\u5757\uff08JavaScript \u6a21\u5757\uff09\u3002\u61d2\u52a0\u8f7d\u662f\u6307\u5c06\u6a21\u5757\u5ef6\u8fdf\u52a0\u8f7d\u2014\u2014\u4e0d\u662f\u5728\u9996\u9875\u5c31\u52a0\u8f7d\uff0c\u800c\u662f\u5728\u7528\u6237\u9700\u8981\u5b83\u7684\u65f6\u5019\u518d\u53bb\u52a0\u8f7d\u5bf9\u5e94\u8d44\u6e90\uff08chunk\uff09\u3002Webpack \u63d0\u4f9b\u4e86\u4e24\u79cd\u6ce8\u91ca\u9b54\u6cd5\u6307\u4ee4\uff0c\u6765\u63a7\u5236\u52a8\u6001\u6a21\u5757\u7684\u201c\u63d0\u524d\u52a0\u8f7d\u884c\u4e3a\u3002_webpack\u6784\u5efa\u6d41\u7a0b<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[186,3099,87],"topic":[],"class_list":["post-38214","post","type-post","status-publish","format-standard","hentry","category-server","tag-node-js","tag-webpack","tag-87"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u524d\u7aef\u9762\u7ecf-webpack\u7bc7-\u5b9a\u4e49\u3001\u914d\u7f6e\u3001\u6784\u5efa\u6d41\u7a0b\u3001 Loader\u3001Tree Shaking\u3001\u61d2\u52a0\u8f7d\u4e0e\u9884\u52a0\u8f7d\u3001\u4ee3\u7801\u5206\u5272\u3001 Plugin \u673a\u5236 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.wsisp.com\/helps\/38214.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u524d\u7aef\u9762\u7ecf-webpack\u7bc7-\u5b9a\u4e49\u3001\u914d\u7f6e\u3001\u6784\u5efa\u6d41\u7a0b\u3001 Loader\u3001Tree Shaking\u3001\u61d2\u52a0\u8f7d\u4e0e\u9884\u52a0\u8f7d\u3001\u4ee3\u7801\u5206\u5272\u3001 Plugin \u673a\u5236 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb1.2k\u6b21\uff0c\u70b9\u8d5e22\u6b21\uff0c\u6536\u85cf14\u6b21\u3002Loader \u662f Webpack \u7684\u6a21\u5757\u8f6c\u6362\u5668\uff0c\u7528\u4e8e\u5c06\u5404\u79cd\u975e JavaScript \u6587\u4ef6\u8f6c\u6362\u4e3a Webpack \u53ef\u4ee5\u7406\u89e3\u7684\u6a21\u5757\uff08JavaScript \u6a21\u5757\uff09\u3002\u61d2\u52a0\u8f7d\u662f\u6307\u5c06\u6a21\u5757\u5ef6\u8fdf\u52a0\u8f7d\u2014\u2014\u4e0d\u662f\u5728\u9996\u9875\u5c31\u52a0\u8f7d\uff0c\u800c\u662f\u5728\u7528\u6237\u9700\u8981\u5b83\u7684\u65f6\u5019\u518d\u53bb\u52a0\u8f7d\u5bf9\u5e94\u8d44\u6e90\uff08chunk\uff09\u3002Webpack \u63d0\u4f9b\u4e86\u4e24\u79cd\u6ce8\u91ca\u9b54\u6cd5\u6307\u4ee4\uff0c\u6765\u63a7\u5236\u52a8\u6001\u6a21\u5757\u7684\u201c\u63d0\u524d\u52a0\u8f7d\u884c\u4e3a\u3002_webpack\u6784\u5efa\u6d41\u7a0b\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/38214.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2025-05-19T17:04:23+00:00\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"11 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/38214.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/38214.html\",\"name\":\"\u524d\u7aef\u9762\u7ecf-webpack\u7bc7-\u5b9a\u4e49\u3001\u914d\u7f6e\u3001\u6784\u5efa\u6d41\u7a0b\u3001 Loader\u3001Tree Shaking\u3001\u61d2\u52a0\u8f7d\u4e0e\u9884\u52a0\u8f7d\u3001\u4ee3\u7801\u5206\u5272\u3001 Plugin \u673a\u5236 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2025-05-19T17:04:23+00:00\",\"dateModified\":\"2025-05-19T17:04:23+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/38214.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/38214.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/38214.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u524d\u7aef\u9762\u7ecf-webpack\u7bc7--\u5b9a\u4e49\u3001\u914d\u7f6e\u3001\u6784\u5efa\u6d41\u7a0b\u3001 Loader\u3001Tree Shaking\u3001\u61d2\u52a0\u8f7d\u4e0e\u9884\u52a0\u8f7d\u3001\u4ee3\u7801\u5206\u5272\u3001 Plugin \u673a\u5236\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\",\"url\":\"https:\/\/www.wsisp.com\/helps\/\",\"name\":\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"description\":\"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"contentUrl\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"caption\":\"admin\"},\"sameAs\":[\"http:\/\/wp.wsisp.com\"],\"url\":\"https:\/\/www.wsisp.com\/helps\/author\/admin\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u524d\u7aef\u9762\u7ecf-webpack\u7bc7-\u5b9a\u4e49\u3001\u914d\u7f6e\u3001\u6784\u5efa\u6d41\u7a0b\u3001 Loader\u3001Tree Shaking\u3001\u61d2\u52a0\u8f7d\u4e0e\u9884\u52a0\u8f7d\u3001\u4ee3\u7801\u5206\u5272\u3001 Plugin \u673a\u5236 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.wsisp.com\/helps\/38214.html","og_locale":"zh_CN","og_type":"article","og_title":"\u524d\u7aef\u9762\u7ecf-webpack\u7bc7-\u5b9a\u4e49\u3001\u914d\u7f6e\u3001\u6784\u5efa\u6d41\u7a0b\u3001 Loader\u3001Tree Shaking\u3001\u61d2\u52a0\u8f7d\u4e0e\u9884\u52a0\u8f7d\u3001\u4ee3\u7801\u5206\u5272\u3001 Plugin \u673a\u5236 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb1.2k\u6b21\uff0c\u70b9\u8d5e22\u6b21\uff0c\u6536\u85cf14\u6b21\u3002Loader \u662f Webpack \u7684\u6a21\u5757\u8f6c\u6362\u5668\uff0c\u7528\u4e8e\u5c06\u5404\u79cd\u975e JavaScript \u6587\u4ef6\u8f6c\u6362\u4e3a Webpack \u53ef\u4ee5\u7406\u89e3\u7684\u6a21\u5757\uff08JavaScript \u6a21\u5757\uff09\u3002\u61d2\u52a0\u8f7d\u662f\u6307\u5c06\u6a21\u5757\u5ef6\u8fdf\u52a0\u8f7d\u2014\u2014\u4e0d\u662f\u5728\u9996\u9875\u5c31\u52a0\u8f7d\uff0c\u800c\u662f\u5728\u7528\u6237\u9700\u8981\u5b83\u7684\u65f6\u5019\u518d\u53bb\u52a0\u8f7d\u5bf9\u5e94\u8d44\u6e90\uff08chunk\uff09\u3002Webpack \u63d0\u4f9b\u4e86\u4e24\u79cd\u6ce8\u91ca\u9b54\u6cd5\u6307\u4ee4\uff0c\u6765\u63a7\u5236\u52a8\u6001\u6a21\u5757\u7684\u201c\u63d0\u524d\u52a0\u8f7d\u884c\u4e3a\u3002_webpack\u6784\u5efa\u6d41\u7a0b","og_url":"https:\/\/www.wsisp.com\/helps\/38214.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2025-05-19T17:04:23+00:00","author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"11 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/38214.html","url":"https:\/\/www.wsisp.com\/helps\/38214.html","name":"\u524d\u7aef\u9762\u7ecf-webpack\u7bc7-\u5b9a\u4e49\u3001\u914d\u7f6e\u3001\u6784\u5efa\u6d41\u7a0b\u3001 Loader\u3001Tree Shaking\u3001\u61d2\u52a0\u8f7d\u4e0e\u9884\u52a0\u8f7d\u3001\u4ee3\u7801\u5206\u5272\u3001 Plugin \u673a\u5236 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2025-05-19T17:04:23+00:00","dateModified":"2025-05-19T17:04:23+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/38214.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/38214.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/38214.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"\u524d\u7aef\u9762\u7ecf-webpack\u7bc7--\u5b9a\u4e49\u3001\u914d\u7f6e\u3001\u6784\u5efa\u6d41\u7a0b\u3001 Loader\u3001Tree Shaking\u3001\u61d2\u52a0\u8f7d\u4e0e\u9884\u52a0\u8f7d\u3001\u4ee3\u7801\u5206\u5272\u3001 Plugin \u673a\u5236"}]},{"@type":"WebSite","@id":"https:\/\/www.wsisp.com\/helps\/#website","url":"https:\/\/www.wsisp.com\/helps\/","name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","description":"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41","name":"admin","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/","url":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","contentUrl":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","caption":"admin"},"sameAs":["http:\/\/wp.wsisp.com"],"url":"https:\/\/www.wsisp.com\/helps\/author\/admin"}]}},"_links":{"self":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/38214","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/comments?post=38214"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/38214\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=38214"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=38214"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=38214"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=38214"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}