{"id":1099,"date":"2022-11-19T14:27:00","date_gmt":"2022-11-19T06:27:00","guid":{"rendered":"http:\/\/blog.xrhoujie.com\/?p=1099"},"modified":"2022-10-25T10:34:12","modified_gmt":"2022-10-25T02:34:12","slug":"%e8%bd%acvue%e4%bc%98%e5%8c%96%e7%9b%b8%e5%85%b3","status":"publish","type":"post","link":"http:\/\/blog.xrhoujie.com\/?p=1099","title":{"rendered":"Vue\u4f18\u5316\u76f8\u5173(\u9488\u5bf9\u4ee3\u7801\u4e0e\u6d4f\u89c8\u5668)"},"content":{"rendered":"\n<h1>\u524d\u8a00<\/h1>\n\n\n\n<p>Vue\u9879\u76ee\u5f00\u53d1\u5b8c\u6bd5\u540e\uff0c\u5bf9\u9879\u76ee\u8fdb\u884c\u6253\u5305\u53d1\u5e03\u4e4b\u524d\uff0c\u5fc5\u4e0d\u53ef\u5c11\u7684\u64cd\u4f5c\u5c31\u662f\u9879\u76ee\u4f18\u5316\uff0c\u8fd9\u4e5f\u662f\u7a0b\u5e8f\u733f\u7684\u52a0\u5206\u9879\u770b\u770b\u5982\u4f55\u5bf9\u9879\u76ee\u8fdb\u884c\u4f18\u5316\u5427~<\/p>\n\n\n\n<hr class=\"wp-block-separator\"\/>\n\n\n\n<h1>\u4e00\u3001\u4ee3\u7801\u5c42\u9762\u4f18\u5316&#8211;\u8def\u7531\u61d2\u52a0\u8f7d<\/h1>\n\n\n\n<h2>1. \u4e3a\u4ec0\u4e48\u9700\u8981\u8def\u7531\u61d2\u52a0\u8f7d<\/h2>\n\n\n\n<p>\u5f53\u521a\u8fd0\u884c\u9879\u76ee\u7684\u65f6\u5019\uff0c\u53d1\u73b0\u521a\u8fdb\u5165\u9875\u9762\uff0c\u5c31\u5c06\u6240\u6709\u7684js\u6587\u4ef6\u548ccss\u6587\u4ef6\u52a0\u8f7d\u4e86\u8fdb\u6765\uff0c\u8fd9\u4e00\u8fdb\u7a0b\u5341\u5206\u7684\u6d88\u8017\u65f6\u95f4\u3002 \u5982\u679c\u6253\u5f00\u54ea\u4e2a\u9875\u9762\u5c31\u5bf9\u5e94\u7684\u52a0\u8f7d\u54cd\u5e94\u9875\u9762\u7684js\u6587\u4ef6\u548ccss\u6587\u4ef6\uff0c\u90a3\u4e48\u9875\u9762\u52a0\u8f7d\u901f\u5ea6\u4f1a\u5927\u5927\u63d0\u5347\u3002<\/p>\n\n\n\n<h2>2. \u5982\u4f55\u5b9e\u73b0\u8def\u7531\u61d2\u52a0\u8f7d<\/h2>\n\n\n\n<p>vue\u5b98\u65b9\u6587\u6863\uff1a<a href=\"https:\/\/link.juejin.cn?target=https%3A%2F%2Frouter.vuejs.org%2Fzh%2Fguide%2Fadvanced%2Flazy-loading.html\" target=\"_blank\" rel=\"noreferrer noopener\">\u8def\u7531\u61d2\u52a0\u8f7d<\/a> \u4ee3\u7801\u5982\u4e0b\uff08\u793a\u4f8b\uff09:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>{\n    path: '\/login',\n    component: () =&gt; import('@\/views\/login\/index'),\n    hidden: true\n  },\n<\/code><\/pre>\n\n\n\n<h2>3. \u8def\u7531\u61d2\u52a0\u8f7d\u4e2d\u7684\u9b54\u6cd5\u6ce8\u91ca<\/h2>\n\n\n\n<p>\u901a\u8fc7\u5728\u6ce8\u91ca\u4e2d\u6307\u5b9a<code>webpackChunkName<\/code>\uff0c\u53ef\u4ee5\u81ea\u5b9a\u4e49\u8fd9\u4e2a\u6587\u4ef6\u7684\u540d\u5b57\u3002 \u4ee3\u7801\u5982\u4e0b\uff08\u793a\u4f8b\uff09:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>components = () =&gt; import(\/* webpackChunkName:\"login\"*\/ \"..\/component\/Login.vue\")\n<\/code><\/pre>\n\n\n\n<p class=\"has-medium-font-size\"><strong>4.\u5408\u7406\u7684\u4f7f\u7528v-if\u4e0ev-show\uff1a<\/strong><\/p>\n\n\n\n<p>v-if \u662f \u771f\u6b63 \u7684\u6761\u4ef6\u6e32\u67d3\uff0c\u56e0\u4e3a\u5b83\u4f1a\u786e\u4fdd\u5728\u5207\u6362\u8fc7\u7a0b\u4e2d\u6761\u4ef6\u5757\u5185\u7684\u4e8b\u4ef6\u76d1\u542c\u5668\u548c\u5b50\u7ec4\u4ef6\u9002\u5f53\u5730\u88ab\u9500\u6bc1\u548c\u91cd\u5efa\uff1b\u4e5f\u662f\u60f0\u6027\u7684\uff1a\u5982\u679c\u5728\u521d\u59cb\u6e32\u67d3\u65f6\u6761\u4ef6\u4e3a\u5047\uff0c\u5219\u4ec0\u4e48\u4e5f\u4e0d\u505a\u2014\u2014\u76f4\u5230\u6761\u4ef6\u7b2c\u4e00\u6b21\u53d8\u4e3a\u771f\u65f6\uff0c\u624d\u4f1a\u5f00\u59cb\u6e32\u67d3\u6761\u4ef6\u5757\u3002<\/p>\n\n\n\n<p>v-show \u5c31\u7b80\u5355\u5f97\u591a\uff0c \u4e0d\u7ba1\u521d\u59cb\u6761\u4ef6\u662f\u4ec0\u4e48\uff0c\u5143\u7d20\u603b\u662f\u4f1a\u88ab\u6e32\u67d3\uff0c\u5e76\u4e14\u53ea\u662f\u7b80\u5355\u5730\u57fa\u4e8e CSS \u7684 display \u5c5e\u6027\u8fdb\u884c\u5207\u6362\u3002<\/p>\n\n\n\n<p>\u6240\u4ee5\uff0cv-if \u9002\u7528\u4e8e\u5728\u8fd0\u884c\u65f6\u5f88\u5c11\u6539\u53d8\u6761\u4ef6\uff0c\u4e0d\u9700\u8981\u9891\u7e41\u5207\u6362\u6761\u4ef6\u7684\u573a\u666f\uff1bv-show \u5219\u9002\u7528\u4e8e\u9700\u8981\u975e\u5e38\u9891\u7e41\u5207\u6362\u6761\u4ef6\u7684\u573a\u666f\u3002<\/p>\n\n\n\n<p>computed\uff1a \u662f\u8ba1\u7b97\u5c5e\u6027\uff0c\u4f9d\u8d56\u5176\u5b83\u5c5e\u6027\u503c\uff0c\u5e76\u4e14 computed \u7684\u503c\u6709\u7f13\u5b58\uff0c\u53ea\u6709\u5b83\u4f9d\u8d56\u7684\u5c5e\u6027\u503c\u53d1\u751f\u6539\u53d8\uff0c\u4e0b\u4e00\u6b21\u83b7\u53d6 computed \u7684\u503c\u65f6\u624d\u4f1a\u91cd\u65b0\u8ba1\u7b97 computed \u7684\u503c\uff1b<\/p>\n\n\n\n<p class=\"has-medium-font-size\"><strong>5.\u5408\u7406\u7684\u4f7f\u7528computed\u4e0ewatch<\/strong><\/p>\n\n\n\n<p>watch\uff1a \u66f4\u591a\u7684\u662f\u300c\u89c2\u5bdf\u300d\u7684\u4f5c\u7528\uff0c\u7c7b\u4f3c\u4e8e\u67d0\u4e9b\u6570\u636e\u7684\u76d1\u542c\u56de\u8c03 \uff0c\u6bcf\u5f53\u76d1\u542c\u7684\u6570\u636e\u53d8\u5316\u65f6\u90fd\u4f1a\u6267\u884c\u56de\u8c03\u8fdb\u884c\u540e\u7eed\u64cd\u4f5c\uff1b<\/p>\n\n\n\n<p>\u8fd0\u7528\u573a\u666f\uff1a<\/p>\n\n\n\n<p>\u5f53\u6211\u4eec\u9700\u8981\u8fdb\u884c\u6570\u503c\u8ba1\u7b97\uff0c\u5e76\u4e14\u4f9d\u8d56\u4e8e\u5176\u5b83\u6570\u636e\u65f6\uff0c\u5e94\u8be5\u4f7f\u7528 computed\uff0c\u56e0\u4e3a\u53ef\u4ee5\u5229\u7528 computed \u7684\u7f13\u5b58\u7279\u6027\uff0c\u907f\u514d\u6bcf\u6b21\u83b7\u53d6\u503c\u65f6\uff0c\u90fd\u8981\u91cd\u65b0\u8ba1\u7b97\uff1b<\/p>\n\n\n\n<p>\u5f53\u6211\u4eec\u9700\u8981\u5728\u6570\u636e\u53d8\u5316\u65f6\u6267\u884c\u5f02\u6b65\u6216\u5f00\u9500\u8f83\u5927\u7684\u64cd\u4f5c\u65f6\uff0c\u5e94\u8be5\u4f7f\u7528 watch\uff0c\u4f7f\u7528 watch \u9009\u9879\u5141\u8bb8\u6211\u4eec\u6267\u884c\u5f02\u6b65\u64cd\u4f5c ( \u8bbf\u95ee\u4e00\u4e2a API )\uff0c\u9650\u5236\u6211\u4eec\u6267\u884c\u8be5\u64cd\u4f5c\u7684\u9891\u7387\uff0c\u5e76\u5728\u6211\u4eec\u5f97\u5230\u6700\u7ec8\u7ed3\u679c\u524d\uff0c\u8bbe\u7f6e\u4e2d\u95f4\u72b6\u6001\u3002\u8fd9\u4e9b\u90fd\u662f\u8ba1\u7b97\u5c5e\u6027\u65e0\u6cd5\u505a\u5230\u7684\u3002<\/p>\n\n\n\n<p class=\"has-medium-font-size\"><strong>6.v-for \u904d\u5386\u5fc5\u987b\u4e3a item \u6dfb\u52a0 key\uff0c\u4e14\u907f\u514d\u540c\u65f6\u4f7f\u7528 v-if<\/strong><\/p>\n\n\n\n<p class=\"has-medium-font-size\"><strong>7.\u957f\u5217\u8868\u6027\u80fd\u4f18\u5316<\/strong><\/p>\n\n\n\n<p class=\"has-normal-font-size\">Vue \u4f1a\u901a\u8fc7 Object.defineProperty \u5bf9\u6570\u636e\u8fdb\u884c\u52ab\u6301\uff0c\u6765\u5b9e\u73b0\u89c6\u56fe\u54cd\u5e94\u6570\u636e\u7684\u53d8\u5316\uff0c\u7136\u800c\u6709\u4e9b\u65f6\u5019\u6211\u4eec\u7684\u7ec4\u4ef6\u5c31\u662f\u7eaf\u7cb9\u7684\u6570\u636e\u5c55\u793a\uff0c\u4e0d\u4f1a\u6709\u4efb\u4f55\u6539\u53d8\uff0c\u5728\u5927\u91cf\u6570\u636e\u5c55\u793a\u7684\u60c5\u51b5\u4e0b\uff0c\u8fd9\u80fd\u591f\u5f88\u660e\u663e\u7684\u51cf\u5c11\u7ec4\u4ef6\u521d\u59cb\u5316\u7684\u65f6\u95f4<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>export default {\n  data: () =&gt; ({\n    users: {}\n  }),\n  async created() {\n    const users = await axios.get(\"\/api\/users\");\n    this.users = Object.freeze(users);\n  }\n};<\/code><\/pre>\n\n\n\n<p class=\"has-medium-font-size\"><br><strong>8<\/strong>.<strong>\u4e8b\u4ef6\u7684\u9500\u6bc1<\/strong><\/p>\n\n\n\n<p>Vue \u7ec4\u4ef6\u9500\u6bc1\u65f6\uff0c\u4f1a\u81ea\u52a8\u6e05\u7406\u5b83\u4e0e\u5176\u5b83\u5b9e\u4f8b\u7684\u8fde\u63a5\uff0c\u89e3\u7ed1\u5b83\u7684\u5168\u90e8\u6307\u4ee4\u53ca\u4e8b\u4ef6\u76d1\u542c\u5668\uff0c\u4f46\u662f\u4ec5\u9650\u4e8e\u7ec4\u4ef6\u672c\u8eab\u7684\u4e8b\u4ef6\u3002\u5982\u679c\u5728 js \u5185<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>created() {\n  addEventListener('click', this.click, false)\n},\nbeforeDestroy() {\n  removeEventListener('click', this.click, false)\n}<\/code><\/pre>\n\n\n\n<p class=\"has-medium-font-size\"><strong>9.\u56fe\u7247\u8d44\u6e90\u61d2\u52a0\u8f7d\u4e0e\u5206\u9875<\/strong><\/p>\n\n\n\n<p>\u9488\u5bf9\u56fe\u7247\u8fc7\u591a\u7684\u9875\u9762\uff0c\u4e3a\u4e86\u9875\u9762\u52a0\u901f\u6e32\u67d3\uff0c\u53ef\u4ee5\u4f7f\u7528\u61d2\u52a0\u8f7d\uff0c\u65e2\u53ef\u89c6\u533a\u57df\u5916\u7684\u5185\u5bb9\u5148\u4e0d\u5c55\u793a\uff0c\u7b49\u6eda\u52a8\u5230\u53ef\u89c6\u533a\u57df\u5728\u8fdb\u884c\u52a0\u8f7d\uff0c\u53ef\u4ee5\u4f7f\u7528&nbsp;Vue \u7684 <a href=\"https:\/\/blog.csdn.net\/halo1416\/article\/details\/81302419\">vue-lazyload \u63d2\u4ef6\uff1a<\/a><\/p>\n\n\n\n<p class=\"has-medium-font-size\"><strong>10.\u7b2c\u4e09\u65b9\u63d2\u4ef6\u7684\u6309\u9700\u5f15\u5165<\/strong><\/p>\n\n\n\n<p>\u6211\u4eec\u5728\u9879\u76ee\u4e2d\u7ecf\u5e38\u4f1a\u9700\u8981\u5f15\u5165\u7b2c\u4e09\u65b9\u63d2\u4ef6\uff0c\u5982\u679c\u6211\u4eec\u76f4\u63a5\u5f15\u5165\u6574\u4e2a\u63d2\u4ef6\uff0c\u4f1a\u5bfc\u81f4\u9879\u76ee\u7684\u4f53\u79ef\u592a\u5927\uff0c\u6211\u4eec\u53ef\u4ee5\u501f\u52a9&nbsp;<code>babel-plugin-component<\/code>&nbsp;\uff0c\u7136\u540e\u53ef\u4ee5\u53ea\u5f15\u5165\u9700\u8981\u7684\u7ec4\u4ef6\uff0c\u4ee5\u8fbe\u5230\u51cf\u5c0f\u9879\u76ee\u4f53\u79ef\u7684\u76ee\u7684\u3002<\/p>\n\n\n\n<p>\u4f8b\u5b50\uff1a<a href=\"https:\/\/element.eleme.io\/#\/zh-CN\/component\/quickstart\">https:\/\/element.eleme.io\/#\/zh-CN\/component\/quickstart<\/a><\/p>\n\n\n\n<p>11.<\/p>\n\n\n\n<h1>\u4e8c\u3001\u5206\u6790\u5305\u5927\u5c0f<\/h1>\n\n\n\n<h2>1. \u9700\u6c42<\/h2>\n\n\n\n<p>\u60f3\u8981\u77e5\u9053\u6253\u5305\u751f\u6210\u7684\u6587\u4ef6\u4e2d\uff0c\u6bcf\u4e2a\u6587\u4ef6\u6240\u5360\u7684\u7a7a\u95f4\u5927\u5c0f\u3002\u4ee5\u4fbf\u4e8e\u6211\u4eec\u5206\u6790\uff0c\u5bf9\u4ee3\u7801\u8fdb\u884c\u4f18\u5316\u5904\u7406\u3002<\/p>\n\n\n\n<p class=\"has-medium-font-size\"><strong>2.\u9488\u5bf9\u6d4f\u89c8\u5668\u7684\u8c03\u8bd5\u5de5\u5177<\/strong>&#8212;<strong>performance insights<\/strong><\/p>\n\n\n\n<figure class=\"wp-block-image size-full is-resized\"><img loading=\"lazy\" src=\"http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-6.png\" alt=\"\" class=\"wp-image-1102\" width=\"215\" height=\"166\" srcset=\"http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-6.png 773w, http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-6-300x232.png 300w, http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-6-768x594.png 768w\" sizes=\"(max-width: 215px) 100vw, 215px\" \/><\/figure>\n\n\n\n<figure class=\"wp-block-image size-full is-resized\"><img loading=\"lazy\" src=\"http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-8.png\" alt=\"\" class=\"wp-image-1104\" width=\"182\" height=\"206\" srcset=\"http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-8.png 460w, http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-8-266x300.png 266w\" sizes=\"(max-width: 182px) 100vw, 182px\" \/><\/figure>\n\n\n\n<p><strong>\u9488\u5bf9\u6574\u4e2a\u9875\u9762\u7684\u6e32\u67d3\u5468\u671f\u90fd\u53ef\u4ee5\u4ece\u8fd9\u91cc\u770b\u5230\uff0c\u6211\u4eec\u53ea\u9700\u8981\u67e5\u9605\u6700\u8017\u65f6\u7684\u9636\u6bb5 \u8fdb\u884c\u4e00\u4e9b\u4f18\u5316\u5373\u53ef <\/strong><\/p>\n\n\n\n<p class=\"has-medium-font-size\"><strong>3.\u9488\u5bf9\u6d4f\u89c8\u5668\u7684\u8c03\u8bd5\u5de5\u5177&#8211;Lighthouse<\/strong><\/p>\n\n\n\n<figure class=\"wp-block-image size-large is-resized\"><img loading=\"lazy\" src=\"http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-9-1024x593.png\" alt=\"\" class=\"wp-image-1109\" width=\"397\" height=\"230\" srcset=\"http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-9-1024x593.png 1024w, http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-9-300x174.png 300w, http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-9-768x445.png 768w, http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-9.png 1081w\" sizes=\"(max-width: 397px) 100vw, 397px\" \/><figcaption>\u6309\u6b65\u9aa4\u64cd\u4f5c\uff0c\u6d4f\u89c8\u5668\u4f1a\u81ea\u52a8\u6a21\u62df\u6d4b\u8bd5\uff0c\u6700\u540e\u4f1a\u7ed9\u51fa\u4e00\u4e2a\u6d4b\u8bc4\u6253\u5206<\/figcaption><\/figure>\n\n\n\n<figure class=\"wp-block-image size-large is-resized\"><img loading=\"lazy\" src=\"http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-11-942x1024.png\" alt=\"\" class=\"wp-image-1111\" width=\"312\" height=\"339\" srcset=\"http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-11-942x1024.png 942w, http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-11-276x300.png 276w, http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-11-768x835.png 768w, http:\/\/blog.xrhoujie.com\/wp-content\/uploads\/2022\/10\/image-11.png 1043w\" sizes=\"(max-width: 312px) 100vw, 312px\" \/><figcaption>\u786e\u5b9e\u8fd8\u6709\u5f88\u5927\u7684\u63d0\u5347\u7a7a\u95f4-\u3002-<\/figcaption><\/figure>\n\n\n\n<h1>\u4e09\u3001webpack\u914d\u7f6e\u6392\u9664\u6253\u5305<\/h1>\n\n\n\n<h2>1. \u9700\u6c42<\/h2>\n\n\n\n<p>\u5c06\u4e00\u4e9b\u4e0d\u5e38\u7528\u7684\u5305\uff0c\u6392\u9664\u5728\u751f\u6210\u7684\u6253\u5305\u6587\u4ef6\u4ee5\u5916\u3002 \u4f8b\u5982\uff1a\u4e0a\u56fe\u6240\u793a\u7684xsxl.js \u3001 element.js\uff0c\u53ef\u4ee5\u5c06\u5176\u6392\u9664\u5728\u6253\u5305\u751f\u6210\u7684\u6587\u4ef6\u4ee5\u5916<\/p>\n\n\n\n<h2>2. \u6392\u9664\u6253\u5305<\/h2>\n\n\n\n<p>\u627e\u5230 <code>vue.config.js<\/code>\uff0c \u6dfb\u52a0 <code>externals<\/code> \u9879\uff0c\u5177\u4f53\u5982\u4e0b\uff1a<\/p>\n\n\n\n<p>\u4ee3\u7801\u5982\u4e0b\uff08\u793a\u4f8b\uff09\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>configureWebpack: {\n  \/\/ \u914d\u7f6e\u5355\u9875\u5e94\u7528\u7a0b\u5e8f\u7684\u9875\u9762\u7684\u6807\u9898\n  name: name,\n  externals: {\n     \/**\n      * externals \u5bf9\u8c61\u5c5e\u6027\u89e3\u6790\u3002\n      *  \u57fa\u672c\u683c\u5f0f\uff1a\n      *     '\u5305\u540d' : '\u5728\u9879\u76ee\u4e2d\u5f15\u5165\u7684\u540d\u5b57'\n      *  \n    *\/\n    'vue': 'Vue',\n    'element-ui': 'ElementUI',\n    'xlsx': 'XLSX'\n  },\n  resolve: {\n    alias: {\n      '@': resolve('src')\n    }\n  }\n}\n<\/code><\/pre>\n\n\n\n<h1>\u56db\u3001 \u5f15\u7528\u7f51\u7edc\u8d44\u6e90<\/h1>\n\n\n\n<h2>1. \u9700\u6c42<\/h2>\n\n\n\n<p>\u6211\u4eec\u8fdb\u884c\u4e86\u4e0a\u4e00\u6b65\u64cd\u4f5c\u4ee5\u540e\uff0c\u6253\u5305\u751f\u6210\u540e\u7684\u5305\u5c0f\u4e86\u5f88\u591a\u3002\u4f46\u662f\u5462\uff0c\u6ca1\u6709\u8fd9\u4e9b\u4f9d\u8d56\u5305\u7684\u8bdd\uff0c\u9879\u76ee\u4e0a\u7ebf\u662f\u6ca1\u6709\u529e\u6cd5\u8fd0\u884c\u7684\u3002\u90a3\u4e48\u5c31\u9700\u8981\u5f15\u7528\u7f51\u7edc\u4e2d\u7684\u8d44\u6e90\uff0c\u6765\u652f\u6301\u6211\u4eec\u4ee3\u7801\u7684\u8fd0\u884c\u3002<\/p>\n\n\n\n<h2>2. CDN<\/h2>\n\n\n\n<ul><li><code>CDN<\/code>\u5168\u79f0\u53eb\u505a\u201cContent Delivery Network\u201d\uff0c\u4e2d\u6587\u53eb<strong>\u5185\u5bb9\u5206\u53d1\u7f51\u7edc<\/strong>\u3002\u6211\u4eec\u7528\u5b83\u6765<strong>\u63d0\u9ad8\u8bbf\u95ee\u901f\u5ea6<\/strong><\/li><li>\u628a\u4e00\u4e9b\u9759\u6001\u8d44\u6e90\uff1acss\uff0c .js\uff0c\u56fe\u7247\uff0c\u89c6\u9891\u653e\u5728\u7b2c\u4e09\u65b9\u7684CDN\u670d\u52a1\u5668\u4e0a\uff0c<strong>\u53ef\u4ee5\u52a0\u901f\u8bbf\u95ee\u901f\u5ea6<\/strong>\u3002<\/li><\/ul>\n\n\n\n<p><strong>\u597d\u5904\uff1a<\/strong><\/p>\n\n\n\n<ol><li>\u51cf\u5c11\u5e94\u7528\u6253\u5305\u51fa\u6765\u7684\u5305\u4f53\u79ef<\/li><li>\u52a0\u5feb\u9759\u6001\u8d44\u6e90\u7684\u8bbf\u95ee<\/li><li>\u5229\u7528\u6d4f\u89c8\u5668\u7f13\u5b58\uff0c\u4e0d\u4f1a\u53d8\u52a8\u7684\u6587\u4ef6\u957f\u671f\u7f13\u5b58<\/li><\/ol>\n\n\n\n<p><strong><span class=\"has-inline-color has-vivid-red-color\">\u5907\u6ce8\uff1a\u5982\u679c\u662f\u4f01\u4e1a\u9879\u76ee\u4e0d\u5efa\u8bae\u8fd9\u4e48\u64cd\u4f5c(\u514d\u8d39\u7684\u5bb9\u6613\u6302\u6389)\uff0c\u4ec5\u5efa\u8bae\u5c0f\u578b\u6216\u4e2a\u4eba\u5b66\u4e60\u4f7f\u7528<\/span><\/strong><\/p>\n\n\n\n<h2>3. \u5b9e\u73b0\u6b65\u9aa4<\/h2>\n\n\n\n<p><code>\u6ce8\u610f<\/code>:\u5728\u5f00\u53d1\u73af\u5883\u65f6\uff0c\u6587\u4ef6\u8d44\u6e90\u8fd8\u662f\u53ef\u4ee5\u4ece\u672c\u5730<code>node_modules<\/code>\u4e2d\u53d6\u51fa\uff0c\u800c\u53ea\u6709\u9879\u76ee\u4e0a\u7ebf\u4e86\uff0c\u624d\u9700\u8981\u53bb\u4f7f\u7528\u5916\u90e8\u8d44\u6e90\u3002\u6b64\u65f6\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528<strong>\u73af\u5883\u53d8\u91cf<\/strong>\u6765\u8fdb\u884c\u533a\u5206\u3002\u5177\u4f53\u5982\u4e0b\uff1a<\/p>\n\n\n\n<p>\u4ee3\u7801\u5982\u4e0b\uff08\u793a\u4f8b\uff09\uff1a<\/p>\n\n\n\n<p>\u5728<code>vue.config.js<\/code>\u6587\u4ef6\u4e2d:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>let externals = {}\nlet cdn = { css: &#91;], js: &#91;] }\nconst isProduction = process.env.NODE_ENV === 'production' \/\/ \u5224\u65ad\u662f\u5426\u662f\u751f\u4ea7\u73af\u5883\nif (isProduction) {\n  externals = {\n      \/**\n      * externals \u5bf9\u8c61\u5c5e\u6027\u89e3\u6790\uff1a\n      * '\u5305\u540d' : '\u5728\u9879\u76ee\u4e2d\u5f15\u5165\u7684\u540d\u5b57'\n    *\/\n      'vue': 'Vue',\n      'element-ui': 'ELEMENT',\n      'xlsx': 'XLSX'\n  }\n  cdn = {\n    css: &#91;\n      'https:\/\/unpkg.com\/element-ui\/lib\/theme-chalk\/index.css' \/\/ element-ui css \u6837\u5f0f\u8868\n    ],\n    js: &#91;\n      \/\/ vue must at first!\n      'https:\/\/unpkg.com\/vue@2.6.12\/dist\/vue.js', \/\/ vuejs\n      'https:\/\/unpkg.com\/element-ui\/lib\/index.js', \/\/ element-ui js\n      'https:\/\/cdn.jsdelivr.net\/npm\/xlsx@0.16.6\/dist\/xlsx.full.min.js', \/\/ xlsx\n    ]\n  }\n}<\/code><\/pre>\n\n\n\n<p>webpack\u914d\u7f6e<code>externals<\/code>\u914d\u7f6e\u9879<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>configureWebpack: {\n  \/\/ \u914d\u7f6e\u5355\u9875\u5e94\u7528\u7a0b\u5e8f\u7684\u9875\u9762\u7684\u6807\u9898\n  name: name,\n  externals: externals,\n  resolve: {\n    alias: {\n      '@': resolve('src')\n    }\n  }\n}\n<\/code><\/pre>\n\n\n\n<p>\u901a\u8fc7 <code>html-webpack-plugin<\/code>\u6ce8\u5165\u5230 <code>index.html<\/code>\u4e4b\u4e2d: \u5728<code>vue.config.js<\/code>\u6587\u4ef6\u4e2d\u914d\u7f6e:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>chainWebpack(config) {\n  config.plugin('preload').tap(() =&gt; &#91;\n    {\n      rel: 'preload',\n      fileBlacklist: &#91;\/\\.map$\/, \/hot-update\\.js$\/, \/runtime\\..*\\.js$\/],\n      include: 'initial'\n    }\n  ])\n  \/\/ \u6ce8\u5165cdn\u53d8\u91cf (\u6253\u5305\u65f6\u4f1a\u6267\u884c)\n  config.plugin('html').tap(args =&gt; {\n    args&#91;0].cdn = cdn \/\/ \u914d\u7f6ecdn\u7ed9\u63d2\u4ef6\n    return args\n  })\n  \/\/ \u7701\u7565\u5176\u4ed6...\n}\n<\/code><\/pre>\n\n\n\n<p>\u627e\u5230 <code>public\/index.html<\/code> \u901a\u8fc7\u914d\u7f6e<code>CDN Config<\/code> \u4f9d\u6b21\u6ce8\u5165 css \u548c js\u3002 \u4fee\u6539head\u7684\u5185\u5bb9\u5982\u4e0b:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;head&gt;\n    &lt;meta charset=\"utf-8\"&gt;\n    &lt;meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge,chrome=1\"&gt;\n    &lt;meta name=\"viewport\" content=\"width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no\"&gt;\n    &lt;link rel=\"icon\" href=\"&lt;%= BASE_URL %&gt;favicon.ico\"&gt;\n    &lt;title&gt;&lt;%= webpackConfig.name %&gt;&lt;\/title&gt;\n\n      &lt;!-- \u5f15\u5165\u6837\u5f0f --&gt;\n      &lt;% for(var css of htmlWebpackPlugin.options.cdn.css) { %&gt;\n        &lt;link rel=\"stylesheet\" href=\"&lt;%=css%&gt;\"&gt;\n        &lt;% } %&gt;\n\n\n    &lt;!-- \u5f15\u5165JS --&gt;\n    &lt;% for(var js of htmlWebpackPlugin.options.cdn.js) { %&gt;\n      &lt;script src=\"&lt;%=js%&gt;\"&gt;&lt;\/script&gt;\n    &lt;% } %&gt;\n  &lt;\/head&gt;\n<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator\"\/>\n\n\n\n<p><\/p>\n\n\n\n<h1>\u603b\u7ed3<\/h1>\n\n\n\n<p>\u8fd9\u4e9b\u624b\u6bb5\u4ec5\u4ec5\u662f\u4e00\u90e8\u5206 \uff0c\u8fd8\u6709\u4e00\u4e9bcss\u5408\u6279\uff0c\u56fe\u7247\u5408\u6279\uff0c\u63d0\u53d6\u516c\u5171\u4ee3\u7801\u7b49\u5c31\u4e0d\u518d\u8bf4\u4e86\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u524d\u8a00 Vue\u9879\u76ee\u5f00\u53d1\u5b8c\u6bd5\u540e\uff0c\u5bf9\u9879\u76ee\u8fdb\u884c\u6253\u5305\u53d1\u5e03\u4e4b\u524d\uff0c\u5fc5\u4e0d\u53ef\u5c11\u7684\u64cd\u4f5c\u5c31\u662f\u9879\u76ee\u4f18\u5316\uff0c\u8fd9\u4e5f\u662f\u7a0b\u5e8f\u733f\u7684\u52a0\u5206\u9879\u770b\u770b\u5982\u4f55\u5bf9 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[41],"tags":[38],"_links":{"self":[{"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=\/wp\/v2\/posts\/1099"}],"collection":[{"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1099"}],"version-history":[{"count":5,"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=\/wp\/v2\/posts\/1099\/revisions"}],"predecessor-version":[{"id":1116,"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=\/wp\/v2\/posts\/1099\/revisions\/1116"}],"wp:attachment":[{"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1099"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1099"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/blog.xrhoujie.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1099"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}