亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue-cli3中如何打包成zip壓縮文件

 更新時(shí)間:2022年10月14日 10:23:42   作者:黑山老妖橙  
這篇文章主要介紹了vue-cli3中如何打包成zip壓縮文件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue-cli3打包成zip壓縮文件

目前在我司,采用前后分離的方式開(kāi)發(fā),這就會(huì)面臨一個(gè)問(wèn)題。那就是部署到服務(wù)器時(shí)如何部署?我們之前的方式是:執(zhí)行打包命令生成文件夾-> 將文件壓縮成zip -> 將zip上傳至服務(wù)器 ->解壓縮 -> 重啟服務(wù)。

在測(cè)試階段每天都要回歸bug,所以每天都要重復(fù)執(zhí)行上述操作。有沒(méi)有更自動(dòng)化一些的方式來(lái)實(shí)現(xiàn)呢?

就有了自動(dòng)化部署,但我在研究自動(dòng)化部署前,其實(shí)我是想在打包的時(shí)候自動(dòng)生成zip文件,然后本地的腳本讀取zip并上傳至服務(wù)器,還有一種思路就是上傳腳本可以進(jìn)行打包壓縮zip等。

因?yàn)槲覀冞€有其他部署方式,所以我采用生成zip包與自動(dòng)部署2步走的方案。

如何實(shí)現(xiàn)?

首先項(xiàng)目框架是vue-cli3,我們也都知道vue-cli內(nèi)置了我們常用的一些webpack配置,比如css壓縮、動(dòng)態(tài)生成html等,但它也提供了擴(kuò)展的方式。

vue-cli3 的webpack配置都放在了根目錄下的vue.config.js中。

生成zip的插件是:filemanager-webpack-plugin

(1) 安裝依賴 npm install filemanager-webpack-plugin --dev

(2) 打開(kāi)vue.config.js進(jìn)行修改。代碼如下:

const FileManagerPlugin = require("filemanager-webpack-plugin"); //引入
const packageName = 'dist';
var path = require('path')
module.exports = {
? productionSourceMap: false,
? outputDir: packageName, // 包名,我這里將他提取成了一個(gè)常量
? devServer: {
? ? open: true, // 默認(rèn)打開(kāi)
? ? port: 8001, // 本地服務(wù)端口口
? ? proxy: {
? ? ? ? // 代理
? ? ? "/api": {
? ? ? ? target: '192.168.162.73:8085', //服務(wù)器地址
? ? ? ? changeOrigin: true,
? ? ? ? ws: true,
? ? ? ? pathRewrite: {
? ? ? ? ? "^/api": ""
? ? ? ? }
? ? ? }
? ? }
? },
? // webpack配置
? configureWebpack: config => {
? ? config.resolve = {
? ? ? extensions: ['.js', '.vue', '.json', '.ts'],
? ? ? alias: {
? ? ? ? '@': path.join(__dirname, 'src')
? ? ? }
? ? }
? ? // plugins插件是一個(gè)數(shù)組且webpack本身已經(jīng)有一些配置,那么我們需要將其追加到數(shù)組中
? ? let fileManagerPlugin = new FileManagerPlugin({?
? ? ? onEnd: {
? ? ? ? delete: [ ? //首先需要?jiǎng)h除項(xiàng)目根目錄下的dist.zip
? ? ? ? ? `./${packageName}.zip`, ??
? ? ? ? ],
? ? ? ? archive: [ //然后我們選擇dist文件夾將之打包成dist.zip并放在根目錄
? ? ? ? ? {source: `./${packageName}`, destination: `./${packageName}.zip`}, ??
? ? ? ? ]
? ? ? }
? ? })
? ? config.plugins.push(fileManagerPlugin) // 追加到webpack plugins數(shù)組中。
? }
};

(3) 執(zhí)行npm run build ,默認(rèn)會(huì)執(zhí)行此配置文件。會(huì)發(fā)現(xiàn)根目錄下不僅有dist文件夾,還有dist.zip文件夾。

思考

我們?cè)谏晌募跋冗M(jìn)行刪除本地dist.zip文件,可根據(jù)自己情況選擇。

它默認(rèn)會(huì)先刪除本地的dist.zip文件夾,如果是第一次打包其實(shí)沒(méi)有此文件,它會(huì)不會(huì)報(bào)錯(cuò)呢?你可以嘗試一下,事實(shí)上是不報(bào)錯(cuò)的。

vue-cli3打包優(yōu)化

vue項(xiàng)目打包是需要做一些性能優(yōu)化的,這篇文章里我寫(xiě)了關(guān)于我知道的要做的優(yōu)化的部分,僅供參考。

const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
const path = require('path')
// 開(kāi)啟Gzip需要的依賴 yarn add compression-webpack-plugin -D
const CompressionWebpackPlugin = require('compression-webpack-plugin')
function resolve(dir) {
    return path.join(__dirname, dir)
}
// 標(biāo)記是否是生產(chǎn)環(huán)境
const isPruction = process.env.NODE_ENV === "production" 
const devNeedCdn = false // 標(biāo)記本地是否需要cdn引入
// cdn配置
// CDN的本質(zhì)上是將媒體資源,動(dòng)靜態(tài)圖片(Flash),HTML,CSS,JS等等內(nèi)容緩存到距離你更近的IDC,
// 從而讓用戶進(jìn)行共享資源,實(shí)現(xiàn)縮減站點(diǎn)間的響應(yīng)時(shí)間等等需求,而網(wǎng)游加速器的本質(zhì)則是通過(guò)建立高帶寬機(jī)房,
// 架設(shè)多節(jié)點(diǎn)服務(wù)器來(lái)為用戶進(jìn)行加速。我們可以將一些大體積的模塊,讓cdn幫我們提供相應(yīng)的資源,
// 這樣就可以緩解我們自己的服務(wù)器的壓力,同時(shí)提供更快更好的資源響應(yīng)

const cdn = {
    // 模塊名稱(chēng)和作用域名(對(duì)應(yīng)的是window里面的全局變量名)
    external: {
        vuex: 'Vuex',
        'vue-router': 'VueRouter'
    },
    //cdn的css鏈接
    css: [],
    //cdn的js連接 這里的資源地址請(qǐng)根據(jù)自己的連接
    js: [
        'https://cdn.staticfile.org/vuex/3.0.2/vuex.min.js', 
        'https://cdn.staticfile.org/vue-router/3.0.2/vue-router.min.js'
    ]
}
module.exports = {
    // devServer : {
    //     proxy: 'localhost:8080'
    // },
    productionSourceMap: false, // 上線后不生成map文件
    chainWebpack: (config) => {
        // 配置路徑別名
        config.resolve.alias
        .set('@', resolve('src'))
        .set('components', resolve('src/components'))
        .set('assets', resolve('src/assets'))
        .set('api', resolve('src/api'))
        .set('views', resolve('src/views'))
        // 上線壓縮圖片 首先要安裝 image-webpack-loader 命令 yarn add image-webpack-loader -D
        config.module.rule('images')
        .use('image-webpack-loader')
        .loader('image-webpack-loader')
        .options({bypassOnDebug:true})
        .end()

        // 注入cdn 
        config.plugin('html').tap(args => {
            // console.log(args)
            //  生產(chǎn)環(huán)境或本地需要cdn時(shí),才注入cdn
            if(isPruction || devNeedCdn) {
                if (isPruction || devNeedCdn) {
                    args[0].cdn = cdn
                } 
            }
            return args
        })
    },

    configureWebpack: config => {
        // 用cdn方式引入,則構(gòu)建時(shí)要忽略相關(guān)資源
        if (isPruction || devNeedCdn) {
            config.externals = cdn.externals
        } 
        if(isPruction) { // 判斷是否是生產(chǎn)環(huán)境
            config.mode = "production";
            // 上線關(guān)閉console和debugger
            // 代碼壓縮
            config.optimization.minimizer = [
                new UglifyJsPlugin({
                    uglifyOptions: {
                        compress: {
                            warnings: false, // 如果打包產(chǎn)生錯(cuò)誤 可注釋掉這里
                            drop_console: true,
                            drop_debugger: true,
                            pure_funcs: ['console.log']
                        }
                    }
                })
            ]
            // 打包文件大小配置
            config["performance"] = {
                "maxEntrypointSize": 10000000, // 此選項(xiàng)根據(jù)入口起點(diǎn)的最大體積,控制 webpack 何時(shí)生成性能提示 單位是(bytes)
                "maxAssetSize": 3000000 // 此選項(xiàng)根據(jù)單個(gè)資源體積,控制 webpack 何時(shí)生成性能提示 單位是(bytes)
            }

            // gzip壓縮
            const productionGzipExtensions = ['html', 'js', 'css']
            config.plugins.push({
                filename:'[path].gz[query]',
                algorithm: 'gzip',
                test: new RegExp( // 進(jìn)行壓縮的文件類(lèi)型
                    '\\.(' + productionGzipExtensions.join('|') + ')$'
                ),
                threshold: 10240, // 定義只有大小大于該值的資源會(huì)被處理
                minRatio: 0.7, // 只有壓縮率小于這個(gè)值的資源被處理
                deleteOriginalAssets: false // 刪除原文件
            })

            // 公共代碼抽離
            config.optimization.splitChunks = {
                cacheGroups: {
                    vendor: {
                        chunks: 'all',
                        test: /node_modules/,
                        name: 'vendor',
                        minChunks: 1,
                        maxInitialRequests: 5,
                        minSize: 0,
                        priority: 100
                    },
                    common: {
                        chunks: 'all',
                        test: /[\\/]src[\\/]js[\\/]/,
                        name: 'common',
                        minChunks: 2,
                        maxInitialRequests: 5,
                        minSize: 0,
                        priority: 60
                    },
                    styles: {
                        name: 'styles',
                        test: /\.(sa|sc|c)ss$/,
                        chunks: 'all',
                        enforce: true
                    },
                    runtimeChunk: {
                        name: 'manifest'
                    }
                }
            }
        } else {
            config.mode = 'development'
        }
    }
}

cdn配置如果添加了那么html文件也要做相應(yīng)的修改,這里是修改后的html文件

	<!DOCTYPE html>
<html lang="">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width,initial-scale=1.0">
    <link rel="icon" href="<%= BASE_URL %>favicon.ico" rel="external nofollow" >
    <!-- 使用CDN的CSS文件 -->
    <% for (var i in htmlWebpackPlugin.options.cdn &&
    htmlWebpackPlugin.options.cdn.css) { %>
    <link
        href="<%= htmlWebpackPlugin.options.cdn.css[i] %>" rel="external nofollow" 
        rel="stylesheet"
    />
    <% } %>
    <title><%= htmlWebpackPlugin.options.title %></title>
  </head>
  <body>
    <noscript>
      <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
    </noscript>
    <div id="app"></div>
    <!-- built files will be auto injected -->
     <!-- 使用CDN的JS文件 -->
     <% for (var i in htmlWebpackPlugin.options.cdn &&
     htmlWebpackPlugin.options.cdn.js) { %>
     <script src="<%= htmlWebpackPlugin.options.cdn.js[i] %>"></script>
     <% } %>
  </body>
</html>

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue 2.X的狀態(tài)管理vuex記錄詳解

    Vue 2.X的狀態(tài)管理vuex記錄詳解

    這篇文章主要介紹了Vue 2.X的狀態(tài)管理vuex記錄的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家的理解和學(xué)習(xí)具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-03-03
  • vue?parseHTML源碼解析hars?end?comment鉤子函數(shù)

    vue?parseHTML源碼解析hars?end?comment鉤子函數(shù)

    這篇文章主要為大家介紹了vue?parseHTML源碼解析hars?end?comment鉤子函數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 前端本地存儲(chǔ)方案localForage在vue3中使用方法

    前端本地存儲(chǔ)方案localForage在vue3中使用方法

    localForage是前端本地存儲(chǔ)的庫(kù),支持多種存儲(chǔ)后端,并提供了一致的API來(lái)存儲(chǔ)和檢索數(shù)據(jù),這篇文章主要給大家介紹了關(guān)于前端本地存儲(chǔ)方案localForage在vue3中使用的相關(guān)資料,需要的朋友可以參考下
    2024-09-09
  • 使用proxy實(shí)現(xiàn)一個(gè)更優(yōu)雅的vue【推薦】

    使用proxy實(shí)現(xiàn)一個(gè)更優(yōu)雅的vue【推薦】

    Proxy 用于修改某些操作的默認(rèn)行為,等同于在語(yǔ)言層面做出修改,所以屬于一種“元編程”。這篇文章主要介紹了用proxy實(shí)現(xiàn)一個(gè)更優(yōu)雅的vue,需要的朋友可以參考下
    2018-06-06
  • vue+springboot實(shí)現(xiàn)圖形驗(yàn)證碼Kaptcha的示例

    vue+springboot實(shí)現(xiàn)圖形驗(yàn)證碼Kaptcha的示例

    圖形驗(yàn)證碼是做網(wǎng)站常用的功能,本文主要介紹了vue+springboot實(shí)現(xiàn)圖形驗(yàn)證碼Kaptcha的示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-11-11
  • vue如何動(dòng)態(tài)加載組件詳解

    vue如何動(dòng)態(tài)加載組件詳解

    組件是Vue.js最強(qiáng)大的功能之一,組件可以擴(kuò)展HTML元素,封裝可重用的代碼,下面這篇文章主要給大家介紹了關(guān)于vue如何動(dòng)態(tài)加載組件的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Vue3.0組件通信mitt源碼ts實(shí)例解析

    Vue3.0組件通信mitt源碼ts實(shí)例解析

    這篇文章主要為大家介紹了Vue3.0組件通信mitt源碼ts實(shí)例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • Vue-Cli如何在index.html中進(jìn)行環(huán)境判斷

    Vue-Cli如何在index.html中進(jìn)行環(huán)境判斷

    這篇文章主要介紹了Vue-Cli如何在index.html中進(jìn)行環(huán)境判斷問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Vue布置導(dǎo)航守衛(wèi)獲取用戶信息

    Vue布置導(dǎo)航守衛(wèi)獲取用戶信息

    這篇文章主要為大家介紹了Vue布置導(dǎo)航守衛(wèi)獲取用戶信息,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • vue計(jì)算屬性和監(jiān)聽(tīng)器實(shí)例解析

    vue計(jì)算屬性和監(jiān)聽(tīng)器實(shí)例解析

    本文通過(guò)基本實(shí)例給大家介紹了vue計(jì)算屬性和監(jiān)聽(tīng)器的相關(guān)知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-05-05

最新評(píng)論