亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

詳解使用webpack構建多頁面應用

2019-11-19 14:40:19
字體:
來源:轉載
供稿:網友

關于webpack的配置和使用,網上已經有許多文章了,大多是在講單頁應用,當我們需要打包多個html時,事情就變得麻煩起來。怎么在webpack-dev-server里使用路由?怎么打包多個html和js chunk并自動更新md5?本文講的就是如何解決這些問題。

這里假設你對Webpack已經有最基礎的了解

需求

來看下我們的需求:

  1. 使用webpack-dev-server做開發時的服務器
  2. 在webpack-dev-server里使用路由,訪問/a時候顯示a.html,/b顯示b.html
  3. 打包成多個html,給其中引用到資源加md5戳

主要目錄結構

├── src            │  └── views         # 每一個文件夾對應一個頁面│    └── a         │      └── index.js│    └── b         │      └── index.js├── output          # 打包輸出的目錄|  └── ...└── template.html       # 將根據這個模版,生成各個頁面的html└── webpack.config.js└── dev-server.js       # webpack-dev-server + express    

只列出了主要的目錄,這里我們根據一個template.html來生成多個頁面的html,他們之間只有引用的資源路徑不同。當然,你也可以每個頁面單獨使用一個html模版。

Webpack 配置

這里主要解決兩個小問題。

1. 打包多個頁面的js文件

讀取src/views下的目錄,約定每一個目錄當成一個頁面,打包成一個js chunk。

2. 打包多個html

循環生成多個HtmlWebpackPlugin插件,把每一個插件的chunks各自指向上面打包的js chunk。

// webpack.config.jsvar glob = require('glob');var webpackConfig = {  /* 一些webpack基礎配置 */  };// 獲取指定路徑下的入口文件function getEntries(globPath) {   var files = glob.sync(globPath),    entries = {};   files.forEach(function(filepath) {     // 取倒數第二層(view下面的文件夾)做包名     var split = filepath.split('/');     var name = split[split.length - 2];     entries[name] = './' + filepath;   });   return entries;}    var entries = getEntries('src/view/**/index.js');Object.keys(entries).forEach(function(name) {  // 每個頁面生成一個entry,如果需要HotUpdate,在這里修改entry  webpackConfig.entry[name] = entries[name];    // 每個頁面生成一個html  var plugin = new HtmlWebpackPlugin({    // 生成出來的html文件名    filename: name + '.html',    // 每個html的模版,這里多個頁面使用同一個模版    template: './template.html',    // 自動將引用插入html    inject: true,    // 每個html引用的js模塊,也可以在這里加上vendor等公用模塊    chunks: [name]  });  webpackConfig.plugins.push(plugin);})

路由配置

在多頁應用下,我們希望訪問的是localhost:8080/a,而不是localhost:8080/a.html。

由于webpack-dev-server只是將文件打包在內存里,所以你沒法在express里直接sendfile('output/views/a.html'),因為這個文件實際上還不存在。還好webpack提供了一個outputFileStream,用來輸出其內存里的文件,我們可以利用它來做路由。

注意,為了自定義路由,你可能需要引進express或koa之類的庫,然后將webpack-dev-server作為中間件處理。

// dev-server.jsvar express = require('express')var webpack = require('webpack')var webpackConfig = require('./webpack.config')var app = express();// webpack編譯器var compiler = webpack(webpackConfig);// webpack-dev-server中間件var devMiddleware = require('webpack-dev-middleware')(compiler, {  publicPath: webpackConfig.output.publicPath,  stats: {    colors: true,    chunks: false  }});app.use(devMiddleware)// 路由app.get('/:viewname?', function(req, res, next) {    var viewname = req.params.viewname     ? req.params.viewname + '.html'     : 'index.html';      var filepath = path.join(compiler.outputPath, viewname);    // 使用webpack提供的outputFileSystem  compiler.outputFileSystem.readFile(filepath, function(err, result) {    if (err) {      // something error      return next(err);    }    res.set('content-type', 'text/html');    res.send(result);    res.end();  });});module.exports = app.listen(8080, function(err) {  if (err) {    // do something    return;  }    console.log('Listening at http://localhost:' + port + '/n')})

最后,在package.json里定義下啟動命令:

// package.json{  scripts: {    "dev": "node ./dev-server.js"    }}

運行 npm run dev,然后在瀏覽器訪問localhost:8080/各個頁面,你應該可以看到想要的結果。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久精品久久| 亚洲乱码av中文一区二区| 日韩亚洲第一页| 26uuu日韩精品一区二区| 97在线精品视频| 亚洲精品小视频在线观看| 日韩av手机在线看| 免费av一区二区| 最新国产成人av网站网址麻豆| 爽爽爽爽爽爽爽成人免费观看| 日韩精品中文字幕在线观看| 久久久久久久影视| 欧美高清在线播放| 亚洲精品电影在线观看| 日韩av中文字幕在线播放| 91成人在线播放| 欧美日韩国产中文字幕| 欧美电影免费观看高清| 国产在线98福利播放视频| 亚洲精品乱码久久久久久金桔影视| 中文字幕亚洲一区在线观看| 亚洲欧美在线看| 国产成人免费av| 亚洲免费一级电影| 91在线直播亚洲| 欧美大成色www永久网站婷| 国产亚洲一区精品| 国产视频亚洲视频| 97精品国产aⅴ7777| 欧美最猛性xxxx| 夜夜狂射影院欧美极品| 中文字幕免费精品一区| 亚洲第一av网站| 欧美大片欧美激情性色a∨久久| 精品日本美女福利在线观看| 91欧美激情另类亚洲| 91精品国产自产在线老师啪| 欧美日韩另类字幕中文| 国产一区二区三区在线观看网站| 国产一区二区三区视频| 51色欧美片视频在线观看| 欧美电影免费观看电视剧大全| 国产日韩精品一区二区| 欧美大片在线看| 91亚洲va在线va天堂va国| 日本精品久久久久影院| 日本免费在线精品| 上原亚衣av一区二区三区| 欧美天堂在线观看| 成人激情在线观看| 久久九九全国免费精品观看| 亚洲图片在线综合| 欧美一级bbbbb性bbbb喷潮片| 国产精品美女www| 久久香蕉精品香蕉| 欧美精品在线网站| 韩国v欧美v日本v亚洲| 亚洲天天在线日亚洲洲精| 亚洲四色影视在线观看| 国产有码在线一区二区视频| 久久成人人人人精品欧| 国产mv久久久| 亚洲精品第一页| 清纯唯美亚洲激情| 日韩av黄色在线观看| 欧美日韩xxx| 欧美自拍视频在线| 欧美xxxx做受欧美.88| 欧美国产日产韩国视频| 91精品国产综合久久香蕉| 欧美乱大交做爰xxxⅹ性3| 精品国产一区二区三区久久久| 性色av一区二区三区红粉影视| 亚洲精品国产欧美| 国产亚洲一区二区精品| 国产视频精品在线| 91视频九色网站| 国产精品久久久久免费a∨| 国产成人在线精品| 一个人看的www欧美| 日韩美女写真福利在线观看| 精品福利免费观看| 91大神在线播放精品| 欧美另类交人妖| 欧美猛交ⅹxxx乱大交视频| 欧美激情va永久在线播放| 亚洲欧美精品在线| 国产精品欧美风情| …久久精品99久久香蕉国产| 日韩黄在线观看| 日韩高清免费在线| 国模精品视频一区二区| 亚洲欧美精品suv| 久久中国妇女中文字幕| 国产精品欧美风情| 国产福利成人在线| 国产精品久久97| 岛国精品视频在线播放| 琪琪亚洲精品午夜在线| 成人黄色在线免费| 国产一区欧美二区三区| 日韩成人小视频| 精品一区精品二区| 亚洲性夜色噜噜噜7777| 亚洲精品久久久久国产| 亚洲精品久久久久久久久久久久久| 国产91精品久久久| 热re99久久精品国产66热| 亚洲综合在线做性| 欧美最顶级的aⅴ艳星| 精品久久久视频| 亚洲成人精品在线| 欧美美女操人视频| 欧美性受xxx| 国产精品久久久久久久久久三级| 成人精品aaaa网站| 欧洲亚洲妇女av| 久久精品亚洲94久久精品| 亚洲一级黄色片| 日韩高清中文字幕| 国产精品成人va在线观看| 一区二区三区 在线观看视| 久久免费视频这里只有精品| 亚洲欧美一区二区激情| 国产精品流白浆视频| 欧美xxxx做受欧美| 日本成熟性欧美| 91在线观看免费高清| 亚洲国产精品一区二区三区| 久久久亚洲福利精品午夜| 亚洲欧美综合精品久久成人| 欧美亚洲成人精品| 日韩精品中文字幕视频在线| 91高清视频免费| 国产精品视频yy9099| 一区二区av在线| 国产91精品久久久久| 欧美丰满少妇xxxxx做受| 欧美大码xxxx| 欧美疯狂性受xxxxx另类| 亚洲成年人影院在线| 欧美视频在线观看免费网址| 精品成人69xx.xyz| 97在线视频精品| 91精品久久久久| 亚洲中国色老太| 国产日韩欧美视频在线| 欧美性高潮床叫视频| 日韩大陆毛片av| 亚洲aaa激情| 亚洲国产天堂网精品网站| 亚洲成人av中文字幕| 亚洲欧美日韩图片| 欧美激情精品久久久久久变态| 国产精品第七影院| 日韩电影免费观看在线观看| 91精品免费看| 98视频在线噜噜噜国产| 国产精品私拍pans大尺度在线| 国产精品pans私拍| 一级做a爰片久久毛片美女图片| 热久久这里只有| 欧美日韩中文字幕| 日韩一区二区久久久|