欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解webpack編譯多頁面vue項目的配置問題

 更新時間:2017年12月11日 10:08:19   作者:_gunner_  
本篇文章主要介紹了詳解webpack編譯多頁面vue項目的配置問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

 本文主要介紹了webpack編譯多頁面vue項目的配置問題,分享給大家,具體如下:

一般情況下,構(gòu)建一個vue項目的步驟為:

1,安裝nodejs環(huán)境

2,安裝vue-cli

cnpm install vue-cli -g 

3,構(gòu)建vue項目

vue init webpack-simple vue-cli-multipage-demo 

4, 安裝項目依賴包

cnpm install 

5,在開發(fā)環(huán)境下運(yùn)行該項目:

npm run dev 

通過上面這幾步一個簡單的vue項目的開發(fā)環(huán)境基本就搭建起來,接下來的工作就是填代碼了。

最近在做一個前端代碼重構(gòu)的時候發(fā)現(xiàn)一個問題,使用這個腳手架構(gòu)建的項目滿足不了我的需求,其實這個需求有一點(diǎn)違背我們vue的初衷的,vue開發(fā)的是單頁面應(yīng)用(SPA),這里我需要他實現(xiàn)多頁面的效果。什么意思呢?舉個例子:我們在網(wǎng)頁開發(fā)的時候,有時候點(diǎn)擊一個連接,瀏覽器會新代開一個tab頁來顯示我們的內(nèi)容,這個時候其實就出現(xiàn)多頁面的情況了,新開的這個頁面其實已經(jīng)不屬于我們之前的那個頁面,(SPA)其實是通過路由的方式,讓多個頁面在主頁面中顯示。但是這個時候新開的頁面已經(jīng)脫離主頁面了。

通過vue-cli腳手架構(gòu)建的項目的webpack配置文件支持單頁面的應(yīng)用開發(fā),他只有一個入口文件。而且最后只會生產(chǎn)一個頁面。如何才能滿足我的需求,讓webpack同時便于多個頁面呢,其實還是比較簡單的,只需要將webpack稍微改裝一下,就完全可以了。

首先我們需要在build文件下的utils.js文件家中增加一個獲取文件夾中文件路徑的方法,這個方法將目標(biāo)文件解析成對象的形式。
utils.js

var glob = require("glob");//分析文件夾中文件路徑的第三方模塊
exports.getEntry = function(globPath) {
 var entries = {},
 basename, tmp, pathname;
 if (typeof (globPath) != "object") {
 globPath = [globPath]
 }
 globPath.forEach((itemPath) => {
 glob.sync(itemPath).forEach(function (entry) {
  basename = path.basename(entry, path.extname(entry));
  if (entry.split('/').length > 4) {
  tmp = entry.split('/').splice(-3);
  pathname = tmp.splice(0, 1) + '/' + basename; // 正確輸出js和html的路徑
  entries[pathname] = entry;
  } else {
  entries[basename] = entry;
  }
 });
 });
 return entries;
}

然后修改wenpack.base.conf.js文件,修改入口文件,原來的文件是單文件,現(xiàn)在需要將單文件入口改成多文件入口了。

webpack.dev.conf.js

var path = require('path')
var config = require('../config')
var utils = require('./utils')
var projectRoot = path.resolve(__dirname, '../')
var glob = require('glob');
var entries = utils.getEntry(['./src/module/**/*.js']); // 獲得多頁面的入口js文件
var env = process.env.NODE_ENV
// various preprocessor loaders added to vue-loader at the end of this file
var cssSourceMapDev = (env === 'development' && config.dev.cssSourceMap)
var cssSourceMapProd = (env === 'production' && config.build.productionSourceMap)
var useCssSourceMap = cssSourceMapDev || cssSourceMapProd
module.exports = {
 entry: entries,//這是通過前面新增的方法獲取的文件路徑對象
 output: {
 path: config.build.assetsRoot,
 publicPath: process.env.NODE_ENV === 'production' ? config.build.assetsPublicPath : config.dev.assetsPublicPath,
 filename: '[name].js'
 }
 ...
}

下面需要修改webpack.dev,conf.js文件了,這里主要是修改原來配置的首頁,這里需要配置多個頁面

webpack.dev.conf.js

var path = require('path');
var config = require('../config')
var webpack = require('webpack')
var merge = require('webpack-merge')
var utils = require('./utils')
var baseWebpackConfig = require('./webpack.base.conf')
var HtmlWebpackPlugin = require('html-webpack-plugin')
Object.keys(baseWebpackConfig.entry).forEach(function (name) {
 baseWebpackConfig.entry[name] = ['./build/dev-client'].concat(baseWebpackConfig.entry[name])
})
module.exports = merge(baseWebpackConfig, {
 ...
});
//新增
var pages =utils.getEntry(['./src/module/*.html','./src/module/**/*.html']);
for (var pathname in pages) {
 // 配置生成的html文件,定義路徑等
 var conf = {
 filename: pathname + '.html',
 template: pages[pathname], // 模板路徑
 inject: true,    // js插入位置
 chunksSortMode: 'dependency'
 };
 if (pathname in module.exports.entry) {
 conf.chunks = ['manifest', 'vendor', pathname];
 conf.hash = true;
 }
 module.exports.plugins.push(new HtmlWebpackPlugin(conf));
}

這里這要是改變了new HtmlWebpackPlugin的conf對象,原來的配置的是單個html,現(xiàn)在通過循環(huán)pages對象,生成多個html配置對象。

通過上面的配置,當(dāng)我們執(zhí)行npm run dev 的時候,webpack就可以同時便于多個頁面,然后將前面wenpack.base.conf.js中配置的js文件,插入到對應(yīng)的html頁面中。

這個時候我們運(yùn)行項目npm run dev 然后我們就可以訪問不同的頁面了,這里需要注意一下,既然我們需要管理多個頁面,我們就應(yīng)該在src下建立一個目錄專門來訪放不同的頁面。這樣項目結(jié)構(gòu)看起來更加清晰,便于維護(hù)。

這是我寫的一個demo地址,有興趣的可以拉下來看看vue-cli-multi-page

運(yùn)行起來后訪問http://localhost:8080/module/index.html,然后點(diǎn)擊按鈕,打開新頁面。

上面這樣配置只是開發(fā)環(huán)境,最后生產(chǎn)環(huán)境的配置文件webpack.prod.conf.js也需要修改,這樣在生產(chǎn)打包的時候就可以同時在dist中生成多個html文件。

webpack.prod.conf:

var path = require('path')
var config = require('../config')
var utils = require('./utils')
var webpack = require('webpack')
var merge = require('webpack-merge')
var baseWebpackConfig = require('./webpack.base.conf')
var ExtractTextPlugin = require('extract-text-webpack-plugin')
var HtmlWebpackPlugin = require('html-webpack-plugin')
var CleanPlugin = require('clean-webpack-plugin')//webpack插件,用于清除目錄文件
var env = config.build.env
var webpackConfig = merge(baseWebpackConfig, {
...
}
//這里是修改的部分,和webpack.dev.conf.js的修改是一樣的
module.exports = webpackConfig
var pages =utils.getEntry(['./src/module/**/*.html']);
for (var pathname in pages) {
 // 配置生成的html文件,定義路徑等
 var conf = {
 filename: pathname + '.html',//生成 html 文件的文件名
 template: pages[pathname], // 根據(jù)自己的指定的模板文件來生成特定的 html 文件。這里的模板類型可以是任意你喜歡的模板,可以是 html, jade, ejs, hbs, 等等,但是要注意的是,使用自定義的模板文件時,需要提前安裝對應(yīng)的 loader,
 inject: true,    // 注入選項。有四個選項值 true, body, head, false.true:默認(rèn)值,script標(biāo)簽位于html文件的 body 底部,body:同 true,head:script 標(biāo)簽位于 head 標(biāo)簽內(nèi),false:不插入生成的 js 文件,只是單純的生成一個 html 文件
 // necessary to consistently work with multiple chunks via CommonsChunkPlugin
 chunksSortMode: 'dependency'
 };
 if (pathname in module.exports.entry) {
 conf.chunks = ['manifest', 'vendor', pathname];
 conf.hash = true;
 }
 module.exports.plugins.push(new HtmlWebpackPlugin(conf));
}

以上就是使用vue-cli腳手架來解決vue多頁面開發(fā)的解決方案,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue彈窗插件實戰(zhàn)代碼

    vue彈窗插件實戰(zhàn)代碼

    這篇文章主要介紹了vue彈窗插件實戰(zhàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • vue2+elementUI的el-tree的選中、高亮、定位功能的實現(xiàn)

    vue2+elementUI的el-tree的選中、高亮、定位功能的實現(xiàn)

    這篇文章主要介紹了vue2+elementUI的el-tree的選中、高亮、定位功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09
  • Vue中簡單的虛擬DOM是什么樣

    Vue中簡單的虛擬DOM是什么樣

    這些年寫前端vue時經(jīng)常碰到虛擬DOM這個單詞,但都是聽到就算了,左耳進(jìn)右耳出,知道有這么個東西就完了,因為感覺也沒有影響我實現(xiàn)公司的產(chǎn)品業(yè)務(wù)邏輯。今天在這里想花點(diǎn)時間探討下虛擬DOM相關(guān)的知識,給自己補(bǔ)補(bǔ)課
    2022-10-10
  • Vue?ELement?Table技巧表格業(yè)務(wù)需求實戰(zhàn)示例

    Vue?ELement?Table技巧表格業(yè)務(wù)需求實戰(zhàn)示例

    這篇文章主要介紹了Vue?ELement?Table技巧表格業(yè)務(wù)需求實戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • vant使用datetime-picker組件設(shè)置maxDate和minDate的坑及解決

    vant使用datetime-picker組件設(shè)置maxDate和minDate的坑及解決

    這篇文章主要介紹了vant使用datetime-picker組件設(shè)置maxDate和minDate的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Vue開發(fā)配置tsconfig.json文件的實現(xiàn)

    Vue開發(fā)配置tsconfig.json文件的實現(xiàn)

    tsconfig.json文件中指定了用來編譯這個項目的根文件和編譯選項,本文就來介紹一下Vue開發(fā)配置tsconfig.json文件的實現(xiàn),感興趣的可以了解一下
    2023-08-08
  • vue 組件中添加樣式不生效的解決方法

    vue 組件中添加樣式不生效的解決方法

    這篇文章主要介紹了vue 組件中添加樣式不生效的解決方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • vue 1.x 交互實現(xiàn)仿百度下拉列表示例

    vue 1.x 交互實現(xiàn)仿百度下拉列表示例

    本篇文章主要介紹了vue 1.x 交互實現(xiàn)仿百度下拉列表示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • Vue3.0寫自定義指令的簡單步驟記錄

    Vue3.0寫自定義指令的簡單步驟記錄

    Vue中除了內(nèi)置指令,也允許注冊自定義的指令,下面這篇文章主要給大家介紹了關(guān)于Vue3.0寫自定義指令的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • 如何實現(xiàn)無感刷新token

    如何實現(xiàn)無感刷新token

    這篇文章主要介紹了如何實現(xiàn)無感刷新token,當(dāng)token過期的時候,刷新token,前端需要做到無感刷新token,即刷token時要做到用戶無感知,避免頻繁登錄。下面我們大家一起進(jìn)入文章看看實現(xiàn)思路即詳細(xì)內(nèi)容,需要的朋友可以參考一下
    2021-11-11

最新評論