基於vue-cli的改造的多頁面開發腳手架

来源:http://www.cnblogs.com/hellobajie/archive/2017/11/28/7911185.html
-Advertisement-
Play Games

項目的GitHub地址:https://github.com/hellobajie/vue-cli-multipage 該腳手架同時支持vux,scss,less 目錄結構 修改配置文件 構建多頁面應用的關鍵在於向配置對象的plugins子項添加多個HtmlWebpackPlugin。 怎樣根據頁面 ...


項目的GitHub地址:https://github.com/hellobajie/vue-cli-multipage

該腳手架同時支持vux,scss,less

目錄結構

vue-cli-multipage
  |---build
  |---config
  |---src
    |---assets  圖片
    |---comm  公共的css及js
    |---components  組件
      |---vux.vue vux的dome頁面
      |---App.vue
    |---pages  html模板文件
      |---abc.html
      |---main.html
    |---abc.js  根據該js進行頁面的打包及調試
    |---main.js 

修改配置文件

構建多頁面應用的關鍵在於向配置對象的plugins子項添加多個HtmlWebpackPlugin。

怎樣根據頁面的多少動態的添加多個HtmlWebpackPlugin呢,我們需要使用glob插件;

npm install --save-dev glob  安裝glob插件

通過glob插件會將特定目錄下的文件名存儲為一個數組,遍歷該數據,生成多個HtmlWebpackPlugin,並插入plugins中;

//webpack.prod.conf.js
var
fileList = glob.sync('./src/*.js'); var fileNameList = []; fileList.forEach(function (item, index) { var name = item.match(/(\/)(\w+)(\.)/g)[0].substring(1, item.match(/(\/)(\w+)(\.)/g)[0].length - 1); fileNameList.push(name); }) var obj = {}; fileList.forEach(function (item, index) { var filename = fileNameList[index]; configObj.entry[filename] = item; configObj.plugins.push(new HtmlWebpackPlugin({ template: './src/pages/' +filename + '.html', filename: filename + '.html', inject: true, minify: { removeComments: true, collapseWhitespace: true, removeAttributeQuotes: true }, chunksSortMode: 'dependency', chunks: ['manifest', 'vendor', filename] })) })
//webpack.dev.conf.js
var
fileList = glob.sync('./src/*.js'); var fileNameList = []; fileList.forEach(function (item, index) { var name = item.match(/(\/)(\w+)(\.)/g)[0].substring(1, item.match(/(\/)(\w+)(\.)/g)[0].length - 1); fileNameList.push(name); }) var obj = {}; fileList.forEach(function (item, index) { var filename = fileNameList[index]; configObj.entry[filename] = item; configObj.plugins.push(new HtmlWebpackPlugin({ template: './src/pages/' + filename + '.html', filename: filename + '.html', inject: true, chunks: [filename] })) })

vue-cli問題優化

  1.遇到問題:項目打包後,無法直接在本地直接打開。

    解決辦法:在./config/index.js文件中,build下找到assetsPublicPath,將其值改為'./',即打包後,會在相對目錄下查找對應的資源;

 

  2.遇到問題:直接打開打包後的文件,報錯webpackJsonp is not defined。

     解決辦法:在webpack.prod.conf.js文件中,每個遍歷生成的HtmlWebpackPlugin,配置選項中,chunks對應的數組添加'manifest','vendor'。添加這兩項的目的是將公用的資源進行單獨打包,瀏覽器緩存後,後面打開的頁面就可以直接從緩存中讀取。

 

  3.遇到問題:多次打包後,未被覆蓋的文件會被保留下來。

     解決辦法:安裝clean-webpack-plugin插件,在webpack.prod.conf.js文件的plugins中添加如下代碼

new CleanWebpackPlugin(['dist'], {
    root: path.resolve(__dirname, '../'),
}),

 

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 簡介: html-webpack-plugin 是一個webpack插件,它簡化了註入webpack打包文件的html的創建。當webpack打包文件使用哈希值作為文件名並且每次編譯的哈希值都不同時尤其有用。你可以使用lodash模板來創建html文件,也可以使用你自己的載入器。 安裝: 第三方插件 ...
  • 1、表格實現 display:table- cell屬性類似於td標簽。會受一些css屬性破壞:float,position:absolute;display與這些樣式同用會失去效果。而且table-cell對margin無反應。 2、inline-block設置垂直居中 3、flex佈局實現居中 ...
  • 表格是一個組合標簽,用來佈局,相容性好;現在佈局思路大多數是div+Css。 對於表格標簽做了一下概述,認識一下。表格的頭部<thead></thead,和<tfoot></tfoot>可以省略,主要樣式如下 <tr></tr>表格的行,<td></td>表格的單元格。 表格標簽類型及特性: 1,單 ...
  • 針對vue中控制項的用法 首先 初步用法 }) 子組件調用父組件的方法 和父組件傳值入子組件 子組件: 父組件 : 動態切換不同的組件 在掛載點使用component標簽,然後使用v-bind:is=”組件名”,會自動去找匹配的組件名,如果沒有,則不顯示; 改變掛載的組件,只需要修改is指令的值即可 ...
  • JavaScript箭頭函數是ECMAScript 6中引入的編寫函數表達式的一種簡便方法。通常,在JavaScript中,可以通過兩種方式創建函數: 函數語句。 函數表達式。 可以如下所示創建函數語句: 也可以創建相同功能的函數表達式,如下所示: ECMA 2015(或ECMA Script 6) ...
  • jquery中的ajax方法參數總是記不住,這裡記錄一下。 1.url: 要求為String類型的參數,(預設為當前頁地址)發送請求的地址。 2.type: 要求為String類型的參數,請求方式(post或get)預設為get。註意其他http請求方法,例如put和delete也可以使用,但僅部分 ...
  • 作者: 以前在寫項目過程一直都沒有使用過Javascript的setter與getter方法,所以對其是一種要懂不懂的概念;今天看書看到這個知識點,還是模模糊糊的,於是就打算研究研究; Javascript對象的屬性是由名字,值和一組特性構成的。那麼首先,來瞭解一下對象的兩種屬性: + 數據屬性,我 ...
  • 簡介 Vue.use( plugin ):安裝 Vue.js 插件。如果插件是一個對象,必須提供 install 方法。如果插件是一個函數,它會被作為 install 方法。install 方法將被作為 Vue 的參數調用。 當 install 方法被同一個插件多次調用,插件將只會被安裝一次。 Vu ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...