<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        vue-cli3.0如何使用CDN區分開發、生產、預發布環境

        來源:懂視網 責編:小采 時間:2020-11-27 22:03:36
        文檔

        vue-cli3.0如何使用CDN區分開發、生產、預發布環境

        vue-cli3.0如何使用CDN區分開發、生產、預發布環境:前言:上一篇記錄文vue-cli 3.0 build包太大導致首屏過長的解決方案中提到了CDN優化,之前是直接在html中手動注入JS,也沒有對開發和生產模式進行區分,因為是使用收費的CDN,所以在開發模式會遇到無權使用CDN的問題。要是使用CDN寫死在html中,不同環
        推薦度:
        導讀vue-cli3.0如何使用CDN區分開發、生產、預發布環境:前言:上一篇記錄文vue-cli 3.0 build包太大導致首屏過長的解決方案中提到了CDN優化,之前是直接在html中手動注入JS,也沒有對開發和生產模式進行區分,因為是使用收費的CDN,所以在開發模式會遇到無權使用CDN的問題。要是使用CDN寫死在html中,不同環

        前言:上一篇記錄文vue-cli 3.0 build包太大導致首屏過長的解決方案中提到了CDN優化,之前是直接在html中手動注入JS,也沒有對開發和生產模式進行區分,因為是使用收費的CDN,所以在開發模式會遇到無權使用CDN的問題。要是使用CDN寫死在html中,不同環境需要手動的切換CDN,那么早晚有一天會搞亂,下面就說說怎么在vue-cli 3.0 中根據不同環境動態注入CDN。

        1. 修改public/index.html

        通過htmlwebpackplugin動態注入腳本和樣式,index.html如下:

        <!DOCTYPE html>
        <html lang="en">
         <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" >
         <title>杭州納舍科技</title>
         <!-- 使用CDN的CSS文件 -->
         <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.css) { %>
         <link href="<%= htmlWebpackPlugin.options.cdn.css[i] %>" rel="external nofollow" rel="external nofollow" rel="preload" as="style">
         <link href="<%= htmlWebpackPlugin.options.cdn.css[i] %>" rel="external nofollow" rel="external nofollow" rel="stylesheet">
         <% } %>
         <!-- 使用CDN的JS文件 -->
         <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.js) { %>
         <link href="<%= htmlWebpackPlugin.options.cdn.js[i] %>" rel="external nofollow" rel="preload" as="script">
         <% } %>
         </head>
         <body>
         <noscript>
         <strong>We're sorry but ui doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
         </noscript>
         <div class="global-loading">
         <div class="spinner"></div>
         </div>
         <div id="app"></div>
         <!-- built files will be auto injected -->
         <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.js) { %>
         <script src="<%= htmlWebpackPlugin.options.cdn.js[i] %>"></script>
         <% } %>
         </body>
        </html>

        2. 修改vue.config.js配置

        首先我們會考慮哪些東西要進行CDN優化,例如我們需要把vue、vue-router、moment在構建的時候排除在外使用CDN加載這三個庫,那么需要把添加externals

        const isProduction = process.env.NODE_ENV === 'production';
        module.exports = {
         configureWebpack: config => {
         if (isProduction) {
         config.externals = {
         'vue': 'Vue',
         'vue-router': 'VueRouter',
         'moment': 'moment'
         }
         }
         }
        }
        

        現在我們運行npm run build 打包出來的文件就沒有Vue、VueRouter、moment,現在我們使用html-webpack-plugin插件進行動態注入CDN,在vue-cli 3.0 中我們要這樣配置:

        const isProduction = process.env.NODE_ENV === 'production';
        const cdn = {
         css: ['xxx.css', 'sss.js'],
         js: ['xxxx.js', 'sss.js']
        }
        module.exports = {
         configureWebpack: config => {
         if (isProduction) {
         config.externals = {
         'vue': 'Vue',
         'vue-router': 'VueRouter',
         'moment': 'moment'
         }
         }
         }
         chainWebpack: config => {
         if (isProduction) {
         config.plugin('html')
         .tap(args => {
         args[0].cdn = cdn;
         return args;
         })
         }
         }
        }
        

        到目前為止已經解決了開發模式不使用CDN,生產模式使用CDN的問題和動態在html中注入CDN的問題。

        可能你會遇到和我一樣的問題

        預發布build測試,但無權使用生產上的CDN問題,那么我們必須再添加一個環境變量來區分預發布build的模式。(vue-cli 3.0 環境變量文檔)這里我添加一個IS_LOCAL_BUILD,首先我們在vue.cofnig.js同路徑下創建一個.en.production.local :

        // .en.production.local` 內容:
        IS_LOCAL_BUILD = 'isLocalBuild'

        修改vue.config.js如下:

        const isProduction = process.env.NODE_ENV === 'production';
        const isLocalBuild = process.env.IS_LOCAL_BUILD === 'isLocalBuild';
        const JS_CDN = isLocalBuild ? [
         預發布CDN(例如那些免費的CDN)
        ] : [
         生產環CDN
        ];
        const CSS_CDN = isLocalBuild ? [預發布CDN]: [生產CDN]
        const cdn = {
         css: CSS_CDN,
         js: JS_CDN
        }
        module.exports = {
         configureWebpack: config => {
         if (isProduction) {
         config.externals = {
         'vue': 'Vue',
         'vue-router': 'VueRouter',
         'moment': 'moment'
         }
         }
         }
         chainWebpack: config => {
         if (isProduction) {
         config.plugin('html')
         .tap(args => {
         args[0].cdn = cdn;
         return args;
         })
         }
         }
        }
        

        ok,上面區分了生產、預發布和開發環境使用CDN的問題,這樣就不用根據不同環境手動去修改CDN了。不過又一點要注意:⚠️預發布版本的構建才需要添加.en.production.local。

        完整的vue.config.js(供參考)

        const path = require('path');
        const CompressionWebpackPlugin = require('compression-webpack-plugin');
        const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
        const productionGzipExtensions = ['js', 'css'];
        const isProduction = process.env.NODE_ENV === 'production';
        
        function resolve(dir) {
         return path.join(__dirname, dir);
        }
        
        // 預發布環境
        const isLocalBuild = process.env.IS_LOCAL_BUILD === 'isLocalBuild';
        console.log('前端文件預發布打包- isLocalBuild:', isLocalBuild);
        
        // 非externals CND前綴設置
        const CDN_URL = isLocalBuild ? '/' : '//s.zypj.nasetech.com/';
        
        // 區分生產環境打包和預發布打包,使用不同的CDN
        const JS_CDN = isLocalBuild ? [
         // 預發布CDN
        ] : [
         // 生產CDN
        ];
        
        const cdn = {
         // css: [],
         js: JS_CDN
        }
        
        module.exports = {
         lintOnSave: true,
         baseUrl: isProduction ? CDN_URL : '/',
         chainWebpack: (config) => {
         // build打包才使用CDN
         if (isProduction) {
         config.plugin('html')
         .tap(args => {
         args[0].cdn = cdn;
         return args;
         })
         }
        
         config.resolve.alias
         .set('assets', resolve('src/assets'))
         .set('pages', resolve('src/pages'))
         .set('components', resolve('src/components'))
         .set('utils', resolve('src/utils'))
         },
         devServer: {
         host: '0.0.0.0',
         port: 8080,
         https: false,
         hotOnly: false,
         disableHostCheck: false,
         proxy: {
         '/api/v0/': {
         // 目標 API 地址
         target: 'http://127.0.0.1:4545',
         // 將主機標頭的原點更改為目標URL
         changeOrigin: true,
         },
         },
         },
         configureWebpack: config => {
         // 生產模式
         if (isProduction) {
         config.externals = {
         'vue': 'Vue',
         'vue-router': 'VueRouter',
         'moment': 'moment'
         }
         // 打包生產.gz包
         config.plugins.push(new CompressionWebpackPlugin({
         algorithm: 'gzip',
         test: new RegExp('\\.(' + productionGzipExtensions.join('|') + ')$'),
         threshold: 10240,
         minRatio: 0.8
         }))
         // 添加自定義代碼壓縮配置
         config.plugins.push(
         new UglifyJsPlugin({
         uglifyOptions: {
         compress: {
         warnings: false,
         drop_debugger: true,
         drop_console: true,
         },
         },
         sourceMap: false,
         parallel: true,
         })
         )
         }
         }
        }

        * 使用CDN一些有意思的坑:

        使用CDN還會遇到一些有意思的事,例如使用beta版的vue導致element UI庫有些組件無法正常工作; 使用免費的CDN上線沒有多久就GG不能用等悲慘故事!!!

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        vue-cli3.0如何使用CDN區分開發、生產、預發布環境

        vue-cli3.0如何使用CDN區分開發、生產、預發布環境:前言:上一篇記錄文vue-cli 3.0 build包太大導致首屏過長的解決方案中提到了CDN優化,之前是直接在html中手動注入JS,也沒有對開發和生產模式進行區分,因為是使用收費的CDN,所以在開發模式會遇到無權使用CDN的問題。要是使用CDN寫死在html中,不同環
        推薦度:
        標簽: 區分 VUE 生產
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 99无码人妻一区二区三区免费| 免费人成激情视频在线观看冫| 亚洲精品动漫免费二区| 亚洲国产精品成人精品小说 | 亚洲成AV人片在线观看无码| www免费插插视频| 国产AⅤ无码专区亚洲AV| 中文精品人人永久免费| 亚洲av网址在线观看| 一个人免费日韩不卡视频| 久久久久久久亚洲Av无码 | 欧洲美女大片免费播放器视频| 亚洲黄黄黄网站在线观看| 久久av免费天堂小草播放| 亚洲AV成人无码久久精品老人| 2021国内精品久久久久精免费| 亚洲人成77777在线播放网站不卡| 日韩一区二区免费视频| 无码的免费不卡毛片视频| 国产亚洲精品无码成人| 成人午夜免费福利视频| 校园亚洲春色另类小说合集| 亚洲伊人成无码综合网 | 高清在线亚洲精品国产二区| 中文字幕手机在线免费看电影| 亚洲黄色免费网站| 欧洲美熟女乱又伦免费视频| 无码AV动漫精品一区二区免费| 亚洲电影国产一区| 国外成人免费高清激情视频| 久久久久久久久久免免费精品| 久久久亚洲欧洲日产国码是AV| 全免费A级毛片免费看网站| 久久久精品国产亚洲成人满18免费网站 | 一区二区三区在线观看免费| 亚洲高清国产拍精品26U| 女人18毛片水最多免费观看 | 最近中文字幕无吗免费高清 | 2021在线观看视频精品免费| 国产精品亚洲精品久久精品| 久久亚洲精品无码|