{"id":64182,"date":"2026-01-22T22:48:34","date_gmt":"2026-01-22T14:48:34","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/64182.html"},"modified":"2026-01-22T22:48:34","modified_gmt":"2026-01-22T14:48:34","slug":"%e5%89%8d%e7%ab%af%e6%80%a7%e8%83%bd%e4%bc%98%e5%8c%96%e7%b3%bb%e5%88%97%ef%bc%88%e4%ba%8c%ef%bc%89%ef%bc%9a%e8%af%b7%e6%b1%82%e4%bc%98%e5%8c%96%e7%ad%96%e7%95%a5","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/64182.html","title":{"rendered":"\u524d\u7aef\u6027\u80fd\u4f18\u5316\u7cfb\u5217\uff08\u4e8c\uff09\uff1a\u8bf7\u6c42\u4f18\u5316\u7b56\u7565"},"content":{"rendered":"<h3>\u4e00\u3001\u8bf7\u6c42\u4f18\u5316\u6838\u5fc3\u601d\u8def<\/h3>\n<h4>1.1 \u4f18\u5316\u56db\u539f\u5219<\/h4>\n<p>\u8bf7\u6c42\u4f18\u5316\u91d1\u5b57\u5854&#xff1a;<br \/>\n        \u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510<br \/>\n        \u2502  \u4e0d\u53d1\u8bf7\u6c42    \u2502 \u2190 \u6700\u4f18&#xff08;\u7f13\u5b58\u3001\u9884\u52a0\u8f7d&#xff09;<br \/>\n        \u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524<br \/>\n        \u2502  \u5c11\u53d1\u8bf7\u6c42    \u2502 \u2190 \u6b21\u4f18&#xff08;\u5408\u5e76\u3001\u61d2\u52a0\u8f7d&#xff09;<br \/>\n        \u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524<br \/>\n        \u2502  \u5c0f\u8bf7\u6c42      \u2502 \u2190 \u4f18\u5316&#xff08;\u538b\u7f29\u3001\u88c1\u526a&#xff09;<br \/>\n        \u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524<br \/>\n        \u2502  \u5feb\u8bf7\u6c42      \u2502 \u2190 \u57fa\u7840&#xff08;CDN\u3001HTTP\/2&#xff09;<br \/>\n        \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518<\/p>\n<p>\u4f18\u5316\u7b56\u7565&#xff1a;<br \/>\n1\ufe0f\u20e3 \u80fd\u4e0d\u53d1\u5c31\u4e0d\u53d1&#xff08;\u7f13\u5b58&#xff09;<br \/>\n2\ufe0f\u20e3 \u80fd\u5c11\u53d1\u5c31\u5c11\u53d1&#xff08;\u5408\u5e76\u3001\u61d2\u52a0\u8f7d&#xff09;<br \/>\n3\ufe0f\u20e3 \u80fd\u5c0f\u53d1\u5c31\u5c0f\u53d1&#xff08;\u538b\u7f29\u3001\u7cbe\u7b80&#xff09;<br \/>\n4\ufe0f\u20e3 \u80fd\u5feb\u53d1\u5c31\u5feb\u53d1&#xff08;CDN\u3001\u5e76\u884c&#xff09;<\/p>\n<h4>1.2 \u5e38\u89c1\u95ee\u9898\u5206\u7c7b<\/h4>\n<table>\n<tr>\u95ee\u9898\u8868\u73b0\u5f71\u54cd\u4f18\u5148\u7ea7<\/tr>\n<tbody>\n<tr>\n<td>\u8bf7\u6c42\u6570\u91cf\u8fc7\u591a<\/td>\n<td>127\u4e2a\u8bf7\u6c42<\/td>\n<td>\u6d4f\u89c8\u5668\u5e76\u53d1\u9650\u5236\u3001\u961f\u5217\u7b49\u5f85<\/td>\n<td>&#x1f534; \u9ad8<\/td>\n<\/tr>\n<tr>\n<td>\u5355\u6b21\u8bf7\u6c42\u8fc7\u5927<\/td>\n<td>\u5355\u4e2aAPI 3.2MB<\/td>\n<td>\u7f51\u7edc\u4f20\u8f93\u6162\u3001\u89e3\u6790\u6162<\/td>\n<td>&#x1f534; \u9ad8<\/td>\n<\/tr>\n<tr>\n<td>\u8bf7\u6c42\u65f6\u673a\u4e0d\u5f53<\/td>\n<td>\u9996\u5c4f\u5168\u91cf\u52a0\u8f7d<\/td>\n<td>\u767d\u5c4f\u65f6\u95f4\u957f<\/td>\n<td>&#x1f534; \u9ad8<\/td>\n<\/tr>\n<tr>\n<td>\u65e0\u7f13\u5b58\u7b56\u7565<\/td>\n<td>\u6bcf\u6b21\u5168\u91cf\u8bf7\u6c42<\/td>\n<td>\u6d6a\u8d39\u5e26\u5bbd\u3001\u4f53\u9a8c\u5dee<\/td>\n<td>\u26a0\ufe0f \u4e2d<\/td>\n<\/tr>\n<tr>\n<td>\u4e32\u884c\u8bf7\u6c42<\/td>\n<td>\u7011\u5e03\u6d41<\/td>\n<td>\u603b\u65f6\u95f4\u957f<\/td>\n<td>\u26a0\ufe0f \u4e2d<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<hr \/>\n<h3>\u4e8c\u3001\u51cf\u5c11\u8bf7\u6c42\u6570\u91cf<\/h3>\n<h4>2.1 \u8d44\u6e90\u5408\u5e76<\/h4>\n<h5>2.1.1 \u56fe\u7247\u96ea\u78a7\u56fe&#xff08;CSS Sprites&#xff09;<\/h5>\n<p>\u95ee\u9898\u573a\u666f&#xff1a;<\/p>\n<p><span class=\"token comment\">&lt;!&#8211; \u4f18\u5316\u524d&#xff1a;20\u4e2a\u5c0f\u56fe\u6807 &#061; 20\u4e2a\u8bf7\u6c42 &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>img<\/span> <span class=\"token attr-name\">src<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>\/icons\/user.png<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>img<\/span> <span class=\"token attr-name\">src<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>\/icons\/cart.png<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>img<\/span> <span class=\"token attr-name\">src<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>\/icons\/search.png<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; &#8230; 17\u4e2a\u56fe\u6807 &#8230; &#8211;&gt;<\/span><\/p>\n<p>\u95ee\u9898&#xff1a;<br \/>\n&#8211; 20\u4e2aHTTP\u8bf7\u6c42<br \/>\n&#8211; \u6bcf\u4e2a\u8bf7\u6c42\u90fd\u6709TCP\u63e1\u624b\u3001\u6392\u961f\u65f6\u95f4<br \/>\n&#8211; \u6d4f\u89c8\u5668\u5e76\u53d1\u9650\u5236&#xff08;6\u4e2a\/\u57df\u540d&#xff09;<\/p>\n<p>\u89e3\u51b3\u65b9\u6848&#xff1a;<\/p>\n<p><span class=\"token comment\">\/* \u4f18\u5316\u540e&#xff1a;1\u4e2a\u96ea\u78a7\u56fe &#061; 1\u4e2a\u8bf7\u6c42 *\/<\/span><br \/>\n<span class=\"token selector\">.sprite<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token property\">background-image<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token url\"><span class=\"token function\">url<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string url\">&#039;\/images\/sprite.png&#039;<\/span><span class=\"token punctuation\">)<\/span><\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token property\">background-repeat<\/span><span class=\"token punctuation\">:<\/span> no-repeat<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token property\">display<\/span><span class=\"token punctuation\">:<\/span> inline-block<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token selector\">.icon-user<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token property\">width<\/span><span class=\"token punctuation\">:<\/span> 20px<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token property\">height<\/span><span class=\"token punctuation\">:<\/span> 20px<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token property\">background-position<\/span><span class=\"token punctuation\">:<\/span> 0 0<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token selector\">.icon-cart<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token property\">width<\/span><span class=\"token punctuation\">:<\/span> 20px<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token property\">height<\/span><span class=\"token punctuation\">:<\/span> 20px<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token property\">background-position<\/span><span class=\"token punctuation\">:<\/span> -20px 0<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token selector\">.icon-search<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token property\">width<\/span><span class=\"token punctuation\">:<\/span> 20px<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token property\">height<\/span><span class=\"token punctuation\">:<\/span> 20px<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token property\">background-position<\/span><span class=\"token punctuation\">:<\/span> -40px 0<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>\u81ea\u52a8\u5316\u5de5\u5177&#xff1a;<\/p>\n<p><span class=\"token comment\"># \u4f7f\u7528 webpack-spritesmith<\/span><br \/>\n<span class=\"token function\">npm<\/span> <span class=\"token function\">install<\/span> webpack-spritesmith &#8211;save-dev<\/p>\n<p><span class=\"token comment\"># webpack.config.js<\/span><br \/>\nconst SpritesmithPlugin <span class=\"token operator\">&#061;<\/span> require<span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;webpack-spritesmith&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>module.exports <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  plugins: <span class=\"token punctuation\">[<\/span><br \/>\n    new SpritesmithPlugin<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span><br \/>\n      src: <span class=\"token punctuation\">{<\/span><br \/>\n        cwd: path.resolve<span class=\"token punctuation\">(<\/span>__dirname, <span class=\"token string\">&#039;src\/assets\/icons&#039;<\/span><span class=\"token punctuation\">)<\/span>,<br \/>\n        glob: <span class=\"token string\">&#039;*.png&#039;<\/span><br \/>\n      <span class=\"token punctuation\">}<\/span>,<br \/>\n      target: <span class=\"token punctuation\">{<\/span><br \/>\n        image: path.resolve<span class=\"token punctuation\">(<\/span>__dirname, <span class=\"token string\">&#039;dist\/sprite.png&#039;<\/span><span class=\"token punctuation\">)<\/span>,<br \/>\n        css: path.resolve<span class=\"token punctuation\">(<\/span>__dirname, <span class=\"token string\">&#039;dist\/sprite.css&#039;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n      <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">]<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>\u73b0\u4ee3\u66ff\u4ee3\u65b9\u6848&#xff08;\u63a8\u8350&#xff09;&#xff1a;<\/p>\n<p><span class=\"token comment\">&lt;!&#8211; \u4f7f\u7528 SVG Sprite&#xff08;\u66f4\u7075\u6d3b&#xff09; &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>svg<\/span> <span class=\"token attr-name\">class<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>icon<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n  <span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>use<\/span> <span class=\"token attr-name\"><span class=\"token namespace\">xlink:<\/span>href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>#icon-user<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;\/<\/span>use<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;\/<\/span>svg<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><\/p>\n<p><span class=\"token comment\">&lt;!&#8211; \u4f7f\u7528 Icon Font &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>i<\/span> <span class=\"token attr-name\">class<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>iconfont icon-user<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;\/<\/span>i<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><\/p>\n<p><span class=\"token comment\">&lt;!&#8211; \u4f7f\u7528\u5185\u8054SVG&#xff08;\u6700\u4f18&#xff09; &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>svg<\/span> <span class=\"token attr-name\">width<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>20<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">height<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>20<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">viewBox<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>0 0 20 20<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n  <span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>path<\/span> <span class=\"token attr-name\">d<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>M10 0C4.48&#8230;<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">\/&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;\/<\/span>svg<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><\/p>\n<hr \/>\n<h5>2.1.2 JS\/CSS\u5408\u5e76<\/h5>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u524d&#xff1a;\u591a\u4e2a\u6587\u4ef6<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span>script src<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;jquery.js&#034;<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>script<span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span>script src<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;lodash.js&#034;<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>script<span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span>script src<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;utils.js&#034;<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>script<span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span>script src<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;app.js&#034;<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>script<span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token comment\">\/\/ 4\u4e2a\u8bf7\u6c42<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u540e&#xff1a;Webpack\u6253\u5305<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span>script src<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;bundle.js&#034;<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>script<span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token comment\">\/\/ 1\u4e2a\u8bf7\u6c42<\/span><\/p>\n<p><span class=\"token comment\">\/\/ webpack.config.js<\/span><br \/>\nmodule<span class=\"token punctuation\">.<\/span>exports <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token literal-property property\">entry<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;.\/src\/index.js&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token literal-property property\">output<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">filename<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;bundle.[contenthash].js&#039;<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token literal-property property\">optimization<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">splitChunks<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n      <span class=\"token literal-property property\">chunks<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;all&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n      <span class=\"token literal-property property\">cacheGroups<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token literal-property property\">vendor<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n          <span class=\"token literal-property property\">test<\/span><span class=\"token operator\">:<\/span> <span class=\"token regex\"><span class=\"token regex-delimiter\">\/<\/span><span class=\"token regex-source language-regex\">[\\\\\\\\\/]node_modules[\\\\\\\\\/]<\/span><span class=\"token regex-delimiter\">\/<\/span><\/span><span class=\"token punctuation\">,<\/span><br \/>\n          <span class=\"token literal-property property\">name<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;vendors&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n          <span class=\"token literal-property property\">priority<\/span><span class=\"token operator\">:<\/span> <span class=\"token number\">10<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n      <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>\u6ce8\u610f\u4e8b\u9879&#xff1a;<\/p>\n<p>\u26a0\ufe0f \u5408\u5e76\u4e0d\u662f\u8d8a\u591a\u8d8a\u597d&#xff01;<\/p>\n<p>\u8fc7\u5ea6\u5408\u5e76\u7684\u95ee\u9898&#xff1a;<br \/>\n\u274c Bundle\u8fc7\u5927&#xff08;\u8d85\u8fc7500KB&#xff09;<br \/>\n\u274c \u89e3\u6790\u65f6\u95f4\u957f&#xff08;\u963b\u585e\u6e32\u67d3&#xff09;<br \/>\n\u274c \u7f13\u5b58\u5931\u6548&#xff08;\u4e00\u4e2a\u6587\u4ef6\u6539\u52a8&#xff0c;\u5168\u90e8\u5931\u6548&#xff09;<\/p>\n<p>\u6700\u4f73\u5b9e\u8df5&#xff1a;<br \/>\n\u2705 \u6309\u8def\u7531\u5206\u5272&#xff08;Route-based splitting&#xff09;<br \/>\n\u2705 \u6309\u7ec4\u4ef6\u5206\u5272&#xff08;Component-based splitting&#xff09;<br \/>\n\u2705 \u7b2c\u4e09\u65b9\u5e93\u5355\u72ec\u6253\u5305&#xff08;Vendor splitting&#xff09;<\/p>\n<hr \/>\n<h4>2.2 \u63a5\u53e3\u5408\u5e76<\/h4>\n<h5>2.2.1 GraphQL&#xff08;\u63a8\u8350&#xff09;<\/h5>\n<p>\u95ee\u9898\u573a\u666f&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ RESTful API&#xff1a;3\u4e2a\u8bf7\u6c42\u83b7\u53d6\u7528\u6237\u5b8c\u6574\u4fe1\u606f<\/span><br \/>\n<span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">getUserInfo<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">userId<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> user <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token template-string\"><span class=\"token template-punctuation string\">&#096;<\/span><span class=\"token string\">\/api\/users\/<\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>userId<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token template-punctuation string\">&#096;<\/span><\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>          <span class=\"token comment\">\/\/ \u8bf7\u6c421<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> posts <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token template-string\"><span class=\"token template-punctuation string\">&#096;<\/span><span class=\"token string\">\/api\/users\/<\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>userId<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token string\">\/posts<\/span><span class=\"token template-punctuation string\">&#096;<\/span><\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>   <span class=\"token comment\">\/\/ \u8bf7\u6c422<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> comments <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token template-string\"><span class=\"token template-punctuation string\">&#096;<\/span><span class=\"token string\">\/api\/users\/<\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>userId<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token string\">\/comments<\/span><span class=\"token template-punctuation string\">&#096;<\/span><\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ \u8bf7\u6c423<\/span><\/p>\n<p>  <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">{<\/span> user<span class=\"token punctuation\">,<\/span> posts<span class=\"token punctuation\">,<\/span> comments <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token comment\">\/\/ \u603b\u8017\u65f6&#xff1a;500ms &#043; 300ms &#043; 200ms &#061; 1000ms&#xff08;\u4e32\u884c&#xff09;<\/span><\/p>\n<p>GraphQL\u65b9\u6848&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ 1\u4e2a\u8bf7\u6c42\u83b7\u53d6\u6240\u6709\u6570\u636e<\/span><br \/>\n<span class=\"token keyword\">const<\/span> query <span class=\"token operator\">&#061;<\/span> <span class=\"token template-string\"><span class=\"token template-punctuation string\">&#096;<\/span><span class=\"token string\"><br \/>\n  query GetUser($userId: ID!) {<br \/>\n    user(id: $userId) {<br \/>\n      id<br \/>\n      name<br \/>\n      avatar<br \/>\n      posts {<br \/>\n        id<br \/>\n        title<br \/>\n        content<br \/>\n      }<br \/>\n      comments {<br \/>\n        id<br \/>\n        content<br \/>\n      }<br \/>\n    }<br \/>\n  }<br \/>\n<\/span><span class=\"token template-punctuation string\">&#096;<\/span><\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">const<\/span> data <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> graphqlClient<span class=\"token punctuation\">.<\/span><span class=\"token function\">query<\/span><span class=\"token punctuation\">(<\/span>query<span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">userId<\/span><span class=\"token operator\">:<\/span> <span class=\"token number\">123<\/span> <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u603b\u8017\u65f6&#xff1a;500ms&#xff08;1\u4e2a\u8bf7\u6c42&#xff09;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u8282\u7701&#xff1a;500ms&#xff08;50%&#xff09;<\/span><\/p>\n<p>\u4f18\u52bf&#xff1a;<\/p>\n<p>\u2705 \u8bf7\u6c42\u6570\u91cf&#xff1a;3\u4e2a \u2192 1\u4e2a<br \/>\n\u2705 \u6570\u636e\u7cbe\u786e&#xff1a;\u53ea\u8fd4\u56de\u9700\u8981\u7684\u5b57\u6bb5<br \/>\n\u2705 \u907f\u514d\u8fc7\u5ea6\u83b7\u53d6&#xff08;Over-fetching&#xff09;<br \/>\n\u2705 \u907f\u514d\u83b7\u53d6\u4e0d\u8db3&#xff08;Under-fetching&#xff09;<\/p>\n<hr \/>\n<h5>2.2.2 BFF&#xff08;Backend For Frontend&#xff09;<\/h5>\n<p>\u67b6\u6784\u8bbe\u8ba1&#xff1a;<\/p>\n<p>\u4f20\u7edf\u65b9\u5f0f&#xff1a;<br \/>\n\u524d\u7aef \u2192 \u7528\u6237\u670d\u52a1 (200ms)<br \/>\n     \u2192 \u8ba2\u5355\u670d\u52a1 (300ms)<br \/>\n     \u2192 \u5546\u54c1\u670d\u52a1 (250ms)<br \/>\n\u603b\u8017\u65f6&#xff1a;750ms&#xff08;\u4e32\u884c&#xff09;\u6216 300ms&#xff08;\u5e76\u884c&#xff0c;\u4f46\u8bf7\u6c42\u591a&#xff09;<\/p>\n<p>BFF\u65b9\u5f0f&#xff1a;<br \/>\n\u524d\u7aef \u2192 BFF\u5c42 \u2192 \u7528\u6237\u670d\u52a1<br \/>\n              \u2192 \u8ba2\u5355\u670d\u52a1<br \/>\n              \u2192 \u5546\u54c1\u670d\u52a1<br \/>\nBFF\u805a\u5408\u6570\u636e \u2192 \u8fd4\u56de\u524d\u7aef<br \/>\n\u603b\u8017\u65f6&#xff1a;350ms&#xff08;BFF\u5185\u90e8\u5e76\u884c &#043; \u805a\u5408&#xff09;<\/p>\n<p>\u5b9e\u73b0\u793a\u4f8b&#xff08;Node.js BFF&#xff09;&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ BFF\u5c42&#xff1a;\u805a\u5408\u591a\u4e2a\u5fae\u670d\u52a1\u6570\u636e<\/span><br \/>\napp<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/page\/dashboard&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token parameter\">req<span class=\"token punctuation\">,<\/span> res<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token comment\">\/\/ \u5e76\u884c\u8bf7\u6c42\u591a\u4e2a\u670d\u52a1<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> <span class=\"token punctuation\">[<\/span>user<span class=\"token punctuation\">,<\/span> orders<span class=\"token punctuation\">,<\/span> products<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> Promise<span class=\"token punctuation\">.<\/span><span class=\"token function\">all<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">[<\/span><br \/>\n    <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;http:\/\/user-service\/api\/user&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;http:\/\/order-service\/api\/orders&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;http:\/\/product-service\/api\/products&#039;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token comment\">\/\/ \u6570\u636e\u805a\u5408\u3001\u5b57\u6bb5\u88c1\u526a<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> result <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">user<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n      <span class=\"token literal-property property\">id<\/span><span class=\"token operator\">:<\/span> user<span class=\"token punctuation\">.<\/span>id<span class=\"token punctuation\">,<\/span><br \/>\n      <span class=\"token literal-property property\">name<\/span><span class=\"token operator\">:<\/span> user<span class=\"token punctuation\">.<\/span>name<br \/>\n      <span class=\"token comment\">\/\/ \u53ea\u8fd4\u56de\u524d\u7aef\u9700\u8981\u7684\u5b57\u6bb5<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token literal-property property\">orderCount<\/span><span class=\"token operator\">:<\/span> orders<span class=\"token punctuation\">.<\/span>total<span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token literal-property property\">topProducts<\/span><span class=\"token operator\">:<\/span> products<span class=\"token punctuation\">.<\/span><span class=\"token function\">slice<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">5<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  res<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span>result<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u524d\u7aef&#xff1a;\u53ea\u97001\u4e2a\u8bf7\u6c42<\/span><br \/>\n<span class=\"token keyword\">const<\/span> data <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/page\/dashboard&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<hr \/>\n<h5>2.2.3 \u6279\u91cf\u63a5\u53e3\u8bbe\u8ba1<\/h5>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u524d&#xff1a;\u5faa\u73af\u8bf7\u6c42&#xff08;N\u4e2a\u8bf7\u6c42&#xff09;<\/span><br \/>\n<span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">getProductDetails<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">productIds<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> promises <span class=\"token operator\">&#061;<\/span> productIds<span class=\"token punctuation\">.<\/span><span class=\"token function\">map<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">id<\/span> <span class=\"token operator\">&#061;&gt;<\/span><br \/>\n    <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token template-string\"><span class=\"token template-punctuation string\">&#096;<\/span><span class=\"token string\">\/api\/products\/<\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>id<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token template-punctuation string\">&#096;<\/span><\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">return<\/span> Promise<span class=\"token punctuation\">.<\/span><span class=\"token function\">all<\/span><span class=\"token punctuation\">(<\/span>promises<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token function\">getProductDetails<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">[<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">3<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">4<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">5<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ 5\u4e2a\u8bf7\u6c42<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u540e&#xff1a;\u6279\u91cf\u63a5\u53e3&#xff08;1\u4e2a\u8bf7\u6c42&#xff09;<\/span><br \/>\n<span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">getProductDetailsBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">productIds<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">return<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/products\/batch&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">method<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;POST&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token literal-property property\">body<\/span><span class=\"token operator\">:<\/span> <span class=\"token constant\">JSON<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">stringify<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">ids<\/span><span class=\"token operator\">:<\/span> productIds <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token function\">getProductDetailsBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">[<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">3<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">4<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">5<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ 1\u4e2a\u8bf7\u6c42<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u540e\u7aef\u5b9e\u73b0&#xff08;\u793a\u4f8b&#xff09;<\/span><br \/>\napp<span class=\"token punctuation\">.<\/span><span class=\"token function\">post<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/products\/batch&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token parameter\">req<span class=\"token punctuation\">,<\/span> res<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> <span class=\"token punctuation\">{<\/span> ids <span class=\"token punctuation\">}<\/span> <span class=\"token operator\">&#061;<\/span> req<span class=\"token punctuation\">.<\/span>body<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> products <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> ProductModel<span class=\"token punctuation\">.<\/span><span class=\"token function\">find<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">_id<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span> $<span class=\"token keyword\">in<\/span><span class=\"token operator\">:<\/span> ids <span class=\"token punctuation\">}<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  res<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span>products<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<hr \/>\n<h4>2.3 \u61d2\u52a0\u8f7d\u4e0e\u6309\u9700\u52a0\u8f7d<\/h4>\n<h5>2.3.1 \u8def\u7531\u61d2\u52a0\u8f7d<\/h5>\n<p><span class=\"token comment\">\/\/ React\u793a\u4f8b<\/span><br \/>\n<span class=\"token comment\">\/\/ \u4f18\u5316\u524d&#xff1a;\u6240\u6709\u8def\u7531\u7ec4\u4ef6\u4e00\u6b21\u6027\u52a0\u8f7d<\/span><br \/>\n<span class=\"token keyword\">import<\/span> Home <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;.\/pages\/Home&#039;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> About <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;.\/pages\/About&#039;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> Products <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;.\/pages\/Products&#039;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> Dashboard <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;.\/pages\/Dashboard&#039;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">const<\/span> routes <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token literal-property property\">component<\/span><span class=\"token operator\">:<\/span> Home <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/about&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token literal-property property\">component<\/span><span class=\"token operator\">:<\/span> About <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/products&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token literal-property property\">component<\/span><span class=\"token operator\">:<\/span> Products <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/dashboard&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token literal-property property\">component<\/span><span class=\"token operator\">:<\/span> Dashboard <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ Bundle\u5927\u5c0f&#xff1a;2.5 MB&#xff08;\u5305\u542b\u6240\u6709\u9875\u9762&#xff09;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u540e&#xff1a;\u8def\u7531\u61d2\u52a0\u8f7d<\/span><br \/>\n<span class=\"token keyword\">const<\/span> Home <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">lazy<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token keyword\">import<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;.\/pages\/Home&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">const<\/span> About <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">lazy<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token keyword\">import<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;.\/pages\/About&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">const<\/span> Products <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">lazy<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token keyword\">import<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;.\/pages\/Products&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">const<\/span> Dashboard <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">lazy<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token keyword\">import<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;.\/pages\/Dashboard&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">const<\/span> routes <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token literal-property property\">component<\/span><span class=\"token operator\">:<\/span> Home <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/about&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token literal-property property\">component<\/span><span class=\"token operator\">:<\/span> About <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/products&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token literal-property property\">component<\/span><span class=\"token operator\">:<\/span> Products <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/dashboard&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token literal-property property\">component<\/span><span class=\"token operator\">:<\/span> Dashboard <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u9996\u5c4fBundle&#xff1a;500 KB&#xff08;\u53ea\u52a0\u8f7dHome\u9875\u9762&#xff09;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u5176\u4ed6\u9875\u9762&#xff1a;\u6309\u9700\u52a0\u8f7d&#xff08;\u8fdb\u5165\u65f6\u624d\u4e0b\u8f7d&#xff09;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f7f\u7528<\/span><br \/>\n<span class=\"token keyword\">function<\/span> <span class=\"token function\">App<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span>Suspense fallback<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token operator\">&lt;<\/span>Loading <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">}<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token operator\">&lt;<\/span>Routes<span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token punctuation\">{<\/span>routes<span class=\"token punctuation\">.<\/span><span class=\"token function\">map<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">route<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n          <span class=\"token operator\">&lt;<\/span>Route key<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>route<span class=\"token punctuation\">.<\/span>path<span class=\"token punctuation\">}<\/span> <span class=\"token punctuation\">{<\/span><span class=\"token operator\">&#8230;<\/span>route<span class=\"token punctuation\">}<\/span> <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">}<\/span><br \/>\n      <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>Routes<span class=\"token operator\">&gt;<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>Suspense<span class=\"token operator\">&gt;<\/span><br \/>\n  <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>Vue\u793a\u4f8b&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ Vue Router\u61d2\u52a0\u8f7d<\/span><br \/>\n<span class=\"token keyword\">const<\/span> routes <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token function-variable function\">component<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token keyword\">import<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;.\/views\/Home.vue&#039;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/about&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token function-variable function\">component<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token keyword\">import<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;.\/views\/About.vue&#039;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u5206\u7ec4\u6253\u5305&#xff08;\u76f8\u5173\u9875\u9762\u6253\u5305\u5728\u4e00\u8d77&#xff09;<\/span><br \/>\n<span class=\"token keyword\">const<\/span> routes <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/user\/profile&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token function-variable function\">component<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token keyword\">import<\/span><span class=\"token punctuation\">(<\/span><span class=\"token comment\">\/* webpackChunkName: &#034;user&#034; *\/<\/span> <span class=\"token string\">&#039;.\/views\/Profile.vue&#039;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">path<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;\/user\/settings&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token function-variable function\">component<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token keyword\">import<\/span><span class=\"token punctuation\">(<\/span><span class=\"token comment\">\/* webpackChunkName: &#034;user&#034; *\/<\/span> <span class=\"token string\">&#039;.\/views\/Settings.vue&#039;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u751f\u6210 user.[hash].js&#xff08;\u5305\u542bProfile\u548cSettings&#xff09;<\/span><\/p>\n<hr \/>\n<h5>2.3.2 \u7ec4\u4ef6\u61d2\u52a0\u8f7d<\/h5>\n<p><span class=\"token comment\">\/\/ React.lazy<\/span><br \/>\n<span class=\"token comment\">\/\/ \u4f18\u5316\u524d&#xff1a;ECharts\u56fe\u8868\u5e93\u59cb\u7ec8\u52a0\u8f7d&#xff08;500KB&#xff09;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> ReactECharts <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;echarts-for-react&#039;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">function<\/span> <span class=\"token function\">Dashboard<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span>div<span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token operator\">&lt;<\/span>h1<span class=\"token operator\">&gt;<\/span>Dashboard<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>h1<span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token punctuation\">{<\/span>showChart <span class=\"token operator\">&amp;&amp;<\/span> <span class=\"token operator\">&lt;<\/span>ReactECharts option<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>option<span class=\"token punctuation\">}<\/span> <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>div<span class=\"token operator\">&gt;<\/span><br \/>\n  <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u540e&#xff1a;\u70b9\u51fb\u65f6\u624d\u52a0\u8f7d<\/span><br \/>\n<span class=\"token keyword\">const<\/span> ReactECharts <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">lazy<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token keyword\">import<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;echarts-for-react&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">function<\/span> <span class=\"token function\">Dashboard<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> <span class=\"token punctuation\">[<\/span>showChart<span class=\"token punctuation\">,<\/span> setShowChart<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">useState<\/span><span class=\"token punctuation\">(<\/span><span class=\"token boolean\">false<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span>div<span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token operator\">&lt;<\/span>h1<span class=\"token operator\">&gt;<\/span>Dashboard<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>h1<span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token operator\">&lt;<\/span>button onClick<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token function\">setShowChart<\/span><span class=\"token punctuation\">(<\/span><span class=\"token boolean\">true<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">}<\/span><span class=\"token operator\">&gt;<\/span>\u663e\u793a\u56fe\u8868<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>button<span class=\"token operator\">&gt;<\/span><\/p>\n<p>      <span class=\"token punctuation\">{<\/span>showChart <span class=\"token operator\">&amp;&amp;<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span>Suspense fallback<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token operator\">&lt;<\/span>div<span class=\"token operator\">&gt;<\/span>\u52a0\u8f7d\u4e2d<span class=\"token operator\">&#8230;<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>div<span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">}<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n          <span class=\"token operator\">&lt;<\/span>ReactECharts option<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>option<span class=\"token punctuation\">}<\/span> <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>Suspense<span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>div<span class=\"token operator\">&gt;<\/span><br \/>\n  <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token comment\">\/\/ \u9996\u6b21\u52a0\u8f7d&#xff1a;\u4e0d\u5305\u542b500KB\u7684ECharts<\/span><br \/>\n<span class=\"token comment\">\/\/ \u70b9\u51fb\u6309\u94ae\u540e&#xff1a;\u52a8\u6001\u52a0\u8f7dECharts<\/span><\/p>\n<hr \/>\n<h5>2.3.3 \u56fe\u7247\u61d2\u52a0\u8f7d<\/h5>\n<p><span class=\"token comment\">\/\/ \u65b9\u68481&#xff1a;\u539f\u751fIntersection Observer<\/span><br \/>\n<span class=\"token keyword\">function<\/span> <span class=\"token function\">LazyImage<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\"><span class=\"token punctuation\">{<\/span> src<span class=\"token punctuation\">,<\/span> alt <span class=\"token punctuation\">}<\/span><\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> imgRef <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">useRef<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token function\">useEffect<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">const<\/span> observer <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">IntersectionObserver<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">entries<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n      entries<span class=\"token punctuation\">.<\/span><span class=\"token function\">forEach<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">entry<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>entry<span class=\"token punctuation\">.<\/span>isIntersecting<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n          <span class=\"token keyword\">const<\/span> img <span class=\"token operator\">&#061;<\/span> entry<span class=\"token punctuation\">.<\/span>target<span class=\"token punctuation\">;<\/span><br \/>\n          img<span class=\"token punctuation\">.<\/span>src <span class=\"token operator\">&#061;<\/span> img<span class=\"token punctuation\">.<\/span>dataset<span class=\"token punctuation\">.<\/span>src<span class=\"token punctuation\">;<\/span><br \/>\n          observer<span class=\"token punctuation\">.<\/span><span class=\"token function\">unobserve<\/span><span class=\"token punctuation\">(<\/span>img<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n      <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>    observer<span class=\"token punctuation\">.<\/span><span class=\"token function\">observe<\/span><span class=\"token punctuation\">(<\/span>imgRef<span class=\"token punctuation\">.<\/span>current<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>    <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> observer<span class=\"token punctuation\">.<\/span><span class=\"token function\">disconnect<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">return<\/span> <span class=\"token operator\">&lt;<\/span>img ref<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>imgRef<span class=\"token punctuation\">}<\/span> data<span class=\"token operator\">&#8211;<\/span>src<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>src<span class=\"token punctuation\">}<\/span> alt<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>alt<span class=\"token punctuation\">}<\/span> <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u65b9\u68482&#xff1a;loading&#061;&#034;lazy&#034;&#xff08;\u539f\u751f\u652f\u6301&#xff0c;\u6700\u7b80\u5355&#xff09;<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span>img src<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;image.jpg&#034;<\/span> loading<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;lazy&#034;<\/span> alt<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;\u4ea7\u54c1\u56fe\u7247&#034;<\/span> <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u65b9\u68483&#xff1a;react-lazyload&#xff08;\u7b2c\u4e09\u65b9\u5e93&#xff09;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> LazyLoad <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;react-lazyload&#039;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token operator\">&lt;<\/span>LazyLoad height<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token number\">200<\/span><span class=\"token punctuation\">}<\/span> offset<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">}<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n  <span class=\"token operator\">&lt;<\/span>img src<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;image.jpg&#034;<\/span> alt<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;\u4ea7\u54c1\u56fe\u7247&#034;<\/span> <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>LazyLoad<span class=\"token operator\">&gt;<\/span><\/p>\n<p>\u6548\u679c\u5bf9\u6bd4&#xff1a;<\/p>\n<p>\u4f18\u5316\u524d&#xff1a;<br \/>\n&#8211; \u9875\u9762\u52a0\u8f7d\u65f6&#xff1a;\u4e0b\u8f7d\u6240\u6709\u56fe\u7247&#xff08;63\u4e2a&#xff0c;9.5MB&#xff09;<br \/>\n&#8211; \u7f51\u7edc\u8017\u65f6&#xff1a;8\u79d2<\/p>\n<p>\u4f18\u5316\u540e&#xff08;\u61d2\u52a0\u8f7d&#xff09;&#xff1a;<br \/>\n&#8211; \u9875\u9762\u52a0\u8f7d\u65f6&#xff1a;\u53ea\u4e0b\u8f7d\u9996\u5c4f\u56fe\u7247&#xff08;8\u4e2a&#xff0c;1.2MB&#xff09;<br \/>\n&#8211; \u7f51\u7edc\u8017\u65f6&#xff1a;1.5\u79d2<br \/>\n&#8211; \u6eda\u52a8\u65f6&#xff1a;\u6309\u9700\u52a0\u8f7d\u5269\u4f59\u56fe\u7247<\/p>\n<hr \/>\n<h4>2.4 \u9884\u52a0\u8f7d\u4e0e\u9884\u8fde\u63a5<\/h4>\n<h5>2.4.1 dns-prefetch&#xff08;DNS\u9884\u89e3\u6790&#xff09;<\/h5>\n<p><span class=\"token comment\">&lt;!&#8211; \u63d0\u524d\u89e3\u6790\u7b2c\u4e09\u65b9\u57df\u540d &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>dns-prefetch<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>https:\/\/cdn.example.com<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>dns-prefetch<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>https:\/\/api.example.com<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>dns-prefetch<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>https:\/\/analytics.google.com<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><\/p>\n<p>\u6548\u679c&#xff1a;<br \/>\n&#8211; \u8282\u7701DNS\u67e5\u8be2\u65f6\u95f4&#xff08;20-120ms&#xff09;<br \/>\n&#8211; \u9002\u7528\u4e8e\u5373\u5c06\u8bbf\u95ee\u7684\u57df\u540d<\/p>\n<h5>2.4.2 preconnect&#xff08;\u9884\u8fde\u63a5&#xff09;<\/h5>\n<p><span class=\"token comment\">&lt;!&#8211; \u63d0\u524d\u5efa\u7acbTCP\u8fde\u63a5 &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>preconnect<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>https:\/\/cdn.example.com<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>preconnect<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>https:\/\/api.example.com<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><\/p>\n<p>\u6548\u679c&#xff1a;<br \/>\n&#8211; DNS\u89e3\u6790 &#043; TCP\u63e1\u624b &#043; TLS\u534f\u5546<br \/>\n&#8211; \u8282\u7701\u65f6\u95f4&#xff1a;100-300ms<br \/>\n&#8211; \u6ce8\u610f&#xff1a;\u6700\u591a3-6\u4e2a&#xff08;\u6d4f\u89c8\u5668\u9650\u5236&#xff09;<\/p>\n<h5>2.4.3 prefetch&#xff08;\u9884\u83b7\u53d6&#xff09;<\/h5>\n<p><span class=\"token comment\">&lt;!&#8211; \u9884\u83b7\u53d6\u4e0b\u4e00\u4e2a\u9875\u9762\u53ef\u80fd\u7528\u5230\u7684\u8d44\u6e90 &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>prefetch<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>\/next-page.js<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>prefetch<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>\/next-page.css<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><\/p>\n<p><span class=\"token comment\">&lt;!&#8211; React Router\u4e2d\u52a8\u6001\u9884\u83b7\u53d6 &#8211;&gt;<\/span><br \/>\n&lt;Link<br \/>\n  to&#061;&#034;\/products&#034;<br \/>\n  onMouseEnter&#061;{() &#061;&gt; {<br \/>\n    import(&#039;.\/pages\/Products&#039;); \/\/ \u9f20\u6807\u60ac\u505c\u65f6\u9884\u52a0\u8f7d<br \/>\n  }}<br \/>\n&gt;<br \/>\n  \u5546\u54c1\u5217\u8868<br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;\/<\/span>Link<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><\/p>\n<p>\u6548\u679c&#xff1a;<br \/>\n&#8211; \u7a7a\u95f2\u65f6\u4e0b\u8f7d\u8d44\u6e90&#xff08;\u4f4e\u4f18\u5148\u7ea7&#xff09;<br \/>\n&#8211; \u4e0b\u6b21\u8bbf\u95ee&#xff1a;\u4ece\u7f13\u5b58\u52a0\u8f7d&#xff08;\u77ac\u95f4\u6253\u5f00&#xff09;<\/p>\n<h5>2.4.4 preload&#xff08;\u9884\u52a0\u8f7d&#xff09;<\/h5>\n<p><span class=\"token comment\">&lt;!&#8211; \u9884\u52a0\u8f7d\u5173\u952e\u8d44\u6e90 &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>preload<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>\/fonts\/custom.woff2<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">as<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>font<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">crossorigin<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>preload<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>\/critical.css<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">as<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>style<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>link<\/span> <span class=\"token attr-name\">rel<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>preload<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">href<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>\/hero-image.jpg<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">as<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>image<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><\/p>\n<p>\u6548\u679c&#xff1a;<br \/>\n&#8211; \u9ad8\u4f18\u5148\u7ea7\u52a0\u8f7d<br \/>\n&#8211; \u907f\u514d\u963b\u585e\u6e32\u67d3<br \/>\n&#8211; \u9002\u7528\u4e8e\u9996\u5c4f\u5173\u952e\u8d44\u6e90<\/p>\n<p>\u56db\u79cd\u9884\u52a0\u8f7d\u5bf9\u6bd4&#xff1a;<\/p>\n<p>\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510<br \/>\n\u2502 \u6280\u672f         \u2502 \u65f6\u673a          \u2502 \u4f18\u5148\u7ea7   \u2502 \u9002\u7528\u573a\u666f  \u2502<br \/>\n\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524<br \/>\n\u2502 dns-prefetch\u2502 \u63d0\u524dDNS\u89e3\u6790   \u2502 \u4f4e       \u2502 \u7b2c\u4e09\u65b9\u57df\u540d\u2502<br \/>\n\u2502 preconnect  \u2502 \u63d0\u524d\u5efa\u7acb\u8fde\u63a5  \u2502 \u4e2d       \u2502 API\u57df\u540d   \u2502<br \/>\n\u2502 prefetch    \u2502 \u7a7a\u95f2\u65f6\u4e0b\u8f7d    \u2502 \u4f4e       \u2502 \u4e0b\u4e00\u9875\u9762  \u2502<br \/>\n\u2502 preload     \u2502 \u7acb\u5373\u4e0b\u8f7d      \u2502 \u9ad8       \u2502 \u5173\u952e\u8d44\u6e90  \u2502<br \/>\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518<\/p>\n<hr \/>\n<h3>\u4e09\u3001\u51cf\u5c0f\u8bf7\u6c42\u4f53\u79ef<\/h3>\n<h4>3.1 \u6570\u636e\u538b\u7f29<\/h4>\n<h5>3.1.1 Gzip \/ Brotli\u538b\u7f29<\/h5>\n<p># Nginx\u914d\u7f6e<br \/>\nhttp {<br \/>\n  # \u5f00\u542fGzip<br \/>\n  gzip on;<br \/>\n  gzip_min_length 1k;<br \/>\n  gzip_comp_level 6;<br \/>\n  gzip_types text\/plain text\/css application\/json application\/javascript;<br \/>\n  gzip_vary on;<\/p>\n<p>  # \u5f00\u542fBrotli&#xff08;\u66f4\u9ad8\u538b\u7f29\u7387&#xff09;<br \/>\n  brotli on;<br \/>\n  brotli_comp_level 6;<br \/>\n  brotli_types text\/plain text\/css application\/json application\/javascript;<br \/>\n}<\/p>\n<p>\u538b\u7f29\u6548\u679c&#xff1a;<br \/>\n\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510<br \/>\n\u2502 \u6587\u4ef6\u7c7b\u578b      \u2502 \u539f\u59cb\u5927\u5c0f  \u2502 Gzip\u538b\u7f29 \u2502 Brotli\u538b\u7f29\u2502<br \/>\n\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524<br \/>\n\u2502 app.js       \u2502 500 KB   \u2502 150 KB   \u2502 120 KB   \u2502<br \/>\n\u2502 styles.css   \u2502 200 KB   \u2502 40 KB    \u2502 30 KB    \u2502<br \/>\n\u2502 data.json    \u2502 1 MB     \u2502 100 KB   \u2502 80 KB    \u2502<br \/>\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518<\/p>\n<p>\u538b\u7f29\u7387&#xff1a;70-90%<\/p>\n<h5>3.1.2 \u56fe\u7247\u538b\u7f29<\/h5>\n<p><span class=\"token comment\"># \u4f7f\u7528imagemin-webpack-plugin<\/span><br \/>\n<span class=\"token function\">npm<\/span> <span class=\"token function\">install<\/span> imagemin-webpack-plugin &#8211;save-dev<\/p>\n<p><span class=\"token comment\"># webpack.config.js<\/span><br \/>\nconst ImageminPlugin <span class=\"token operator\">&#061;<\/span> require<span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;imagemin-webpack-plugin&#039;<\/span><span class=\"token punctuation\">)<\/span>.default<span class=\"token punctuation\">;<\/span><\/p>\n<p>module.exports <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  plugins: <span class=\"token punctuation\">[<\/span><br \/>\n    new ImageminPlugin<span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span><br \/>\n      pngquant: <span class=\"token punctuation\">{<\/span><br \/>\n        quality: <span class=\"token string\">&#039;80-90&#039;<\/span>  \/\/ PNG\u538b\u7f29\u8d28\u91cf<br \/>\n      <span class=\"token punctuation\">}<\/span>,<br \/>\n      jpegtran: <span class=\"token punctuation\">{<\/span><br \/>\n        progressive: <span class=\"token boolean\">true<\/span>  \/\/ JPEG\u6e10\u8fdb\u5f0f<br \/>\n      <span class=\"token punctuation\">}<\/span>,<br \/>\n      optipng: <span class=\"token punctuation\">{<\/span><br \/>\n        optimizationLevel: <span class=\"token number\">5<\/span>  \/\/ PNG\u4f18\u5316\u7ea7\u522b<br \/>\n      <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">]<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>\u538b\u7f29\u6548\u679c&#xff1a;<br \/>\n\u539f\u56fe&#xff1a;2 MB&#xff08;4000&#215;3000 PNG&#xff09;<br \/>\n\u538b\u7f29\u540e&#xff1a;200 KB&#xff08;\u8d28\u91cf\u51e0\u4e4e\u65e0\u635f&#xff09;<br \/>\n\u538b\u7f29\u7387&#xff1a;90%<\/p>\n<p>\u73b0\u4ee3\u56fe\u7247\u683c\u5f0f&#xff1a;<\/p>\n<p><span class=\"token comment\">&lt;!&#8211; WebP\u683c\u5f0f&#xff08;\u63a8\u8350&#xff09; &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>picture<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n  <span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>source<\/span> <span class=\"token attr-name\">srcset<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>image.webp<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">type<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>image\/webp<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n  <span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>source<\/span> <span class=\"token attr-name\">srcset<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>image.jpg<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">type<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>image\/jpeg<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n  <span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>img<\/span> <span class=\"token attr-name\">src<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>image.jpg<span class=\"token punctuation\">&#034;<\/span><\/span> <span class=\"token attr-name\">alt<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>\u4ea7\u54c1\u56fe\u7247<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;\/<\/span>picture<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><\/p>\n<p>\u683c\u5f0f\u5bf9\u6bd4&#xff1a;<br \/>\n\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510<br \/>\n\u2502 \u683c\u5f0f  \u2502 \u6587\u4ef6\u5927\u5c0f  \u2502 \u538b\u7f29\u7387 \u2502 \u652f\u6301\u5ea6  \u2502<br \/>\n\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524<br \/>\n\u2502 JPEG \u2502 150 KB   \u2502 \u57fa\u51c6   \u2502 100%   \u2502<br \/>\n\u2502 PNG  \u2502 200 KB   \u2502 -33%   \u2502 100%   \u2502<br \/>\n\u2502 WebP \u2502 80 KB    \u2502 &#043;47%   \u2502 96%    \u2502<br \/>\n\u2502 AVIF \u2502 50 KB    \u2502 &#043;67%   \u2502 85%    \u2502<br \/>\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518<\/p>\n<hr \/>\n<h4>3.2 \u6570\u636e\u88c1\u526a<\/h4>\n<h5>3.2.1 \u5b57\u6bb5\u8fc7\u6ee4<\/h5>\n<p><span class=\"token comment\">\/\/ \u540e\u7aef&#xff1a;\u53ea\u8fd4\u56de\u524d\u7aef\u9700\u8981\u7684\u5b57\u6bb5<\/span><br \/>\n<span class=\"token comment\">\/\/ \u4f18\u5316\u524d&#xff1a;\u8fd4\u56de\u5b8c\u6574\u7528\u6237\u5bf9\u8c61<\/span><br \/>\napp<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/users\/:id&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token parameter\">req<span class=\"token punctuation\">,<\/span> res<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> user <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> User<span class=\"token punctuation\">.<\/span><span class=\"token function\">findById<\/span><span class=\"token punctuation\">(<\/span>req<span class=\"token punctuation\">.<\/span>params<span class=\"token punctuation\">.<\/span>id<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  res<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span>user<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u54cd\u5e94\u6570\u636e&#xff1a;2 KB&#xff08;\u5305\u542bpassword\u3001internalId\u7b49\u654f\u611f\u5b57\u6bb5&#xff09;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u540e&#xff1a;\u5b57\u6bb5\u8fc7\u6ee4<\/span><br \/>\napp<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/users\/:id&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token parameter\">req<span class=\"token punctuation\">,<\/span> res<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> user <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> User<span class=\"token punctuation\">.<\/span><span class=\"token function\">findById<\/span><span class=\"token punctuation\">(<\/span>req<span class=\"token punctuation\">.<\/span>params<span class=\"token punctuation\">.<\/span>id<span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">.<\/span><span class=\"token function\">select<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;id name avatar email createdAt&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ \u53ea\u9009\u62e9\u9700\u8981\u7684\u5b57\u6bb5<\/span><br \/>\n  res<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span>user<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u54cd\u5e94\u6570\u636e&#xff1a;300 B&#xff08;\u51cf\u5c1185%&#xff09;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u524d\u7aef&#xff1a;GraphQL\u65b9\u5f0f<\/span><br \/>\nquery <span class=\"token function\">GetUser<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\"><span class=\"token literal-property property\">$id<\/span><span class=\"token operator\">:<\/span> <span class=\"token constant\">ID<\/span><span class=\"token operator\">!<\/span><\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token function\">user<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\"><span class=\"token literal-property property\">id<\/span><span class=\"token operator\">:<\/span> $id<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    id<br \/>\n    name<br \/>\n    avatar<br \/>\n    # \u53ea\u8bf7\u6c42\u9700\u8981\u7684\u5b57\u6bb5<br \/>\n  <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h5>3.2.2 \u5206\u9875\u52a0\u8f7d<\/h5>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u524d&#xff1a;\u4e00\u6b21\u6027\u8fd4\u56de2000\u6761\u6570\u636e<\/span><br \/>\napp<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/products&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token parameter\">req<span class=\"token punctuation\">,<\/span> res<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> products <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> Product<span class=\"token punctuation\">.<\/span><span class=\"token function\">find<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  res<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span>products<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u54cd\u5e94\u5927\u5c0f&#xff1a;3.2 MB<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u540e&#xff1a;\u5206\u9875<\/span><br \/>\napp<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/products&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token parameter\">req<span class=\"token punctuation\">,<\/span> res<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> <span class=\"token punctuation\">{<\/span> page <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> pageSize <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">20<\/span> <span class=\"token punctuation\">}<\/span> <span class=\"token operator\">&#061;<\/span> req<span class=\"token punctuation\">.<\/span>query<span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">const<\/span> products <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> Product<span class=\"token punctuation\">.<\/span><span class=\"token function\">find<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">.<\/span><span class=\"token function\">skip<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span>page <span class=\"token operator\">&#8211;<\/span> <span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">*<\/span> pageSize<span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">.<\/span><span class=\"token function\">limit<\/span><span class=\"token punctuation\">(<\/span>pageSize<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">const<\/span> total <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> Product<span class=\"token punctuation\">.<\/span><span class=\"token function\">countDocuments<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  res<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">data<\/span><span class=\"token operator\">:<\/span> products<span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token literal-property property\">pagination<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n      <span class=\"token literal-property property\">page<\/span><span class=\"token operator\">:<\/span> <span class=\"token function\">parseInt<\/span><span class=\"token punctuation\">(<\/span>page<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n      <span class=\"token literal-property property\">pageSize<\/span><span class=\"token operator\">:<\/span> <span class=\"token function\">parseInt<\/span><span class=\"token punctuation\">(<\/span>pageSize<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n      total<span class=\"token punctuation\">,<\/span><br \/>\n      <span class=\"token literal-property property\">totalPages<\/span><span class=\"token operator\">:<\/span> Math<span class=\"token punctuation\">.<\/span><span class=\"token function\">ceil<\/span><span class=\"token punctuation\">(<\/span>total <span class=\"token operator\">\/<\/span> pageSize<span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u9996\u6b21\u54cd\u5e94&#xff1a;32 KB&#xff08;20\u6761\u6570\u636e&#xff09;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u51cf\u5c11&#xff1a;99%<\/span><\/p>\n<h5>3.2.3 \u865a\u62df\u6eda\u52a8&#xff08;Virtual Scrolling&#xff09;<\/h5>\n<p><span class=\"token comment\">\/\/ React-Window\u793a\u4f8b<\/span><br \/>\n<span class=\"token keyword\">import<\/span> <span class=\"token punctuation\">{<\/span> FixedSizeList <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;react-window&#039;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u524d&#xff1a;\u6e32\u67d32000\u4e2aDOM\u8282\u70b9<\/span><br \/>\n<span class=\"token keyword\">function<\/span> <span class=\"token function\">ProductList<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\"><span class=\"token punctuation\">{<\/span> products <span class=\"token punctuation\">}<\/span><\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span>div<span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token punctuation\">{<\/span>products<span class=\"token punctuation\">.<\/span><span class=\"token function\">map<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">product<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span>ProductCard key<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>product<span class=\"token punctuation\">.<\/span>id<span class=\"token punctuation\">}<\/span> data<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>product<span class=\"token punctuation\">}<\/span> <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>div<span class=\"token operator\">&gt;<\/span><br \/>\n  <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token comment\">\/\/ \u95ee\u9898&#xff1a;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; 2000\u4e2aDOM\u8282\u70b9<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u6e32\u67d3\u65f6\u95f4&#xff1a;1.5s<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u5185\u5b58\u5360\u7528&#xff1a;150 MB<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u540e&#xff1a;\u865a\u62df\u6eda\u52a8&#xff08;\u53ea\u6e32\u67d3\u53ef\u89c1\u90e8\u5206&#xff09;<\/span><br \/>\n<span class=\"token keyword\">function<\/span> <span class=\"token function\">ProductList<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\"><span class=\"token punctuation\">{<\/span> products <span class=\"token punctuation\">}<\/span><\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span>FixedSizeList<br \/>\n      height<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token number\">600<\/span><span class=\"token punctuation\">}<\/span>        <span class=\"token comment\">\/\/ \u5bb9\u5668\u9ad8\u5ea6<\/span><br \/>\n      itemCount<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>products<span class=\"token punctuation\">.<\/span>length<span class=\"token punctuation\">}<\/span><br \/>\n      itemSize<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">}<\/span>      <span class=\"token comment\">\/\/ \u6bcf\u9879\u9ad8\u5ea6<\/span><br \/>\n      width<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;100%&#034;<\/span><br \/>\n    <span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token punctuation\">{<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\"><span class=\"token punctuation\">{<\/span> index<span class=\"token punctuation\">,<\/span> style <span class=\"token punctuation\">}<\/span><\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">(<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span>div style<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>style<span class=\"token punctuation\">}<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n          <span class=\"token operator\">&lt;<\/span>ProductCard data<span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">{<\/span>products<span class=\"token punctuation\">[<\/span>index<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">}<\/span> <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>div<span class=\"token operator\">&gt;<\/span><br \/>\n      <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>FixedSizeList<span class=\"token operator\">&gt;<\/span><br \/>\n  <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token comment\">\/\/ \u4f18\u5316\u6548\u679c&#xff1a;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u53ea\u6e32\u67d37\u4e2a\u53ef\u89c1DOM\u8282\u70b9&#xff08;600\/100 &#061; 6&#xff0c;&#043;1\u7f13\u51b2&#xff09;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u6e32\u67d3\u65f6\u95f4&#xff1a;50ms<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u5185\u5b58\u5360\u7528&#xff1a;5 MB<\/span><\/p>\n<hr \/>\n<h4>3.3 Tree Shaking&#xff08;\u6811\u6447&#xff09;<\/h4>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u524d&#xff1a;\u5f15\u5165\u6574\u4e2alodash\u5e93<\/span><br \/>\n<span class=\"token keyword\">import<\/span> _ <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;lodash&#039;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n_<span class=\"token punctuation\">.<\/span><span class=\"token function\">debounce<\/span><span class=\"token punctuation\">(<\/span>func<span class=\"token punctuation\">,<\/span> <span class=\"token number\">300<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ Bundle\u589e\u52a0&#xff1a;70 KB<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u540e&#xff1a;\u6309\u9700\u5f15\u5165<\/span><br \/>\n<span class=\"token keyword\">import<\/span> debounce <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;lodash\/debounce&#039;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ Bundle\u589e\u52a0&#xff1a;2 KB<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u66f4\u597d\u7684\u65b9\u5f0f&#xff1a;\u4f7f\u7528lodash-es&#xff08;\u652f\u6301Tree Shaking&#xff09;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> <span class=\"token punctuation\">{<\/span> debounce <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;lodash-es&#039;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u914d\u5408Webpack Tree Shaking&#xff0c;\u81ea\u52a8\u79fb\u9664\u672a\u4f7f\u7528\u4ee3\u7801<\/span><\/p>\n<p><span class=\"token comment\">\/\/ package.json\u914d\u7f6e<\/span><br \/>\n<span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token string-property property\">&#034;sideEffects&#034;<\/span><span class=\"token operator\">:<\/span> <span class=\"token boolean\">false<\/span>  <span class=\"token comment\">\/\/ \u6807\u8bb0\u4e3a\u65e0\u526f\u4f5c\u7528&#xff0c;\u5141\u8bb8Tree Shaking<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ webpack.config.js<\/span><br \/>\nmodule<span class=\"token punctuation\">.<\/span>exports <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token literal-property property\">mode<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">&#039;production&#039;<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ \u751f\u4ea7\u6a21\u5f0f\u81ea\u52a8\u5f00\u542fTree Shaking<\/span><br \/>\n  <span class=\"token literal-property property\">optimization<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">usedExports<\/span><span class=\"token operator\">:<\/span> <span class=\"token boolean\">true<\/span>  <span class=\"token comment\">\/\/ \u6807\u8bb0\u672a\u4f7f\u7528\u7684\u5bfc\u51fa<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<hr \/>\n<h3>\u56db\u3001\u63d0\u5347\u8bf7\u6c42\u901f\u5ea6<\/h3>\n<h4>4.1 CDN\u52a0\u901f<\/h4>\n<p><span class=\"token comment\">&lt;!&#8211; \u4f18\u5316\u524d&#xff1a;\u9759\u6001\u8d44\u6e90\u4ece\u6e90\u7ad9\u52a0\u8f7d &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>script<\/span> <span class=\"token attr-name\">src<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>https:\/\/www.example.com\/static\/app.js<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><span class=\"token script\"><\/span><span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;\/<\/span>script<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; \u7528\u6237\u5728\u5e7f\u5dde&#xff0c;\u670d\u52a1\u5668\u5728\u5317\u4eac &#8211;&gt;<\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; \u7f51\u7edc\u5ef6\u8fdf&#xff1a;50ms RTT \u00d7 3\u6b21\u63e1\u624b &#061; 150ms &#8211;&gt;<\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; \u4e0b\u8f7d\u65f6\u95f4&#xff1a;500KB \u00f7 5MB\/s &#061; 100ms &#8211;&gt;<\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; \u603b\u8017\u65f6&#xff1a;250ms &#8211;&gt;<\/span><\/p>\n<p><span class=\"token comment\">&lt;!&#8211; \u4f18\u5316\u540e&#xff1a;\u4f7f\u7528CDN &#8211;&gt;<\/span><br \/>\n<span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;<\/span>script<\/span> <span class=\"token attr-name\">src<\/span><span class=\"token attr-value\"><span class=\"token punctuation attr-equals\">&#061;<\/span><span class=\"token punctuation\">&#034;<\/span>https:\/\/cdn.example.com\/static\/app.js<span class=\"token punctuation\">&#034;<\/span><\/span><span class=\"token punctuation\">&gt;<\/span><\/span><span class=\"token script\"><\/span><span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\">&lt;\/<\/span>script<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; CDN\u8282\u70b9\u5728\u5e7f\u5dde&#xff08;\u5c31\u8fd1\u8bbf\u95ee&#xff09;&#8211;&gt;<\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; \u7f51\u7edc\u5ef6\u8fdf&#xff1a;5ms RTT \u00d7 3\u6b21\u63e1\u624b &#061; 15ms &#8211;&gt;<\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; \u4e0b\u8f7d\u65f6\u95f4&#xff1a;500KB \u00f7 50MB\/s &#061; 10ms &#8211;&gt;<\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; \u603b\u8017\u65f6&#xff1a;25ms &#8211;&gt;<\/span><br \/>\n<span class=\"token comment\">&lt;!&#8211; \u63d0\u5347&#xff1a;90% &#8211;&gt;<\/span><\/p>\n<p>CDN\u914d\u7f6e\u793a\u4f8b&#xff08;\u963f\u91cc\u4e91OSS &#043; CDN&#xff09;&#xff1a;<br \/>\n1. \u4e0a\u4f20\u9759\u6001\u8d44\u6e90\u5230OSS<br \/>\n2. \u7ed1\u5b9aCDN\u57df\u540d<br \/>\n3. \u914d\u7f6e\u7f13\u5b58\u7b56\u7565&#xff1a;<br \/>\n   &#8211; HTML: \u4e0d\u7f13\u5b58<br \/>\n   &#8211; JS\/CSS: 1\u5e74&#xff08;\u6587\u4ef6\u540d\u5e26hash&#xff09;<br \/>\n   &#8211; \u56fe\u7247: 1\u5e74<\/p>\n<hr \/>\n<h4>4.2 HTTP\/2<\/h4>\n<p>HTTP\/1.1\u95ee\u9898&#xff1a;<br \/>\n&#8211; \u6d4f\u89c8\u5668\u9650\u52366\u4e2a\u5e76\u53d1\u8fde\u63a5<br \/>\n&#8211; \u961f\u5934\u963b\u585e&#xff08;HOL Blocking&#xff09;<br \/>\n&#8211; \u91cd\u590d\u7684Header<\/p>\n<p>HTTP\/2\u4f18\u52bf&#xff1a;<br \/>\n\u2705 \u591a\u8def\u590d\u7528&#xff08;Multiplexing&#xff09;<br \/>\n   &#8211; 1\u4e2a\u8fde\u63a5&#xff0c;\u65e0\u9650\u5236\u5e76\u53d1\u8bf7\u6c42<br \/>\n   &#8211; \u89e3\u51b3\u961f\u5934\u963b\u585e<br \/>\n\u2705 Header\u538b\u7f29&#xff08;HPACK&#xff09;<br \/>\n   &#8211; \u51cf\u5c11\u91cd\u590dHeader<br \/>\n   &#8211; \u8282\u7701\u5e26\u5bbd<br \/>\n\u2705 Server Push&#xff08;\u670d\u52a1\u5668\u63a8\u9001&#xff09;<br \/>\n   &#8211; \u4e3b\u52a8\u63a8\u9001CSS\u3001JS<br \/>\n   &#8211; \u65e0\u9700\u7b49\u5f85\u8bf7\u6c42<\/p>\n<p>\u6548\u679c\u5bf9\u6bd4&#xff1a;<br \/>\nHTTP\/1.1&#xff1a;\u52a0\u8f7d100\u4e2a\u8d44\u6e90<br \/>\n\u251c\u2500\u2500 6\u4e2a\u5e76\u53d1<br \/>\n\u251c\u2500\u2500 \u9700\u898117\u8f6e&#xff08;100\/6&#xff09;<br \/>\n\u251c\u2500\u2500 \u6bcf\u8f6e\u7b49\u5f85\u5ef6\u8fdf&#xff1a;50ms<br \/>\n\u2514\u2500\u2500 \u603b\u989d\u5916\u5ef6\u8fdf&#xff1a;850ms<\/p>\n<p>HTTP\/2&#xff1a;\u52a0\u8f7d100\u4e2a\u8d44\u6e90<br \/>\n\u251c\u2500\u2500 \u65e0\u9650\u5e76\u53d1<br \/>\n\u251c\u2500\u2500 1\u8f6e\u5b8c\u6210<br \/>\n\u251c\u2500\u2500 \u5ef6\u8fdf&#xff1a;50ms<br \/>\n\u2514\u2500\u2500 \u8282\u7701&#xff1a;800ms<\/p>\n<p>Nginx\u542f\u7528HTTP\/2&#xff1a;<\/p>\n<p>server {<br \/>\n  listen 443 ssl http2;  # \u542f\u7528HTTP\/2<br \/>\n  server_name example.com;<\/p>\n<p>  ssl_certificate \/path\/to\/cert.pem;<br \/>\n  ssl_certificate_key \/path\/to\/key.pem;<br \/>\n}<\/p>\n<hr \/>\n<h4>4.3 \u8bf7\u6c42\u5e76\u884c\u5316<\/h4>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u524d&#xff1a;\u4e32\u884c\u8bf7\u6c42<\/span><br \/>\n<span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">loadData<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> user <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/user&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>        <span class=\"token comment\">\/\/ 300ms<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> orders <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/orders&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>    <span class=\"token comment\">\/\/ 400ms<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> products <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/products&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><span class=\"token comment\">\/\/ 200ms<\/span><br \/>\n  <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">{<\/span> user<span class=\"token punctuation\">,<\/span> orders<span class=\"token punctuation\">,<\/span> products <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token comment\">\/\/ \u603b\u8017\u65f6&#xff1a;900ms<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f18\u5316\u540e&#xff1a;\u5e76\u884c\u8bf7\u6c42<\/span><br \/>\n<span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">loadData<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> <span class=\"token punctuation\">[<\/span>user<span class=\"token punctuation\">,<\/span> orders<span class=\"token punctuation\">,<\/span> products<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> Promise<span class=\"token punctuation\">.<\/span><span class=\"token function\">all<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">[<\/span><br \/>\n    <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/user&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/orders&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/products&#039;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">return<\/span> <span class=\"token punctuation\">{<\/span> user<span class=\"token punctuation\">,<\/span> orders<span class=\"token punctuation\">,<\/span> products <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token comment\">\/\/ \u603b\u8017\u65f6&#xff1a;400ms&#xff08;\u6700\u6162\u7684\u8bf7\u6c42&#xff09;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u63d0\u5347&#xff1a;55%<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u8fdb\u9636&#xff1a;\u5e76\u53d1\u63a7\u5236&#xff08;\u907f\u514d\u540c\u65f6\u53d1\u8d77100\u4e2a\u8bf7\u6c42&#xff09;<\/span><br \/>\n<span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">batchFetch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">urls<span class=\"token punctuation\">,<\/span> concurrency <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">6<\/span><\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> results <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> queue <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token operator\">&#8230;<\/span>urls<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">worker<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">while<\/span> <span class=\"token punctuation\">(<\/span>queue<span class=\"token punctuation\">.<\/span>length <span class=\"token operator\">&gt;<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n      <span class=\"token keyword\">const<\/span> url <span class=\"token operator\">&#061;<\/span> queue<span class=\"token punctuation\">.<\/span><span class=\"token function\">shift<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n      <span class=\"token keyword\">const<\/span> result <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n      results<span class=\"token punctuation\">.<\/span><span class=\"token function\">push<\/span><span class=\"token punctuation\">(<\/span>result<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><\/p>\n<p>  <span class=\"token comment\">\/\/ \u542f\u52a86\u4e2a\u5e76\u53d1worker<\/span><br \/>\n  <span class=\"token keyword\">await<\/span> Promise<span class=\"token punctuation\">.<\/span><span class=\"token function\">all<\/span><span class=\"token punctuation\">(<\/span><br \/>\n    <span class=\"token function\">Array<\/span><span class=\"token punctuation\">(<\/span>concurrency<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">fill<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">map<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token function\">worker<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">return<\/span> results<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f7f\u7528<\/span><br \/>\n<span class=\"token keyword\">await<\/span> <span class=\"token function\">batchFetch<\/span><span class=\"token punctuation\">(<\/span>productUrls<span class=\"token punctuation\">,<\/span> <span class=\"token number\">6<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<hr \/>\n<h3>\u4e94\u3001\u667a\u80fd\u7f13\u5b58\u7b56\u7565<\/h3>\n<h4>5.1 HTTP\u7f13\u5b58<\/h4>\n<h5>5.1.1 \u5f3a\u7f13\u5b58&#xff08;Cache-Control&#xff09;<\/h5>\n<p># Nginx\u914d\u7f6e<br \/>\nlocation ~* \\\\.(js|css|png|jpg|jpeg|gif|ico|woff2)$ {<br \/>\n  expires 1y;  # 1\u5e74<br \/>\n  add_header Cache-Control &#034;public, immutable&#034;;<br \/>\n}<\/p>\n<p>location ~* \\\\.html$ {<br \/>\n  expires -1;  # \u4e0d\u7f13\u5b58<br \/>\n  add_header Cache-Control &#034;no-cache&#034;;<br \/>\n}<\/p>\n<p>\u6548\u679c&#xff1a;<br \/>\n\u7b2c\u4e00\u6b21\u8bbf\u95ee&#xff1a;<br \/>\n&#8211; app.123abc.js (500 KB) &#8211; \u4e0b\u8f7d\u8017\u65f6 500ms<\/p>\n<p>\u7b2c\u4e8c\u6b21\u8bbf\u95ee&#xff08;\u6587\u4ef6\u672a\u53d8&#xff09;&#xff1a;<br \/>\n&#8211; app.123abc.js &#8211; \u4ece\u7f13\u5b58\u8bfb\u53d6 (0ms) \u2705<\/p>\n<p>\u6587\u4ef6\u66f4\u65b0\u540e&#xff1a;<br \/>\n&#8211; app.456def.js (500 KB) &#8211; \u4e0b\u8f7d\u65b0\u6587\u4ef6<br \/>\n&#8211; \u65e7\u7f13\u5b58\u81ea\u52a8\u5931\u6548&#xff08;\u6587\u4ef6\u540d\u53d8\u4e86&#xff09;<\/p>\n<h5>5.1.2 \u534f\u5546\u7f13\u5b58&#xff08;ETag \/ Last-Modified&#xff09;<\/h5>\n<p>\u5de5\u4f5c\u6d41\u7a0b&#xff1a;<br \/>\n1. \u9996\u6b21\u8bf7\u6c42<br \/>\n   \u6d4f\u89c8\u5668 \u2192 \u670d\u52a1\u5668&#xff1a;GET \/api\/products<br \/>\n   \u670d\u52a1\u5668 \u2192 \u6d4f\u89c8\u5668&#xff1a;200 OK<br \/>\n                    ETag: &#034;v1.0&#034;<br \/>\n                    Data: {&#8230;}<\/p>\n<p>2. \u518d\u6b21\u8bf7\u6c42<br \/>\n   \u6d4f\u89c8\u5668 \u2192 \u670d\u52a1\u5668&#xff1a;GET \/api\/products<br \/>\n                    If-None-Match: &#034;v1.0&#034;<\/p>\n<p>   \u5982\u679c\u6570\u636e\u672a\u53d8&#xff1a;<br \/>\n   \u670d\u52a1\u5668 \u2192 \u6d4f\u89c8\u5668&#xff1a;304 Not Modified<br \/>\n                    (\u65e0Body&#xff0c;\u8282\u7701\u5e26\u5bbd)<\/p>\n<p>   \u5982\u679c\u6570\u636e\u5df2\u53d8&#xff1a;<br \/>\n   \u670d\u52a1\u5668 \u2192 \u6d4f\u89c8\u5668&#xff1a;200 OK<br \/>\n                    ETag: &#034;v2.0&#034;<br \/>\n                    Data: {&#8230;}<\/p>\n<p>\u6548\u679c&#xff1a;<br \/>\n&#8211; \u8282\u7701\u5e26\u5bbd&#xff08;304\u54cd\u5e94\u65e0Body&#xff09;<br \/>\n&#8211; \u51cf\u5c11\u670d\u52a1\u5668\u538b\u529b&#xff08;\u6570\u636e\u672a\u53d8\u65f6\u65e0\u9700\u67e5\u8be2DB&#xff09;<\/p>\n<p>\u540e\u7aef\u5b9e\u73b0&#xff08;Express&#xff09;&#xff1a;<\/p>\n<p><span class=\"token keyword\">const<\/span> express <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">require<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;express&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">const<\/span> etag <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">require<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;etag&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>app<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/products&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token parameter\">req<span class=\"token punctuation\">,<\/span> res<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> products <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">getProducts<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> dataString <span class=\"token operator\">&#061;<\/span> <span class=\"token constant\">JSON<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">stringify<\/span><span class=\"token punctuation\">(<\/span>products<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> hash <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">etag<\/span><span class=\"token punctuation\">(<\/span>dataString<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token comment\">\/\/ \u68c0\u67e5\u5ba2\u6237\u7aefETag<\/span><br \/>\n  <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>req<span class=\"token punctuation\">.<\/span>headers<span class=\"token punctuation\">[<\/span><span class=\"token string\">&#039;if-none-match&#039;<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;&#061;&#061;<\/span> hash<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">return<\/span> res<span class=\"token punctuation\">.<\/span><span class=\"token function\">status<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">304<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">end<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ 304 Not Modified<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><\/p>\n<p>  res<span class=\"token punctuation\">.<\/span><span class=\"token function\">setHeader<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;ETag&#039;<\/span><span class=\"token punctuation\">,<\/span> hash<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  res<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span>products<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<hr \/>\n<h4>5.2 \u524d\u7aef\u7f13\u5b58<\/h4>\n<h5>5.2.1 Memory Cache&#xff08;\u5185\u5b58\u7f13\u5b58&#xff09;<\/h5>\n<p><span class=\"token comment\">\/\/ \u7b80\u5355\u7684\u5185\u5b58\u7f13\u5b58<\/span><br \/>\n<span class=\"token keyword\">const<\/span> cache <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">Map<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">fetchWithCache<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">url<span class=\"token punctuation\">,<\/span> ttl <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">60000<\/span><\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> cached <span class=\"token operator\">&#061;<\/span> cache<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>cached <span class=\"token operator\">&amp;&amp;<\/span> Date<span class=\"token punctuation\">.<\/span><span class=\"token function\">now<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#8211;<\/span> cached<span class=\"token punctuation\">.<\/span>time <span class=\"token operator\">&lt;<\/span> ttl<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    console<span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\u4ece\u7f13\u5b58\u8bfb\u53d6&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token keyword\">return<\/span> cached<span class=\"token punctuation\">.<\/span>data<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><\/p>\n<p>  console<span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\u53d1\u8d77\u8bf7\u6c42&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> data <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">then<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">r<\/span> <span class=\"token operator\">&#061;&gt;<\/span> r<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  cache<span class=\"token punctuation\">.<\/span><span class=\"token function\">set<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    data<span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token literal-property property\">time<\/span><span class=\"token operator\">:<\/span> Date<span class=\"token punctuation\">.<\/span><span class=\"token function\">now<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">return<\/span> data<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f7f\u7528<\/span><br \/>\n<span class=\"token keyword\">const<\/span> products <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetchWithCache<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/products&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">5<\/span> <span class=\"token operator\">*<\/span> <span class=\"token number\">60<\/span> <span class=\"token operator\">*<\/span> <span class=\"token number\">1000<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ 5\u5206\u949f\u7f13\u5b58<\/span><\/p>\n<h5>5.2.2 LocalStorage\u7f13\u5b58<\/h5>\n<p><span class=\"token comment\">\/\/ \u5e26\u8fc7\u671f\u65f6\u95f4\u7684LocalStorage<\/span><br \/>\n<span class=\"token keyword\">function<\/span> <span class=\"token function\">setCache<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">key<span class=\"token punctuation\">,<\/span> data<span class=\"token punctuation\">,<\/span> ttl <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">3600000<\/span><\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> item <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    data<span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token literal-property property\">expiry<\/span><span class=\"token operator\">:<\/span> Date<span class=\"token punctuation\">.<\/span><span class=\"token function\">now<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#043;<\/span> ttl<br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  localStorage<span class=\"token punctuation\">.<\/span><span class=\"token function\">setItem<\/span><span class=\"token punctuation\">(<\/span>key<span class=\"token punctuation\">,<\/span> <span class=\"token constant\">JSON<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">stringify<\/span><span class=\"token punctuation\">(<\/span>item<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token keyword\">function<\/span> <span class=\"token function\">getCache<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">key<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> itemStr <span class=\"token operator\">&#061;<\/span> localStorage<span class=\"token punctuation\">.<\/span><span class=\"token function\">getItem<\/span><span class=\"token punctuation\">(<\/span>key<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token operator\">!<\/span>itemStr<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">return<\/span> <span class=\"token keyword\">null<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">const<\/span> item <span class=\"token operator\">&#061;<\/span> <span class=\"token constant\">JSON<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">parse<\/span><span class=\"token punctuation\">(<\/span>itemStr<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>Date<span class=\"token punctuation\">.<\/span><span class=\"token function\">now<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&gt;<\/span> item<span class=\"token punctuation\">.<\/span>expiry<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    localStorage<span class=\"token punctuation\">.<\/span><span class=\"token function\">removeItem<\/span><span class=\"token punctuation\">(<\/span>key<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token keyword\">return<\/span> <span class=\"token keyword\">null<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><\/p>\n<p>  <span class=\"token keyword\">return<\/span> item<span class=\"token punctuation\">.<\/span>data<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u5c01\u88c5fetch<\/span><br \/>\n<span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">fetchWithLocalStorage<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">url<span class=\"token punctuation\">,<\/span> ttl <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">3600000<\/span><\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> cached <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">getCache<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>cached<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">return<\/span> cached<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><\/p>\n<p>  <span class=\"token keyword\">const<\/span> data <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">then<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">r<\/span> <span class=\"token operator\">&#061;&gt;<\/span> r<span class=\"token punctuation\">.<\/span><span class=\"token function\">json<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token function\">setCache<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">,<\/span> data<span class=\"token punctuation\">,<\/span> ttl<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token keyword\">return<\/span> data<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f7f\u7528<\/span><br \/>\n<span class=\"token keyword\">const<\/span> userData <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">fetchWithLocalStorage<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/user&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">30<\/span> <span class=\"token operator\">*<\/span> <span class=\"token number\">60<\/span> <span class=\"token operator\">*<\/span> <span class=\"token number\">1000<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ 30\u5206\u949f<\/span><\/p>\n<h5>5.2.3 Service Worker\u7f13\u5b58<\/h5>\n<p><span class=\"token comment\">\/\/ sw.js&#xff08;Service Worker&#xff09;<\/span><br \/>\n<span class=\"token keyword\">const<\/span> <span class=\"token constant\">CACHE_NAME<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#039;v1&#039;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">const<\/span> urlsToCache <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">[<\/span><br \/>\n  <span class=\"token string\">&#039;\/&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token string\">&#039;\/styles\/main.css&#039;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n  <span class=\"token string\">&#039;\/scripts\/app.js&#039;<\/span><br \/>\n<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u5b89\u88c5\u65f6\u7f13\u5b58\u8d44\u6e90<\/span><br \/>\nself<span class=\"token punctuation\">.<\/span><span class=\"token function\">addEventListener<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;install&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token parameter\">event<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  event<span class=\"token punctuation\">.<\/span><span class=\"token function\">waitUntil<\/span><span class=\"token punctuation\">(<\/span><br \/>\n    caches<span class=\"token punctuation\">.<\/span><span class=\"token function\">open<\/span><span class=\"token punctuation\">(<\/span><span class=\"token constant\">CACHE_NAME<\/span><span class=\"token punctuation\">)<\/span><br \/>\n      <span class=\"token punctuation\">.<\/span><span class=\"token function\">then<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">cache<\/span> <span class=\"token operator\">&#061;&gt;<\/span> cache<span class=\"token punctuation\">.<\/span><span class=\"token function\">addAll<\/span><span class=\"token punctuation\">(<\/span>urlsToCache<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u62e6\u622a\u8bf7\u6c42<\/span><br \/>\nself<span class=\"token punctuation\">.<\/span><span class=\"token function\">addEventListener<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;fetch&#039;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token parameter\">event<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  event<span class=\"token punctuation\">.<\/span><span class=\"token function\">respondWith<\/span><span class=\"token punctuation\">(<\/span><br \/>\n    caches<span class=\"token punctuation\">.<\/span><span class=\"token function\">match<\/span><span class=\"token punctuation\">(<\/span>event<span class=\"token punctuation\">.<\/span>request<span class=\"token punctuation\">)<\/span><br \/>\n      <span class=\"token punctuation\">.<\/span><span class=\"token function\">then<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">response<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u7f13\u5b58\u547d\u4e2d&#xff1a;\u8fd4\u56de\u7f13\u5b58<\/span><br \/>\n        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>response<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n          <span class=\"token keyword\">return<\/span> response<span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u7f13\u5b58\u672a\u547d\u4e2d&#xff1a;\u53d1\u8d77\u8bf7\u6c42<\/span><br \/>\n        <span class=\"token keyword\">return<\/span> <span class=\"token function\">fetch<\/span><span class=\"token punctuation\">(<\/span>event<span class=\"token punctuation\">.<\/span>request<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">then<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">response<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n          <span class=\"token comment\">\/\/ \u7f13\u5b58\u65b0\u8bf7\u6c42<\/span><br \/>\n          <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>response<span class=\"token punctuation\">.<\/span>status <span class=\"token operator\">&#061;&#061;&#061;<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token keyword\">const<\/span> responseClone <span class=\"token operator\">&#061;<\/span> response<span class=\"token punctuation\">.<\/span><span class=\"token function\">clone<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            caches<span class=\"token punctuation\">.<\/span><span class=\"token function\">open<\/span><span class=\"token punctuation\">(<\/span><span class=\"token constant\">CACHE_NAME<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">then<\/span><span class=\"token punctuation\">(<\/span><span class=\"token parameter\">cache<\/span> <span class=\"token operator\">&#061;&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n              cache<span class=\"token punctuation\">.<\/span><span class=\"token function\">put<\/span><span class=\"token punctuation\">(<\/span>event<span class=\"token punctuation\">.<\/span>request<span class=\"token punctuation\">,<\/span> responseClone<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n          <span class=\"token punctuation\">}<\/span><br \/>\n          <span class=\"token keyword\">return<\/span> response<span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n      <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><br \/>\n  <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u6ce8\u518cService Worker<\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;serviceWorker&#039;<\/span> <span class=\"token keyword\">in<\/span> navigator<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  navigator<span class=\"token punctuation\">.<\/span>serviceWorker<span class=\"token punctuation\">.<\/span><span class=\"token function\">register<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/sw.js&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<hr \/>\n<h4>5.3 \u6570\u636e\u9884\u53d6<\/h4>\n<p><span class=\"token comment\">\/\/ React Query\u793a\u4f8b<\/span><br \/>\n<span class=\"token keyword\">import<\/span> <span class=\"token punctuation\">{<\/span> useQuery <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;react-query&#039;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">function<\/span> <span class=\"token function\">ProductList<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> <span class=\"token punctuation\">{<\/span> <span class=\"token literal-property property\">data<\/span><span class=\"token operator\">:<\/span> products <span class=\"token punctuation\">}<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">useQuery<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;products&#039;<\/span><span class=\"token punctuation\">,<\/span> fetchProducts<span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">staleTime<\/span><span class=\"token operator\">:<\/span> <span class=\"token number\">5<\/span> <span class=\"token operator\">*<\/span> <span class=\"token number\">60<\/span> <span class=\"token operator\">*<\/span> <span class=\"token number\">1000<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ 5\u5206\u949f\u5185\u8ba4\u4e3a\u6570\u636e\u662f\u65b0\u9c9c\u7684<\/span><br \/>\n    <span class=\"token literal-property property\">cacheTime<\/span><span class=\"token operator\">:<\/span> <span class=\"token number\">30<\/span> <span class=\"token operator\">*<\/span> <span class=\"token number\">60<\/span> <span class=\"token operator\">*<\/span> <span class=\"token number\">1000<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token comment\">\/\/ \u7f13\u5b5830\u5206\u949f<\/span><br \/>\n    <span class=\"token literal-property property\">refetchOnWindowFocus<\/span><span class=\"token operator\">:<\/span> <span class=\"token boolean\">false<\/span> <span class=\"token comment\">\/\/ \u7a97\u53e3\u805a\u7126\u65f6\u4e0d\u91cd\u65b0\u8bf7\u6c42<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">return<\/span> <span class=\"token operator\">&lt;<\/span>div<span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token comment\">\/* \u6e32\u67d3\u4ea7\u54c1\u5217\u8868 *\/<\/span><span class=\"token punctuation\">}<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>div<span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ SWR\u793a\u4f8b<\/span><br \/>\n<span class=\"token keyword\">import<\/span> useSWR <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;swr&#039;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">function<\/span> <span class=\"token function\">Profile<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token keyword\">const<\/span> <span class=\"token punctuation\">{<\/span> data<span class=\"token punctuation\">,<\/span> error <span class=\"token punctuation\">}<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">useSWR<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#039;\/api\/user&#039;<\/span><span class=\"token punctuation\">,<\/span> fetcher<span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">revalidateOnFocus<\/span><span class=\"token operator\">:<\/span> <span class=\"token boolean\">false<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    <span class=\"token literal-property property\">dedupingInterval<\/span><span class=\"token operator\">:<\/span> <span class=\"token number\">60000<\/span>  <span class=\"token comment\">\/\/ 60\u79d2\u5185\u76f8\u540c\u8bf7\u6c42\u8fd4\u56de\u7f13\u5b58<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>  <span class=\"token keyword\">return<\/span> <span class=\"token operator\">&lt;<\/span>div<span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">{<\/span>data<span class=\"token punctuation\">.<\/span>name<span class=\"token punctuation\">}<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>div<span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<hr \/>\n<h3>\u516d\u3001\u5b9e\u6218\u6848\u4f8b<\/h3>\n<h4>6.1 \u6848\u4f8b\u56de\u987e<\/h4>\n<p>\u4f18\u5316\u76ee\u6807&#xff1a;<br \/>\n&#8211; \u8bf7\u6c42\u6570\u91cf&#xff1a;127\u4e2a \u2192 &lt;30\u4e2a<br \/>\n&#8211; \u9875\u9762\u5927\u5c0f&#xff1a;15.2 MB \u2192 &lt;2 MB<br \/>\n&#8211; \u52a0\u8f7d\u65f6\u95f4&#xff1a;8\u79d2 \u2192 &lt;2\u79d2<\/p>\n<h4>6.2 \u4f18\u5316\u5b9e\u65bd<\/h4>\n<h5>\u9636\u6bb51&#xff1a;\u51cf\u5c11\u8bf7\u6c42\u6570\u91cf&#xff08;127 \u2192 35&#xff09;<\/h5>\n<p>1. \u56fe\u7247\u61d2\u52a0\u8f7d<br \/>\n   &#8211; \u9996\u5c4f\u5916\u7684\u56fe\u7247&#xff1a;53\u4e2a \u2192 0\u4e2a&#xff08;\u6eda\u52a8\u65f6\u52a0\u8f7d&#xff09;<br \/>\n   &#8211; \u8282\u7701\u8bf7\u6c42&#xff1a;53\u4e2a<\/p>\n<p>2. \u8def\u7531\u61d2\u52a0\u8f7d<br \/>\n   &#8211; \u975e\u5f53\u524d\u9875\u9762\u7ec4\u4ef6&#xff1a;15\u4e2a \u2192 0\u4e2a<br \/>\n   &#8211; \u8282\u7701\u8bf7\u6c42&#xff1a;15\u4e2a<\/p>\n<p>3. \u63a5\u53e3\u5408\u5e76<br \/>\n   &#8211; \u5546\u54c1\u8be6\u60c5\u8bf7\u6c42&#xff1a;20\u4e2a \u2192 1\u4e2a\u6279\u91cf\u63a5\u53e3<br \/>\n   &#8211; \u8282\u7701\u8bf7\u6c42&#xff1a;19\u4e2a<\/p>\n<p>4. \u96ea\u78a7\u56fe<br \/>\n   &#8211; \u5c0f\u56fe\u6807&#xff1a;8\u4e2a \u2192 1\u4e2asprite<br \/>\n   &#8211; \u8282\u7701\u8bf7\u6c42&#xff1a;7\u4e2a<\/p>\n<p>\u603b\u8ba1&#xff1a;127 \u2192 33\u4e2a\u8bf7\u6c42<\/p>\n<h5>\u9636\u6bb52&#xff1a;\u51cf\u5c0f\u8bf7\u6c42\u4f53\u79ef&#xff08;15.2 MB \u2192 1.8 MB&#xff09;<\/h5>\n<p>1. API\u6570\u636e\u5206\u9875<br \/>\n   &#8211; \u5546\u54c1\u5217\u8868&#xff1a;3.2 MB (2000\u6761) \u2192 100 KB (20\u6761)<br \/>\n   &#8211; \u8282\u7701&#xff1a;3.1 MB<\/p>\n<p>2. \u56fe\u7247\u4f18\u5316<br \/>\n   &#8211; \u538b\u7f29 &#043; WebP&#xff1a;9.5 MB \u2192 1.2 MB<br \/>\n   &#8211; \u8282\u7701&#xff1a;8.3 MB<\/p>\n<p>3. JS Bundle\u4f18\u5316<br \/>\n   &#8211; Tree Shaking &#043; \u4ee3\u7801\u5206\u5272&#xff1a;2.5 MB \u2192 600 KB<br \/>\n   &#8211; \u8282\u7701&#xff1a;1.9 MB<\/p>\n<p>4. Gzip\u538b\u7f29<br \/>\n   &#8211; \u6587\u672c\u8d44\u6e90\u538b\u7f29&#xff1a;\u5269\u4f591.8 MB \u2192 500 KB<br \/>\n   &#8211; \u8282\u7701&#xff1a;1.3 MB<\/p>\n<p>\u603b\u8ba1&#xff1a;15.2 MB \u2192 1.8 MB&#xff08;\u672a\u538b\u7f29&#xff09;\u2192 800 KB&#xff08;Gzip\u540e&#xff09;<\/p>\n<h5>\u9636\u6bb53&#xff1a;\u63d0\u5347\u8bf7\u6c42\u901f\u5ea6<\/h5>\n<p>1. \u542f\u7528CDN<br \/>\n   &#8211; \u9759\u6001\u8d44\u6e90\u52a0\u8f7d\u65f6\u95f4&#xff1a;500ms \u2192 50ms<br \/>\n   &#8211; \u63d0\u5347&#xff1a;90%<\/p>\n<p>2. \u542f\u7528HTTP\/2<br \/>\n   &#8211; \u5e76\u53d1\u9650\u5236&#xff1a;6\u4e2a \u2192 \u65e0\u9650\u5236<br \/>\n   &#8211; \u51cf\u5c11\u961f\u5217\u7b49\u5f85&#xff1a;300ms<\/p>\n<p>3. \u9884\u8fde\u63a5API\u57df\u540d<br \/>\n   &lt;link rel&#061;&#034;preconnect&#034; href&#061;&#034;https:\/\/api.example.com&#034;&gt;<br \/>\n   &#8211; \u8282\u7701\u8fde\u63a5\u65f6\u95f4&#xff1a;100ms<\/p>\n<p>4. \u8bf7\u6c42\u5e76\u884c\u5316<br \/>\n   &#8211; \u4e32\u884c\u8bf7\u6c42&#xff1a;900ms \u2192 \u5e76\u884c&#xff1a;400ms<br \/>\n   &#8211; \u8282\u7701&#xff1a;500ms<\/p>\n<h5>\u9636\u6bb54&#xff1a;\u7f13\u5b58\u7b56\u7565<\/h5>\n<p>1. \u5f3a\u7f13\u5b58&#xff08;\u9759\u6001\u8d44\u6e90&#xff09;<br \/>\n   &#8211; JS\/CSS\/\u56fe\u7247&#xff1a;Cache-Control: max-age&#061;31536000<br \/>\n   &#8211; \u4e8c\u6b21\u8bbf\u95ee&#xff1a;0ms&#xff08;\u4ece\u7f13\u5b58&#xff09;<\/p>\n<p>2. API\u7f13\u5b58&#xff08;React Query&#xff09;<br \/>\n   &#8211; \u7528\u6237\u4fe1\u606f&#xff1a;\u7f13\u5b585\u5206\u949f<br \/>\n   &#8211; \u5546\u54c1\u5206\u7c7b&#xff1a;\u7f13\u5b5830\u5206\u949f<br \/>\n   &#8211; \u51cf\u5c11\u91cd\u590d\u8bf7\u6c42&#xff1a;60%<\/p>\n<p>3. Service Worker<br \/>\n   &#8211; \u79bb\u7ebf\u8bbf\u95ee\u652f\u6301<br \/>\n   &#8211; \u79d2\u5f00\u4f53\u9a8c<\/p>\n<hr \/>\n<h4>6.3 \u4f18\u5316\u6210\u679c<\/h4>\n<p>\u6700\u7ec8\u6548\u679c\u5bf9\u6bd4&#xff1a;<br \/>\n\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510<br \/>\n\u2502 \u6307\u6807          \u2502 \u4f18\u5316\u524d    \u2502 \u4f18\u5316\u540e    \u2502 \u63d0\u5347     \u2502<br \/>\n\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524<br \/>\n\u2502 \u8bf7\u6c42\u6570\u91cf      \u2502 127\u4e2a    \u2502 33\u4e2a     \u2502 74% \u2705   \u2502<br \/>\n\u2502 \u9996\u6b21\u52a0\u8f7d\u5927\u5c0f  \u2502 15.2 MB  \u2502 1.8 MB   \u2502 88% \u2705   \u2502<br \/>\n\u2502 Gzip\u540e\u5927\u5c0f    \u2502 3.5 MB   \u2502 800 KB   \u2502 77% \u2705   \u2502<br \/>\n\u2502 \u52a0\u8f7d\u65f6\u95f4      \u2502 8.0s     \u2502 1.6s     \u2502 80% \u2705   \u2502<br \/>\n\u2502 FCP          \u2502 4.2s     \u2502 0.9s     \u2502 79% \u2705   \u2502<br \/>\n\u2502 LCP          \u2502 8.1s     \u2502 1.8s     \u2502 78% \u2705   \u2502<br \/>\n\u2502 Lighthouse   \u2502 32\u5206     \u2502 92\u5206     \u2502 &#043;60\u5206\u2705  \u2502<br \/>\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518<\/p>\n<p>\u4e8c\u6b21\u8bbf\u95ee&#xff08;\u6709\u7f13\u5b58&#xff09;&#xff1a;<br \/>\n&#8211; \u52a0\u8f7d\u65f6\u95f4&#xff1a;1.6s \u2192 0.3s<br \/>\n&#8211; \u8bf7\u6c42\u6570\u91cf&#xff1a;33\u4e2a \u2192 5\u4e2a&#xff08;\u4ec5API\u8bf7\u6c42&#xff09;<\/p>\n<hr \/>\n<h3>\u4e03\u3001\u603b\u7ed3<\/h3>\n<h4>7.1 \u4f18\u5316\u6e05\u5355<\/h4>\n<p>\u2611\ufe0f \u51cf\u5c11\u8bf7\u6c42\u6570\u91cf<br \/>\n   &#8211; [ ] \u9759\u6001\u8d44\u6e90\u5408\u5e76&#xff08;\u96ea\u78a7\u56fe\u3001Bundle&#xff09;<br \/>\n   &#8211; [ ] \u63a5\u53e3\u5408\u5e76&#xff08;\u6279\u91cf\u3001GraphQL\u3001BFF&#xff09;<br \/>\n   &#8211; [ ] \u61d2\u52a0\u8f7d&#xff08;\u8def\u7531\u3001\u7ec4\u4ef6\u3001\u56fe\u7247&#xff09;<br \/>\n   &#8211; [ ] \u9884\u52a0\u8f7d&#xff08;preload\u3001prefetch\u3001dns-prefetch&#xff09;<\/p>\n<p>\u2611\ufe0f \u51cf\u5c0f\u8bf7\u6c42\u4f53\u79ef<br \/>\n   &#8211; [ ] \u6570\u636e\u538b\u7f29&#xff08;Gzip\u3001Brotli&#xff09;<br \/>\n   &#8211; [ ] \u56fe\u7247\u4f18\u5316&#xff08;\u538b\u7f29\u3001WebP\u3001AVIF&#xff09;<br \/>\n   &#8211; [ ] \u6570\u636e\u88c1\u526a&#xff08;\u5b57\u6bb5\u8fc7\u6ee4\u3001\u5206\u9875&#xff09;<br \/>\n   &#8211; [ ] Tree Shaking&#xff08;\u79fb\u9664\u672a\u4f7f\u7528\u4ee3\u7801&#xff09;<\/p>\n<p>\u2611\ufe0f \u63d0\u5347\u8bf7\u6c42\u901f\u5ea6<br \/>\n   &#8211; [ ] CDN\u52a0\u901f<br \/>\n   &#8211; [ ] HTTP\/2<br \/>\n   &#8211; [ ] \u8bf7\u6c42\u5e76\u884c\u5316<br \/>\n   &#8211; [ ] \u57df\u540d\u6536\u655b<\/p>\n<p>\u2611\ufe0f \u7f13\u5b58\u7b56\u7565<br \/>\n   &#8211; [ ] HTTP\u7f13\u5b58&#xff08;\u5f3a\u7f13\u5b58\u3001\u534f\u5546\u7f13\u5b58&#xff09;<br \/>\n   &#8211; [ ] \u524d\u7aef\u7f13\u5b58&#xff08;Memory\u3001LocalStorage&#xff09;<br \/>\n   &#8211; [ ] Service Worker<br \/>\n   &#8211; [ ] \u6570\u636e\u9884\u53d6<\/p>\n<h4>7.2 \u4f18\u5316\u4f18\u5148\u7ea7<\/h4>\n<p>&#x1f534; P0\u7ea7&#xff08;\u7acb\u5373\u6267\u884c&#xff09;&#xff1a;<br \/>\n1. API\u5206\u9875&#xff08;\u6570\u636e\u91cf\u5927 \u2192 \u9996\u5c4f\u6162&#xff09;<br \/>\n2. \u56fe\u7247\u61d2\u52a0\u8f7d&#xff08;\u8bf7\u6c42\u591a \u2192 \u5e76\u53d1\u963b\u585e&#xff09;<br \/>\n3. \u8def\u7531\u61d2\u52a0\u8f7d&#xff08;Bundle\u5927 \u2192 \u89e3\u6790\u6162&#xff09;<\/p>\n<p>\u26a0\ufe0f P1\u7ea7&#xff08;\u91cd\u8981&#xff09;&#xff1a;<br \/>\n4. \u56fe\u7247\u538b\u7f29 &#043; WebP<br \/>\n5. \u542f\u7528Gzip\/Brotli<br \/>\n6. \u542f\u7528CDN<\/p>\n<p>\u2b55 P2\u7ea7&#xff08;\u4f18\u5316&#xff09;&#xff1a;<br \/>\n7. \u63a5\u53e3\u5408\u5e76&#xff08;GraphQL\/BFF&#xff09;<br \/>\n8. HTTP\/2<br \/>\n9. Service Worker<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u4e00\u3001\u8bf7\u6c42\u4f18\u5316\u6838\u5fc3\u601d\u8def<br \/>\n1.1 \u4f18\u5316\u56db\u539f\u5219<br \/>\n\u8bf7\u6c42\u4f18\u5316\u91d1\u5b57\u5854&#xff1a;\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\u2502  \u4e0d\u53d1\u8bf7\u6c42    \u2502 \u2190 \u6700\u4f18&#xff08;\u7f13\u5b58\u3001\u9884\u52a0\u8f7d&#xff09;\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\u2502  \u5c11\u53d1\u8bf7\u6c42    \u2502 \u2190 \u6b21\u4f18&#xff08;\u5408\u5e76\u3001\u61d2\u52a0\u8f7d&#xff09;\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\u2502  \u5c0f\u8bf7\u6c42      \u2502 \u2190 \u4f18\u5316&#xff08;\u538b\u7f29\u3001\u88c1\u526a&#xff09;\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\u2502  \u5feb\u8bf7\u6c42      \u2502 \u2190 \u57fa\u7840&amp;#xff08<\/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":[87,56],"topic":[],"class_list":["post-64182","post","type-post","status-publish","format-standard","hentry","category-server","tag-87","tag-56"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u524d\u7aef\u6027\u80fd\u4f18\u5316\u7cfb\u5217\uff08\u4e8c\uff09\uff1a\u8bf7\u6c42\u4f18\u5316\u7b56\u7565 - \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\/64182.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u524d\u7aef\u6027\u80fd\u4f18\u5316\u7cfb\u5217\uff08\u4e8c\uff09\uff1a\u8bf7\u6c42\u4f18\u5316\u7b56\u7565 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"\u4e00\u3001\u8bf7\u6c42\u4f18\u5316\u6838\u5fc3\u601d\u8def 1.1 \u4f18\u5316\u56db\u539f\u5219 \u8bf7\u6c42\u4f18\u5316\u91d1\u5b57\u5854&#xff1a;\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\u2502 \u4e0d\u53d1\u8bf7\u6c42  \u2502 \u2190 \u6700\u4f18&#xff08;\u7f13\u5b58\u3001\u9884\u52a0\u8f7d&#xff09;\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\u2502 \u5c11\u53d1\u8bf7\u6c42  \u2502 \u2190 \u6b21\u4f18&#xff08;\u5408\u5e76\u3001\u61d2\u52a0\u8f7d&#xff09;\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\u2502 \u5c0f\u8bf7\u6c42   \u2502 \u2190 \u4f18\u5316&#xff08;\u538b\u7f29\u3001\u88c1\u526a&#xff09;\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\u2502 \u5feb\u8bf7\u6c42   \u2502 \u2190 \u57fa\u7840&amp;#xff08\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/64182.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2026-01-22T14:48:34+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=\"14 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/64182.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/64182.html\",\"name\":\"\u524d\u7aef\u6027\u80fd\u4f18\u5316\u7cfb\u5217\uff08\u4e8c\uff09\uff1a\u8bf7\u6c42\u4f18\u5316\u7b56\u7565 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2026-01-22T14:48:34+00:00\",\"dateModified\":\"2026-01-22T14:48:34+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/64182.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/64182.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/64182.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u524d\u7aef\u6027\u80fd\u4f18\u5316\u7cfb\u5217\uff08\u4e8c\uff09\uff1a\u8bf7\u6c42\u4f18\u5316\u7b56\u7565\"}]},{\"@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\u6027\u80fd\u4f18\u5316\u7cfb\u5217\uff08\u4e8c\uff09\uff1a\u8bf7\u6c42\u4f18\u5316\u7b56\u7565 - \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\/64182.html","og_locale":"zh_CN","og_type":"article","og_title":"\u524d\u7aef\u6027\u80fd\u4f18\u5316\u7cfb\u5217\uff08\u4e8c\uff09\uff1a\u8bf7\u6c42\u4f18\u5316\u7b56\u7565 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"\u4e00\u3001\u8bf7\u6c42\u4f18\u5316\u6838\u5fc3\u601d\u8def 1.1 \u4f18\u5316\u56db\u539f\u5219 \u8bf7\u6c42\u4f18\u5316\u91d1\u5b57\u5854&#xff1a;\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\u2502 \u4e0d\u53d1\u8bf7\u6c42  \u2502 \u2190 \u6700\u4f18&#xff08;\u7f13\u5b58\u3001\u9884\u52a0\u8f7d&#xff09;\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\u2502 \u5c11\u53d1\u8bf7\u6c42  \u2502 \u2190 \u6b21\u4f18&#xff08;\u5408\u5e76\u3001\u61d2\u52a0\u8f7d&#xff09;\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\u2502 \u5c0f\u8bf7\u6c42   \u2502 \u2190 \u4f18\u5316&#xff08;\u538b\u7f29\u3001\u88c1\u526a&#xff09;\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\u2502 \u5feb\u8bf7\u6c42   \u2502 \u2190 \u57fa\u7840&amp;#xff08","og_url":"https:\/\/www.wsisp.com\/helps\/64182.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2026-01-22T14:48:34+00:00","author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"14 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/64182.html","url":"https:\/\/www.wsisp.com\/helps\/64182.html","name":"\u524d\u7aef\u6027\u80fd\u4f18\u5316\u7cfb\u5217\uff08\u4e8c\uff09\uff1a\u8bf7\u6c42\u4f18\u5316\u7b56\u7565 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2026-01-22T14:48:34+00:00","dateModified":"2026-01-22T14:48:34+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/64182.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/64182.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/64182.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"\u524d\u7aef\u6027\u80fd\u4f18\u5316\u7cfb\u5217\uff08\u4e8c\uff09\uff1a\u8bf7\u6c42\u4f18\u5316\u7b56\u7565"}]},{"@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\/64182","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=64182"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/64182\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=64182"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=64182"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=64182"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=64182"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}