詳解webpack 多入口配置,詳解webpack入口

來源:互聯網
上載者:User

詳解webpack 多入口配置,詳解webpack入口

同事套搭建vue項目,個人推薦了VUE官網的vue-cil的方式,http://cn.vuejs.org/guide/application.html

順著官網的操作,我們可以本地測試起我們的項目 npm run dev,首先我們要理解webpack打包主要是針對js,查看下面產生的配置,首頁是index.html,模版用的index.html,入口檔案用的mian.js

//file build/webpack.base.conf.js//entry 配置module.exports = { entry: {  app: './src/main.js' }, //....//file build/webpack.dev.conf.js//html配置  new HtmlWebpackPlugin({   filename: 'index.html',   template: 'index.html',   inject: true  })

1.上面的目錄沒辦法滿足我們多入口的要求,我們希望的是html放在一個views檔案夾下面,相關業務應用的vue放在一起,對就是這個樣子的

我們先簡單的改動下我們的配置,來適應這個項目結構,再尋找其中的規律,來完成自動設定(index.html)

//file build/webpack.base.conf.js//entry 配置module.exports = { entry: {  'index': './src/view/index/index.js',  'login': './src/view/login/login.js', }, //....//file build/webpack.dev.conf.js//html配置,index我們保留了根目錄訪問路徑  new HtmlWebpackPlugin({   filename: 'index.html',   template: './src/view/index/index.html',   inject: true,   chunks: ['index']  }),  new HtmlWebpackPlugin({   filename: 'login/login.html', //http訪問路徑   template: './src/view/login/login.html', //實際檔案路徑   inject: true,   chunks: ['login']  })

2.規律出來了,我們只要按照這樣的js和html的對應關係,就可以通過尋找檔案,來進行同一配置

var glob = require('glob')function getEntry(globPath, pathDir) {  var files = glob.sync(globPath);  var entries = {},    entry, dirname, basename, pathname, extname;  for (var i = 0; i < files.length; i++) {    entry = files[i];    dirname = path.dirname(entry);    extname = path.extname(entry);    basename = path.basename(entry, extname);    pathname = path.join(dirname, basename);    pathname = pathDir ? pathname.replace(pathDir, '') : pathname;    console.log(2, pathname, entry);    entries[pathname] = './' + entry;  }  return entries;}//我們的key不是簡單用的上一個代碼的index,login而是用的index/index,login/login因為考慮在login目錄下面還有register//檔案路徑的\\和/跟作業系統也有關係,需要注意var htmls = getEntry('./src/view/**/*.html', 'src\\view\\');var entries = {};var HtmlPlugin = [];for (var key in htmls) {  entries[key] = htmls[key].replace('.html', '.js')  HtmlPlugin.push(new HtmlWebpackPlugin({   filename: (key == 'index\\index' ? 'index.html' : key + '.html'),    template: htmls[key],   inject: true,    chunks: [key]  }))}

3.多入口配置就完成了,當然下面其實還有公用js提取的相關配置,如果項目裡面用到了非同步載入,即require.ensure,放在單獨目錄,進行匹配,按照上面的邏輯進行推理吧

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援幫客之家。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.