2018_11_02_04.html 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. <!DOCTYPE html>
  2. <html lang="en-US">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width,initial-scale=1">
  6. <title>vue-cli | 看白鹿的博客</title>
  7. <meta name="description" content="只有敢于尝试,才能品味人生.">
  8. <link rel="icon" href="/logo.png">
  9. <link rel="preload" href="/assets/css/0.styles.72bab9ec.css" as="style"><link rel="preload" href="/assets/js/app.44a82e39.js" as="script"><link rel="preload" href="/assets/js/3.8ae7454d.js" as="script"><link rel="preload" href="/assets/js/116.e934c00e.js" as="script"><link rel="prefetch" href="/assets/js/10.dee33bc4.js"><link rel="prefetch" href="/assets/js/100.7c8a9a23.js"><link rel="prefetch" href="/assets/js/101.05f5e1eb.js"><link rel="prefetch" href="/assets/js/102.e035a30f.js"><link rel="prefetch" href="/assets/js/103.f5588224.js"><link rel="prefetch" href="/assets/js/104.3cd6cf9b.js"><link rel="prefetch" href="/assets/js/105.9ae72903.js"><link rel="prefetch" href="/assets/js/106.bb7815a1.js"><link rel="prefetch" href="/assets/js/107.048043e1.js"><link rel="prefetch" href="/assets/js/108.2f879181.js"><link rel="prefetch" href="/assets/js/109.6d921894.js"><link rel="prefetch" href="/assets/js/11.8fbf6040.js"><link rel="prefetch" href="/assets/js/110.f3be3340.js"><link rel="prefetch" href="/assets/js/111.af80c446.js"><link rel="prefetch" href="/assets/js/112.c799df40.js"><link rel="prefetch" href="/assets/js/113.c27448ef.js"><link rel="prefetch" href="/assets/js/114.75e95324.js"><link rel="prefetch" href="/assets/js/115.6c8ff112.js"><link rel="prefetch" href="/assets/js/117.e8137ce8.js"><link rel="prefetch" href="/assets/js/118.b2c3b110.js"><link rel="prefetch" href="/assets/js/119.c64cdae0.js"><link rel="prefetch" href="/assets/js/12.6363f40e.js"><link rel="prefetch" href="/assets/js/120.de5163ec.js"><link rel="prefetch" href="/assets/js/121.0c4bd6d5.js"><link rel="prefetch" href="/assets/js/122.126c75a8.js"><link rel="prefetch" href="/assets/js/123.3f4492ff.js"><link rel="prefetch" href="/assets/js/13.82c54c81.js"><link rel="prefetch" href="/assets/js/14.0a6c5c0e.js"><link rel="prefetch" href="/assets/js/15.49935a00.js"><link rel="prefetch" href="/assets/js/16.f46aca5a.js"><link rel="prefetch" href="/assets/js/17.8c2dd42a.js"><link rel="prefetch" href="/assets/js/18.a2b1092e.js"><link rel="prefetch" href="/assets/js/19.1ded9624.js"><link rel="prefetch" href="/assets/js/20.1a95bd05.js"><link rel="prefetch" href="/assets/js/21.3828a440.js"><link rel="prefetch" href="/assets/js/22.c94e1951.js"><link rel="prefetch" href="/assets/js/23.c1c9836a.js"><link rel="prefetch" href="/assets/js/24.7defc8bd.js"><link rel="prefetch" href="/assets/js/25.b66c4544.js"><link rel="prefetch" href="/assets/js/26.cc7753fb.js"><link rel="prefetch" href="/assets/js/27.79806d2f.js"><link rel="prefetch" href="/assets/js/28.3a893535.js"><link rel="prefetch" href="/assets/js/29.19cf894b.js"><link rel="prefetch" href="/assets/js/30.6fda243a.js"><link rel="prefetch" href="/assets/js/31.e1d3c8bb.js"><link rel="prefetch" href="/assets/js/32.225aec53.js"><link rel="prefetch" href="/assets/js/33.1a9f93d4.js"><link rel="prefetch" href="/assets/js/34.1461452d.js"><link rel="prefetch" href="/assets/js/35.97721728.js"><link rel="prefetch" href="/assets/js/36.93d251dc.js"><link rel="prefetch" href="/assets/js/37.2c59c75b.js"><link rel="prefetch" href="/assets/js/38.80d4d542.js"><link rel="prefetch" href="/assets/js/39.ab08c2b7.js"><link rel="prefetch" href="/assets/js/4.820ed4fb.js"><link rel="prefetch" href="/assets/js/40.0d874970.js"><link rel="prefetch" href="/assets/js/41.2c30a136.js"><link rel="prefetch" href="/assets/js/42.bb23c5e0.js"><link rel="prefetch" href="/assets/js/43.332b616a.js"><link rel="prefetch" href="/assets/js/44.475084bc.js"><link rel="prefetch" href="/assets/js/45.99acbefe.js"><link rel="prefetch" href="/assets/js/46.f8fbfa00.js"><link rel="prefetch" href="/assets/js/47.72d13e8f.js"><link rel="prefetch" href="/assets/js/48.37873401.js"><link rel="prefetch" href="/assets/js/49.34520dc5.js"><link rel="prefetch" href="/assets/js/5.380bfded.js"><link rel="prefetch" href="/assets/js/50.b29ef5c8.js"><link rel="prefetch" href="/assets/js/51.225f616f.js"><link rel="prefetch" href="/assets/js/52.cfe14ed9.js"><link rel="prefetch" href="/assets/js/53.4e2ec73a.js"><link rel="prefetch" href="/assets/js/54.8ff2afa0.js"><link rel="prefetch" href="/assets/js/55.358770f5.js"><link rel="prefetch" href="/assets/js/56.d755c0c2.js"><link rel="prefetch" href="/assets/js/57.985fc3df.js"><link rel="prefetch" href="/assets/js/58.8d2845a1.js"><link rel="prefetch" href="/assets/js/59.8d34ecec.js"><link rel="prefetch" href="/assets/js/6.eb12f52b.js"><link rel="prefetch" href="/assets/js/60.d5bd9a2b.js"><link rel="prefetch" href="/assets/js/61.dc32bd44.js"><link rel="prefetch" href="/assets/js/62.552676dd.js"><link rel="prefetch" href="/assets/js/63.b8326d03.js"><link rel="prefetch" href="/assets/js/64.fd7d8d47.js"><link rel="prefetch" href="/assets/js/65.11e3cad8.js"><link rel="prefetch" href="/assets/js/66.a4470ce0.js"><link rel="prefetch" href="/assets/js/67.cb6c8810.js"><link rel="prefetch" href="/assets/js/68.d73daf51.js"><link rel="prefetch" href="/assets/js/69.41b1f367.js"><link rel="prefetch" href="/assets/js/7.956f94fd.js"><link rel="prefetch" href="/assets/js/70.5a9d525e.js"><link rel="prefetch" href="/assets/js/71.61d2af56.js"><link rel="prefetch" href="/assets/js/72.f41a6640.js"><link rel="prefetch" href="/assets/js/73.8545072d.js"><link rel="prefetch" href="/assets/js/74.b337a1c4.js"><link rel="prefetch" href="/assets/js/75.3ff729cf.js"><link rel="prefetch" href="/assets/js/76.06c88518.js"><link rel="prefetch" href="/assets/js/77.af07aba6.js"><link rel="prefetch" href="/assets/js/78.e1d6fcf7.js"><link rel="prefetch" href="/assets/js/79.803707d9.js"><link rel="prefetch" href="/assets/js/8.f0965cfc.js"><link rel="prefetch" href="/assets/js/80.bba0c262.js"><link rel="prefetch" href="/assets/js/81.4f9053d0.js"><link rel="prefetch" href="/assets/js/82.3de526cd.js"><link rel="prefetch" href="/assets/js/83.04036093.js"><link rel="prefetch" href="/assets/js/84.4e2cf172.js"><link rel="prefetch" href="/assets/js/85.f3376af6.js"><link rel="prefetch" href="/assets/js/86.278d3f52.js"><link rel="prefetch" href="/assets/js/87.17859abd.js"><link rel="prefetch" href="/assets/js/88.7fb10d8d.js"><link rel="prefetch" href="/assets/js/89.6bcd0a7e.js"><link rel="prefetch" href="/assets/js/9.f39c8e32.js"><link rel="prefetch" href="/assets/js/90.dab61711.js"><link rel="prefetch" href="/assets/js/91.204e0d89.js"><link rel="prefetch" href="/assets/js/92.6fad0cca.js"><link rel="prefetch" href="/assets/js/93.765d2445.js"><link rel="prefetch" href="/assets/js/94.ecd49b4c.js"><link rel="prefetch" href="/assets/js/95.2d7fd0f1.js"><link rel="prefetch" href="/assets/js/96.5265e8c8.js"><link rel="prefetch" href="/assets/js/97.18d4ec68.js"><link rel="prefetch" href="/assets/js/98.9bc7b7b4.js"><link rel="prefetch" href="/assets/js/99.b2750206.js"><link rel="prefetch" href="/assets/js/vendors~docsearch.431cfe91.js">
  10. <link rel="stylesheet" href="/assets/css/0.styles.72bab9ec.css">
  11. </head>
  12. <body>
  13. <div id="app" data-server-rendered="true"><div class="theme-container"><header class="navbar"><div class="sidebar-button"><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewBox="0 0 448 512" class="icon"><path fill="currentColor" d="M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z"></path></svg></div> <a href="/" class="home-link router-link-active"><!----> <span class="site-name">看白鹿的博客</span></a> <div class="links"><form id="search-form" role="search" class="algolia-search-wrapper search-box"><input id="algolia-search-input" class="search-query"></form> <nav class="nav-links can-hide"><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="前端" class="dropdown-title"><span class="title">前端</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/CSS/" class="nav-link">CSS</a></li><li class="dropdown-item"><!----> <a href="/FLUTTER/" class="nav-link">flutter</a></li><li class="dropdown-item"><!----> <a href="/GIT/" class="nav-link">GIT</a></li><li class="dropdown-item"><!----> <a href="/JavaScript/" class="nav-link">JavaScript</a></li><li class="dropdown-item"><!----> <a href="/REACT/" class="nav-link">react</a></li><li class="dropdown-item"><!----> <a href="/VUE/" class="nav-link router-link-active">vue</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="后台" class="dropdown-title"><span class="title">后台</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/NODE/" class="nav-link">node</a></li><li class="dropdown-item"><!----> <a href="/UBUNTU/" class="nav-link">ubuntu</a></li><li class="dropdown-item"><!----> <a href="/ffmpeg/" class="nav-link">ffmpeg</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="其他" class="dropdown-title"><span class="title">其他</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/IDE/" class="nav-link">IDE</a></li><li class="dropdown-item"><!----> <a href="/mac/" class="nav-link">MACBOOK PRO</a></li><li class="dropdown-item"><!----> <a href="/About/WHY.html" class="nav-link">待了解</a></li><li class="dropdown-item"><!----> <a href="/INTERVIEW/" class="nav-link">面试</a></li></ul></div></div><div class="nav-item"><a href="https://github.com/Johnhong9527" target="_blank" rel="noopener noreferrer" class="nav-link external">
  14. GitHub
  15. <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></div> <!----></nav></div></header> <div class="sidebar-mask"></div> <aside class="sidebar"><nav class="nav-links"><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="前端" class="dropdown-title"><span class="title">前端</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/CSS/" class="nav-link">CSS</a></li><li class="dropdown-item"><!----> <a href="/FLUTTER/" class="nav-link">flutter</a></li><li class="dropdown-item"><!----> <a href="/GIT/" class="nav-link">GIT</a></li><li class="dropdown-item"><!----> <a href="/JavaScript/" class="nav-link">JavaScript</a></li><li class="dropdown-item"><!----> <a href="/REACT/" class="nav-link">react</a></li><li class="dropdown-item"><!----> <a href="/VUE/" class="nav-link router-link-active">vue</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="后台" class="dropdown-title"><span class="title">后台</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/NODE/" class="nav-link">node</a></li><li class="dropdown-item"><!----> <a href="/UBUNTU/" class="nav-link">ubuntu</a></li><li class="dropdown-item"><!----> <a href="/ffmpeg/" class="nav-link">ffmpeg</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="其他" class="dropdown-title"><span class="title">其他</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/IDE/" class="nav-link">IDE</a></li><li class="dropdown-item"><!----> <a href="/mac/" class="nav-link">MACBOOK PRO</a></li><li class="dropdown-item"><!----> <a href="/About/WHY.html" class="nav-link">待了解</a></li><li class="dropdown-item"><!----> <a href="/INTERVIEW/" class="nav-link">面试</a></li></ul></div></div><div class="nav-item"><a href="https://github.com/Johnhong9527" target="_blank" rel="noopener noreferrer" class="nav-link external">
  16. GitHub
  17. <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></div> <!----></nav> <ul class="sidebar-links"><li><a href="/VUE/" class="sidebar-link">vue 目录</a></li><li><a href="/VUE/2018_10_31_01.html" class="sidebar-link">vue-router</a></li><li><a href="/VUE/2018_10_31_02.html" class="sidebar-link">vuepress</a></li><li><a href="/VUE/2018_11_02_01.html" class="sidebar-link">components</a></li><li><a href="/VUE/2018_11_02_02.html" class="sidebar-link">jsx</a></li><li><a href="/VUE/2018_11_02_03.html" class="sidebar-link">plugin</a></li><li><a href="/VUE/2018_11_02_04.html" class="active sidebar-link">vue-cli</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header"><a href="/VUE/2018_11_02_04.html#案例" class="sidebar-link">案例</a></li><li class="sidebar-sub-header"><a href="/VUE/2018_11_02_04.html#配置" class="sidebar-link">配置</a></li><li class="sidebar-sub-header"><a href="/VUE/2018_11_02_04.html#vue-config-js" class="sidebar-link">vue.config.js</a></li></ul></li></ul> </aside> <main class="page"> <div class="theme-default-content content__default"><h1 id="vue-cli"><a href="#vue-cli" class="header-anchor">#</a> vue-cli</h1> <h2 id="案例"><a href="#案例" class="header-anchor">#</a> 案例</h2> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">const</span> path <span class="token operator">=</span> <span class="token function">require</span><span class="token punctuation">(</span><span class="token string">'path'</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  18. <span class="token keyword">function</span> <span class="token function">resolve</span><span class="token punctuation">(</span><span class="token parameter">dir</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  19. <span class="token keyword">return</span> path<span class="token punctuation">.</span><span class="token function">join</span><span class="token punctuation">(</span>__dirname<span class="token punctuation">,</span> dir<span class="token punctuation">)</span><span class="token punctuation">;</span>
  20. <span class="token punctuation">}</span>
  21. <span class="token keyword">const</span> targetUrl <span class="token operator">=</span> <span class="token string">'[地址]'</span><span class="token punctuation">;</span>
  22. module<span class="token punctuation">.</span>exports <span class="token operator">=</span> <span class="token punctuation">{</span>
  23. <span class="token comment">// Project deployment base</span>
  24. <span class="token comment">// By default we assume your app will be deployed at the root of a domain,</span>
  25. <span class="token comment">// e.g. https://www.my-app.com/</span>
  26. <span class="token comment">// If your app is deployed at a sub-path, you will need to specify that</span>
  27. <span class="token comment">// sub-path here. For example, if your app is deployed at</span>
  28. <span class="token comment">// https://www.foobar.com/my-app/</span>
  29. <span class="token comment">// then change this to '/my-app/'</span>
  30. <span class="token comment">// baseUrl: '/web/app/img/',</span>
  31. baseUrl<span class="token punctuation">:</span> <span class="token string">'/'</span><span class="token punctuation">,</span>
  32. <span class="token comment">// where to output built files</span>
  33. outputDir<span class="token punctuation">:</span> <span class="token string">'dist'</span><span class="token punctuation">,</span>
  34. <span class="token comment">// whether to use eslint-loader for lint on save.</span>
  35. <span class="token comment">// valid values: true | false | 'error'</span>
  36. <span class="token comment">// when set to 'error', lint errors will cause compilation to fail.</span>
  37. lintOnSave<span class="token punctuation">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  38. <span class="token comment">// use the full build with in-browser compiler?</span>
  39. <span class="token comment">// https://vuejs.org/v2/guide/installation.html#Runtime-Compiler-vs-Runtime-only</span>
  40. <span class="token comment">// compiler: false,</span>
  41. <span class="token comment">// tweak internal webpack configuration.</span>
  42. <span class="token comment">// see https://github.com/vuejs/vue-cli/blob/dev/docs/webpack.md</span>
  43. <span class="token function-variable function">chainWebpack</span><span class="token punctuation">:</span> <span class="token parameter">config</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  44. config<span class="token punctuation">.</span>resolve<span class="token punctuation">.</span>alias
  45. <span class="token punctuation">.</span><span class="token function">set</span><span class="token punctuation">(</span><span class="token string">'@$'</span><span class="token punctuation">,</span> <span class="token function">resolve</span><span class="token punctuation">(</span><span class="token string">'src'</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  46. <span class="token punctuation">.</span><span class="token function">set</span><span class="token punctuation">(</span><span class="token string">'common'</span><span class="token punctuation">,</span> <span class="token function">resolve</span><span class="token punctuation">(</span><span class="token string">'src/common'</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  47. <span class="token punctuation">.</span><span class="token function">set</span><span class="token punctuation">(</span><span class="token string">'components'</span><span class="token punctuation">,</span> <span class="token function">resolve</span><span class="token punctuation">(</span><span class="token string">'src/components'</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  48. <span class="token punctuation">.</span><span class="token function">set</span><span class="token punctuation">(</span><span class="token string">'page'</span><span class="token punctuation">,</span> <span class="token function">resolve</span><span class="token punctuation">(</span><span class="token string">'src/page'</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  49. <span class="token punctuation">.</span><span class="token function">set</span><span class="token punctuation">(</span><span class="token string">'config'</span><span class="token punctuation">,</span> <span class="token function">resolve</span><span class="token punctuation">(</span><span class="token string">'src/config'</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  50. <span class="token punctuation">.</span><span class="token function">set</span><span class="token punctuation">(</span><span class="token string">'layout'</span><span class="token punctuation">,</span> <span class="token function">resolve</span><span class="token punctuation">(</span><span class="token string">'src/layout'</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  51. <span class="token punctuation">.</span><span class="token function">set</span><span class="token punctuation">(</span><span class="token string">'base'</span><span class="token punctuation">,</span> <span class="token function">resolve</span><span class="token punctuation">(</span><span class="token string">'src/base'</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  52. <span class="token punctuation">.</span><span class="token function">set</span><span class="token punctuation">(</span><span class="token string">'static'</span><span class="token punctuation">,</span> <span class="token function">resolve</span><span class="token punctuation">(</span><span class="token string">'src/static'</span><span class="token punctuation">)</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  53. config<span class="token punctuation">.</span>module
  54. <span class="token punctuation">.</span><span class="token function">rule</span><span class="token punctuation">(</span><span class="token string">'pug'</span><span class="token punctuation">)</span>
  55. <span class="token punctuation">.</span><span class="token function">test</span><span class="token punctuation">(</span><span class="token regex">/\.pug$/</span><span class="token punctuation">)</span>
  56. <span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span><span class="token string">'pug-html-loader'</span><span class="token punctuation">)</span>
  57. <span class="token punctuation">.</span><span class="token function">loader</span><span class="token punctuation">(</span><span class="token string">'pug-html-loader'</span><span class="token punctuation">)</span>
  58. <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>
  59. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  60. <span class="token function-variable function">configureWebpack</span><span class="token punctuation">:</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span><span class="token punctuation">}</span><span class="token punctuation">,</span>
  61. <span class="token comment">// vue-loader options</span>
  62. <span class="token comment">// https://vue-loader.vuejs.org/en/options.html</span>
  63. <span class="token comment">// vueLoader: {},</span>
  64. <span class="token comment">// generate sourceMap for production build?</span>
  65. productionSourceMap<span class="token punctuation">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  66. <span class="token comment">// CSS related options</span>
  67. css<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  68. <span class="token comment">// extract CSS in components into a single CSS file (only in production)</span>
  69. extract<span class="token punctuation">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  70. <span class="token comment">// enable CSS source maps?</span>
  71. sourceMap<span class="token punctuation">:</span> <span class="token boolean">false</span><span class="token punctuation">,</span>
  72. <span class="token comment">// pass custom options to pre-processor loaders. e.g. to pass options to</span>
  73. <span class="token comment">// sass-loader, use { sass: { ... } }</span>
  74. loaderOptions<span class="token punctuation">:</span> <span class="token punctuation">{</span><span class="token punctuation">}</span><span class="token punctuation">,</span>
  75. <span class="token comment">// Enable CSS modules for all css / pre-processor files.</span>
  76. <span class="token comment">// This option does not affect *.vue files.</span>
  77. modules<span class="token punctuation">:</span> <span class="token boolean">false</span><span class="token punctuation">,</span>
  78. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  79. <span class="token comment">// use thread-loader for babel &amp; TS in production build</span>
  80. <span class="token comment">// enabled by default if the machine has more than 1 cores</span>
  81. parallel<span class="token punctuation">:</span> <span class="token function">require</span><span class="token punctuation">(</span><span class="token string">'os'</span><span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">cpus</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">.</span>length <span class="token operator">&gt;</span> <span class="token number">1</span><span class="token punctuation">,</span>
  82. <span class="token comment">// split vendors using autoDLLPlugin?</span>
  83. <span class="token comment">// can also be an explicit Array of dependencies to include in the DLL chunk.</span>
  84. <span class="token comment">// See https://github.com/vuejs/vue-cli/blob/dev/docs/cli-service.md#dll-mode</span>
  85. <span class="token comment">// dll: false,</span>
  86. <span class="token comment">// options for the PWA plugin.</span>
  87. <span class="token comment">// see https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-pwa</span>
  88. <span class="token comment">// pwa: {},</span>
  89. <span class="token comment">// configure webpack-dev-server behavior</span>
  90. devServer<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  91. open<span class="token punctuation">:</span> process<span class="token punctuation">.</span>platform <span class="token operator">===</span> <span class="token string">'darwin'</span><span class="token punctuation">,</span>
  92. host<span class="token punctuation">:</span> <span class="token string">'0.0.0.0'</span><span class="token punctuation">,</span>
  93. port<span class="token punctuation">:</span> <span class="token number">8080</span><span class="token punctuation">,</span>
  94. https<span class="token punctuation">:</span> <span class="token boolean">false</span><span class="token punctuation">,</span>
  95. hotOnly<span class="token punctuation">:</span> <span class="token boolean">false</span><span class="token punctuation">,</span>
  96. <span class="token comment">// See https://github.com/vuejs/vue-cli/blob/dev/docs/cli-service.md#configuring-proxy</span>
  97. proxy<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  98. <span class="token string">'/j'</span><span class="token punctuation">:</span> <span class="token punctuation">{</span>
  99. target<span class="token punctuation">:</span> <span class="token template-string"><span class="token template-punctuation string">`</span><span class="token interpolation"><span class="token interpolation-punctuation punctuation">${</span>targetUrl<span class="token interpolation-punctuation punctuation">}</span></span><span class="token string">/j</span><span class="token template-punctuation string">`</span></span><span class="token punctuation">,</span> <span class="token comment">//设置调用接口域名和端口号别忘了加http</span>
  100. changeOrigin<span class="token punctuation">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  101. pathRewrite<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  102. <span class="token string">'^/j'</span><span class="token punctuation">:</span> <span class="token string">'/'</span><span class="token punctuation">,</span> <span class="token comment">//这里理解成用‘/api’代替target里面的地址,组件中我们调接口时直接用/api代替</span>
  103. <span class="token comment">// 比如我要调用'http://0.0:300/user/add',直接写‘/api/user/add’即可 代理后地址栏显示/</span>
  104. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  105. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  106. <span class="token string">'/o2o'</span><span class="token punctuation">:</span> <span class="token punctuation">{</span>
  107. target<span class="token punctuation">:</span> <span class="token template-string"><span class="token template-punctuation string">`</span><span class="token interpolation"><span class="token interpolation-punctuation punctuation">${</span>targetUrl<span class="token interpolation-punctuation punctuation">}</span></span><span class="token string">/o2o</span><span class="token template-punctuation string">`</span></span><span class="token punctuation">,</span>
  108. changeOrigin<span class="token punctuation">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  109. pathRewrite<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  110. <span class="token string">'^/o2o'</span><span class="token punctuation">:</span> <span class="token string">'/'</span><span class="token punctuation">,</span>
  111. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  112. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  113. <span class="token string">'/moonclub'</span><span class="token punctuation">:</span> <span class="token punctuation">{</span>
  114. target<span class="token punctuation">:</span> <span class="token template-string"><span class="token template-punctuation string">`</span><span class="token interpolation"><span class="token interpolation-punctuation punctuation">${</span>targetUrl<span class="token interpolation-punctuation punctuation">}</span></span><span class="token string">/moonclub</span><span class="token template-punctuation string">`</span></span><span class="token punctuation">,</span>
  115. changeOrigin<span class="token punctuation">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  116. pathRewrite<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  117. <span class="token string">'^/moonclub'</span><span class="token punctuation">:</span> <span class="token string">'/'</span><span class="token punctuation">,</span>
  118. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  119. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  120. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token comment">// string | Object</span>
  121. <span class="token function-variable function">before</span><span class="token punctuation">:</span> <span class="token parameter">app</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span><span class="token punctuation">}</span><span class="token punctuation">,</span>
  122. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  123. <span class="token comment">// options for 3rd party plugins</span>
  124. pluginOptions<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  125. <span class="token comment">// ...</span>
  126. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  127. <span class="token punctuation">}</span><span class="token punctuation">;</span>
  128. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br><span class="line-number">18</span><br><span class="line-number">19</span><br><span class="line-number">20</span><br><span class="line-number">21</span><br><span class="line-number">22</span><br><span class="line-number">23</span><br><span class="line-number">24</span><br><span class="line-number">25</span><br><span class="line-number">26</span><br><span class="line-number">27</span><br><span class="line-number">28</span><br><span class="line-number">29</span><br><span class="line-number">30</span><br><span class="line-number">31</span><br><span class="line-number">32</span><br><span class="line-number">33</span><br><span class="line-number">34</span><br><span class="line-number">35</span><br><span class="line-number">36</span><br><span class="line-number">37</span><br><span class="line-number">38</span><br><span class="line-number">39</span><br><span class="line-number">40</span><br><span class="line-number">41</span><br><span class="line-number">42</span><br><span class="line-number">43</span><br><span class="line-number">44</span><br><span class="line-number">45</span><br><span class="line-number">46</span><br><span class="line-number">47</span><br><span class="line-number">48</span><br><span class="line-number">49</span><br><span class="line-number">50</span><br><span class="line-number">51</span><br><span class="line-number">52</span><br><span class="line-number">53</span><br><span class="line-number">54</span><br><span class="line-number">55</span><br><span class="line-number">56</span><br><span class="line-number">57</span><br><span class="line-number">58</span><br><span class="line-number">59</span><br><span class="line-number">60</span><br><span class="line-number">61</span><br><span class="line-number">62</span><br><span class="line-number">63</span><br><span class="line-number">64</span><br><span class="line-number">65</span><br><span class="line-number">66</span><br><span class="line-number">67</span><br><span class="line-number">68</span><br><span class="line-number">69</span><br><span class="line-number">70</span><br><span class="line-number">71</span><br><span class="line-number">72</span><br><span class="line-number">73</span><br><span class="line-number">74</span><br><span class="line-number">75</span><br><span class="line-number">76</span><br><span class="line-number">77</span><br><span class="line-number">78</span><br><span class="line-number">79</span><br><span class="line-number">80</span><br><span class="line-number">81</span><br><span class="line-number">82</span><br><span class="line-number">83</span><br><span class="line-number">84</span><br><span class="line-number">85</span><br><span class="line-number">86</span><br><span class="line-number">87</span><br><span class="line-number">88</span><br><span class="line-number">89</span><br><span class="line-number">90</span><br><span class="line-number">91</span><br><span class="line-number">92</span><br><span class="line-number">93</span><br><span class="line-number">94</span><br><span class="line-number">95</span><br><span class="line-number">96</span><br><span class="line-number">97</span><br><span class="line-number">98</span><br><span class="line-number">99</span><br><span class="line-number">100</span><br><span class="line-number">101</span><br><span class="line-number">102</span><br><span class="line-number">103</span><br><span class="line-number">104</span><br><span class="line-number">105</span><br><span class="line-number">106</span><br><span class="line-number">107</span><br><span class="line-number">108</span><br><span class="line-number">109</span><br><span class="line-number">110</span><br><span class="line-number">111</span><br><span class="line-number">112</span><br><span class="line-number">113</span><br><span class="line-number">114</span><br><span class="line-number">115</span><br><span class="line-number">116</span><br><span class="line-number">117</span><br><span class="line-number">118</span><br><span class="line-number">119</span><br><span class="line-number">120</span><br><span class="line-number">121</span><br><span class="line-number">122</span><br><span class="line-number">123</span><br><span class="line-number">124</span><br><span class="line-number">125</span><br><span class="line-number">126</span><br></div></div><h2 id="配置"><a href="#配置" class="header-anchor">#</a> 配置</h2> <p>可参照下面链接中的文章进行配置<br> <a href="https://www.cnblogs.com/Grewer/p/9427560.html" target="_blank" rel="noopener noreferrer">在 Vue 项目中(vue-cli2,vue-cli3)使用 pug 简化 HTML 的编写<svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></p> <h2 id="vue-config-js"><a href="#vue-config-js" class="header-anchor">#</a> vue.config.js</h2> <p>webpack.config.js</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code>module<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  129. rules<span class="token punctuation">:</span> <span class="token punctuation">[</span>
  130. <span class="token punctuation">{</span>
  131. test<span class="token punctuation">:</span> <span class="token regex">/\.vue$/</span><span class="token punctuation">,</span>
  132. use<span class="token punctuation">:</span> <span class="token punctuation">[</span>
  133. <span class="token punctuation">{</span>
  134. loader<span class="token punctuation">:</span> <span class="token string">'vue-loader'</span><span class="token punctuation">,</span>
  135. options<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  136. loaders<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  137. stylus<span class="token punctuation">:</span> <span class="token punctuation">[</span>
  138. <span class="token punctuation">{</span>
  139. loader<span class="token punctuation">:</span> <span class="token string">'stylus-resources-loader'</span><span class="token punctuation">,</span>
  140. options<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  141. resources<span class="token punctuation">:</span> <span class="token string">'./src/assets/_base.styl'</span><span class="token punctuation">,</span>
  142. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  143. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  144. <span class="token punctuation">]</span><span class="token punctuation">,</span>
  145. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  146. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  147. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  148. <span class="token punctuation">]</span><span class="token punctuation">,</span>
  149. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  150. <span class="token punctuation">]</span><span class="token punctuation">,</span>
  151. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  152. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br><span class="line-number">18</span><br><span class="line-number">19</span><br><span class="line-number">20</span><br><span class="line-number">21</span><br><span class="line-number">22</span><br><span class="line-number">23</span><br><span class="line-number">24</span><br></div></div><p>vue.config.js</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">const</span> path <span class="token operator">=</span> <span class="token function">require</span><span class="token punctuation">(</span><span class="token string">'path'</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  153. module<span class="token punctuation">.</span>exports <span class="token operator">=</span> <span class="token punctuation">{</span>
  154. <span class="token function-variable function">chainWebpack</span><span class="token punctuation">:</span> <span class="token parameter">config</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  155. config<span class="token punctuation">.</span>module
  156. <span class="token punctuation">.</span><span class="token function">rule</span><span class="token punctuation">(</span><span class="token string">'vue'</span><span class="token punctuation">)</span>
  157. <span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span><span class="token string">'vue-loader'</span><span class="token punctuation">)</span>
  158. <span class="token punctuation">.</span><span class="token function">tap</span><span class="token punctuation">(</span><span class="token parameter">options</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  159. options<span class="token punctuation">.</span>loaders<span class="token punctuation">.</span>stylus <span class="token operator">=</span> options<span class="token punctuation">.</span>loaders<span class="token punctuation">.</span>stylus<span class="token punctuation">.</span><span class="token function">concat</span><span class="token punctuation">(</span><span class="token punctuation">{</span>
  160. loader<span class="token punctuation">:</span> <span class="token string">'stylus-resources-loader'</span><span class="token punctuation">,</span>
  161. options<span class="token punctuation">:</span> <span class="token punctuation">{</span>
  162. resources<span class="token punctuation">:</span> path<span class="token punctuation">.</span><span class="token function">resolve</span><span class="token punctuation">(</span><span class="token string">'./src/assets/_base.styl'</span><span class="token punctuation">)</span><span class="token punctuation">,</span>
  163. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  164. <span class="token punctuation">}</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  165. <span class="token keyword">return</span> options<span class="token punctuation">;</span>
  166. <span class="token punctuation">}</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  167. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  168. <span class="token punctuation">}</span><span class="token punctuation">;</span>
  169. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br></div></div></div> <footer class="page-edit"><!----> <div class="last-updated"><span class="prefix">Last Updated:</span> <span class="time">11/6/2018, 9:54:47 AM</span></div></footer> <div class="page-nav"><p class="inner"><span class="prev">
  170. <a href="/VUE/2018_11_02_03.html" class="prev">plugin</a></span> <!----></p></div> </main></div><div class="global-ui"></div></div>
  171. <script src="/assets/js/app.44a82e39.js" defer></script><script src="/assets/js/3.8ae7454d.js" defer></script><script src="/assets/js/116.e934c00e.js" defer></script>
  172. </body>
  173. </html>