仿Nuxt.js的vue-cli多頁面配置

1.全局安裝vue-cli:Vue.js官方提供的用于快速創(chuàng)建項(xiàng)目模板的腳手架工具

$ npm install -g vue-cli 

$ yarn global add vue-cli

2.創(chuàng)建項(xiàng)目模板:官方提供了五個(gè)模板--webpack鹦倚、webpack-simple蒸痹、browserify左敌、browserify-simple、simple,選擇webpack模板

$ vue init webpack project-name

3.在安裝過程中會有一些提示:
1)Vue build這個(gè)選項(xiàng)選擇Runtime + Compiler
2)安裝vue-router,ESLint躯舔、Karma+Mocha、Nightwatch根據(jù)需求選擇安裝

image.png

image.png

3)根據(jù)提示操作省古,即可成功啟動(dòng)項(xiàng)目

4.現(xiàn)在創(chuàng)建的項(xiàng)目模板是單頁面應(yīng)用,與多頁面應(yīng)用還有些差別丧失,需要做一些調(diào)整:
1)項(xiàng)目目錄結(jié)構(gòu)的調(diào)整:


image.png

在開發(fā)路徑src下增加modules和pages文件夾豺妓,分別存放模塊和頁面
有關(guān)頁面的所有文件都放到同一文件夾下就近管理:index.html(頁面模板)、main.js(頁面入口文件)布讹、App.vue(頁面使用的組件琳拭,公用組件放到components文件夾下)、router(頁面的路由配置)描验、assets(頁面的靜態(tài)資源)都移到index文件夾下白嘁,并把main.js改為index.js,保證頁面的入口js文件和模板文件的名稱一致

2)在build/utils.js中添加兩個(gè)方法:webpack多入口文件和多頁面輸出

var path = require('path')
var glob = require('glob')
var HtmlWebpackPlugin = require('html-webpack-plugin')
var PAGE_PATH = path.resolve(__dirname, '../src/pages')
var merge = require('webpack-merge')

//多入口配置
exports.entries = function() {
  var entryFiles = glob.sync(PAGE_PATH + '/*/*.js')
  var map = {}
  entryFiles.forEach((filePath) => {
    var filename = filePath.substring(filePath.lastIndexOf('\/') + 1, filePath.lastIndexOf('.'))
    map[filename] = filePath
  })
  return map
}

//多頁面輸出配置
exports.htmlPlugin = function() {
  let entryHtml = glob.sync(PAGE_PATH + '/*/*.html')
  let arr = []
  entryHtml.forEach((filePath) => {
    let filename = filePath.substring(filePath.lastIndexOf('\/') + 1, filePath.lastIndexOf('.'))
    let conf = {
      template: filePath,
      filename: filename + '.html',
      chunks: [filename],
      inject: true
    }
    if (process.env.NODE_ENV === 'production') {
      conf = merge(conf, {
        chunks: ['manifest', 'vendor', filename],
        minify: {
          removeComments: true,
          collapseWhitespace: true,
          removeAttributeQuotes: true
        },
        chunksSortMode: 'dependency'
      })
    }
    arr.push(new HtmlWebpackPlugin(conf))
  })
  return arr
}

3)修改build/webpack.base.conf.js的入口配置

module.exports = {
  entry: utils.entries(),
...

4)修改build/webpack.dev.conf.js和build/webpack.prod.conf.js的多頁面配置:把原有的頁面模板配置注釋或刪除,并把多頁面配置添加到plugins
webpack.dev.conf.js:

  plugins: [
    ......
    //  new HtmlWebpackPlugin({
    //    filename: 'index.html',
    //    template: 'index.html',
    //    inject: true
    //  }),
    ......
  ].concat(utils.htmlPlugin())

webpack.prod.conf.js:

  plugins: [
    ......
    // new HtmlWebpackPlugin({
    //   filename: config.build.index,
    //   template: 'index.html',
    //   inject: true,
    //   minify: {
    //     removeComments: true,
    //     collapseWhitespace: true,
    //     removeAttributeQuotes: true
    //   },
    //   chunksSortMode: 'dependency'
    // }),
    ......
  ].concat(utils.htmlPlugin())

補(bǔ)充說明:在上面多頁面輸出配置中有這樣一行代碼:

  chunks: ['manifest', 'vendor', filename],

這是html-webpack-plugin插件對頁面入口文件(即js文件)的限定膘流,如果不設(shè)置則會把整個(gè)項(xiàng)目下的所有入口文件全部引入
為什么要引入'manifest'和'vendor'絮缅,在build/webpack.prod.conf.js中有如下代碼:

    // split vendor js into its own file
    new webpack.optimize.CommonsChunkPlugin({
      name: 'vendor',
      minChunks: function (module, count) {
        // any required modules inside node_modules are extracted to vendor
        return (
          module.resource &&
          /\.js$/.test(module.resource) &&
          module.resource.indexOf(
            path.join(__dirname, '../node_modules')
          ) === 0
        )
      }
    }),
    // extract webpack runtime and module manifest to its own file in order to
    // prevent vendor hash from being updated whenever app bundle is updated
    new webpack.optimize.CommonsChunkPlugin({
      name: 'manifest',
      chunks: ['vendor']
    }),

vendor模塊是指提取涉及node_modules中的公共模塊
manifest模塊是對vendor模塊做的緩存
關(guān)于CommonsChunkPlugin插件的詳細(xì)說明請閱讀官方文檔

關(guān)于html-webpack-plugin插件的配置還有一行代碼:

chunksSortMode: 'dependency'

插件會按照模塊的依賴關(guān)系依次加載鲁沥,即:manifest,vendor耕魄,本頁面入口画恰,其他頁面入口...

至此,多頁面應(yīng)用已經(jīng)搭建完畢吸奴,只需要在pages文件夾創(chuàng)建相應(yīng)的頁面文件即可允扇。
本文轉(zhuǎn)載自https://github.com/tonyfree/blog/issues/1
如果有什么不理解可以在下方留言
但是我依然覺得 nuxt會更適合上手 如果你是項(xiàng)目需要 建議使用nuxt.js

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市则奥,隨后出現(xiàn)的幾起案子考润,更是在濱河造成了極大的恐慌,老刑警劉巖读处,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件糊治,死亡現(xiàn)場離奇詭異,居然都是意外死亡档泽,警方通過查閱死者的電腦和手機(jī)俊戳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來馆匿,“玉大人扰她,你說我怎么就攤上這事所禀。” “怎么了?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵猿规,是天一觀的道長。 經(jīng)常有香客問我夭谤,道長港粱,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任呕臂,我火速辦了婚禮破托,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘歧蒋。我一直安慰自己土砂,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布谜洽。 她就那樣靜靜地躺著萝映,像睡著了一般。 火紅的嫁衣襯著肌膚如雪阐虚。 梳的紋絲不亂的頭發(fā)上序臂,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天,我揣著相機(jī)與錄音实束,去河邊找鬼奥秆。 笑死逊彭,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的吭练。 我是一名探鬼主播诫龙,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鲫咽!你這毒婦竟也來了签赃?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤分尸,失蹤者是張志新(化名)和其女友劉穎锦聊,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體箩绍,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡孔庭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了材蛛。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片圆到。...
    茶點(diǎn)故事閱讀 39,711評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖卑吭,靈堂內(nèi)的尸體忽然破棺而出芽淡,到底是詐尸還是另有隱情,我是刑警寧澤豆赏,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布挣菲,位于F島的核電站,受9級特大地震影響掷邦,放射性物質(zhì)發(fā)生泄漏白胀。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一抚岗、第九天 我趴在偏房一處隱蔽的房頂上張望或杠。 院中可真熱鬧,春花似錦宣蔚、人聲如沸廷痘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至元暴,卻和暖如春篷扩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背茉盏。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工鉴未, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留枢冤,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓铜秆,卻偏偏與公主長得像淹真,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子连茧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評論 2 353

推薦閱讀更多精彩內(nèi)容