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

Vue項目中打包優(yōu)化的四種方法詳解

 更新時間:2022年07月18日 09:16:28   作者:smouns_  
最近入職了新公司,接手了一個新拆分出來的Vue項目,針對該項目做了個打包優(yōu)化,下面這篇文章主要給大家介紹了關(guān)于Vue項目中打包優(yōu)化的四種方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

前言

默認情況下,通過import語法導(dǎo)入的第三方依賴包,最終會全部打包到一個js文件中,會導(dǎo)致單文件體積過大大,在網(wǎng)速底下時會阻塞網(wǎng)頁加載,影響用戶體驗。

打包優(yōu)化的目的:

1、項目啟動速度,和性能

2、必要的清理數(shù)據(jù)

3、減少打包后的體積

第一點是核心,第二點呢其實主要是清理console

性能優(yōu)化的主要方向:

路由懶加載

去除生產(chǎn)版console.log的打印輸出

開發(fā)版使用依賴項,生產(chǎn)版使用在線CDN

項目打包及配置

1.異步組件配置(路由懶加載)

一上來加載所有的組件, 首屏加載就比較慢, 可以配置路由按需加載

當(dāng)打包構(gòu)建項目時,js包會變得非常大,影響頁面加載,我們把不同路由的對應(yīng)組件分割成不同的代碼塊,然后當(dāng)路由被訪問的時候加載對應(yīng)的組件,這樣能提升訪問效率。

切分之后,并不是瀏覽器訪問某個路由,才去下載對應(yīng)的模塊,仍然在首次訪問程序時,下載所有模塊,只不過每個模塊分的很小,加載首頁時需要的模塊能夠更快的下載下來,所以能夠更快的顯示

具體分三步:

  • 安裝包  npm install --save-dev @babel/plugin-syntax-dynamic-impor
  • 在babel.config.js配置文件中加入插件
  • 將路由改為按需加載的形式
import Vue from 'vue'
import VueRouter from 'vue-router'
 
Vue.use(VueRouter)
 
const routes = [
  {
    path: '/Login',
    name: 'Login',
    // 路由懶加載
    component: () => import('../views/Login/index.vue')
  },
  {
    path: '/',
    component: () => import('../views/layout/index.vue'),
    children: [
      {
        path: '',
        component: () => import('../views/Home/index.vue')
      }
    ]
  }
]
 
//或者如下
 
const Login = () => import('@/views/Login')
const Reg = () => import('@/views/Reg')
const Layout = () => import('@/views/Layout')

2.去掉打包后的 console

打包上線后的console語句沒有任何作用,所以我們應(yīng)該移除它,除去手動移除,還可以使用插件的方式來移除代碼里的console語句。

  安裝依賴 : yarn add terser-webpack-plugin -D (npm i terser-webpack-plugin -D)

在vue.config.js修改配置文件

// 獲取當(dāng)前的打包環(huán)境(具體文章最后會說明)
const env = process.env.NODE_ENV
// 覆蓋默認的webpack配置
module.exports = {
  publicPath: './',  //首次加載白屏(打包后文件路徑問題)
  devServer: {
    port: 3000,
    open: true
  },
  chainWebpack: (config) => {
    config.optimization.minimizer('terser').tap((args) => {
      args[0].terserOptions.compress.drop_console = true
      return args
    })
  } 
}

3.使用CDN

使用CDN,減少包的體積。 將線上環(huán)境中用到的一些依賴,使用CDN網(wǎng)絡(luò)節(jié)點的方式進行引用,而不是直接打包到包里。

項目開發(fā)階段和生產(chǎn)階段不一樣,我們在開發(fā)階段還是要使用import導(dǎo)入依賴的方式來進行開發(fā),在生產(chǎn)階段再配置CDN外鏈來獲取項目依賴。

默認情況下,Vue項目的開發(fā)模式和發(fā)布模式,共同使用一個打包的入口文件(src/main.js)為了將項目的開發(fā)過程與發(fā)布過程分離,我們可以分別使用兩個入口文件,一個用于開發(fā)環(huán)境打包(這個就是main.js),一個用于生產(chǎn)環(huán)境打包

在vue.config.js中

// 是否為生產(chǎn)環(huán)境
const isProduction = process.env.NODE_ENV !== 'development';
 
// 本地環(huán)境是否需要使用cdn
const devNeedCdn = false
 
// cdn鏈接
const cdn = {
    // cdn:模塊名稱和模塊作用域命名(對應(yīng)window里面掛載的變量名稱)
    externals: {
        vue: 'Vue',
        vuex: 'Vuex',
        'vue-router': 'VueRouter',
        'marked': 'marked',
        'highlight.js': 'hljs',
        'nprogress': 'NProgress',
        'axios': 'axios'
    },
    // cdn的css鏈接
    css: [
        
    ],
    // cdn的js鏈接
    js: [
        'https://cdn.bootcss.com/vue/2.6.10/vue.min.js',
        'https://cdn.bootcss.com/vuex/3.1.2/vuex.min.js',
        'https://cdn.bootcss.com/vue-router/3.1.3/vue-router.min.js',
        'https://cdn.bootcss.com/axios/0.19.2/axios.min.js'
    ]
}
 
module.exports = {
    chainWebpack: config => {
        // ============注入cdn start============
        config.plugin('html').tap(args => {
            // 生產(chǎn)環(huán)境或本地需要cdn時,才注入cdn
            if (isProduction || devNeedCdn) args[0].cdn = cdn
            return args
        })
        // ============注入cdn start============
    },
    configureWebpack: config => {
        // 用cdn方式引入,則構(gòu)建時要忽略相關(guān)資源
        if (isProduction || devNeedCdn) config.externals = cdn.externals
    }
}
 <!-- 使用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"
  />
  <% } %>
  <!-- 使用CDN的CSS文件 -->
 
 
  <!-- 使用CDN的JS文件 -->
 <% for (var i in htmlWebpackPlugin.options.cdn &&
  htmlWebpackPlugin.options.cdn.js) { %>
  <script src="<%= htmlWebpackPlugin.options.cdn.js[i] %>"></script>
  <% } %>
  <!-- 使用CDN的JS文件 -->

4.yarn build生成dist目錄

得到一個dist目錄,這個目錄包含了項目中所有的頁面,樣式,業(yè)務(wù), 第三方包, 默認html文件中引入了資源文件是以項目根目錄引入的, 雙擊目前是打開不了的 可以 借助vscode中的live-sever

打包的過程中, 會對代碼進行壓縮合并, 版本降級, 語法轉(zhuǎn)換等...

module.exports = {
  publicPath: './',  //解決路徑問題
  devServer: {
    port: 3000,   //改變端口號
    open: true    //運行后,自動打開瀏覽器運行
  }
}

總結(jié)

到此這篇關(guān)于Vue項目中打包優(yōu)化的四種方法的文章就介紹到這了,更多相關(guān)Vue項目打包優(yōu)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決vue刷新頁面以后丟失store的數(shù)據(jù)問題

    解決vue刷新頁面以后丟失store的數(shù)據(jù)問題

    這篇文章主要介紹了解決vue刷新頁面以后丟失store的數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue Router常用屬性詳解

    vue Router常用屬性詳解

    這篇文章主要介紹了vueRouter常用屬性,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • vue 中自定義指令改變data中的值

    vue 中自定義指令改變data中的值

    這篇文章主要介紹了vue 中自定義指令改變data中的值,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-06-06
  • Vue模板內(nèi)引入的組件樣式覆蓋失效原因及解決

    Vue模板內(nèi)引入的組件樣式覆蓋失效原因及解決

    這篇文章主要介紹了Vue模板內(nèi)引入的組件樣式覆蓋失效原因及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue中element-ui使用axios上傳文件

    vue中element-ui使用axios上傳文件

    這篇文章主要為大家詳細介紹了vue中element-ui使用axios上傳文件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • vite+vue3中require?is?not?defined問題及解決

    vite+vue3中require?is?not?defined問題及解決

    這篇文章主要介紹了vite+vue3中require?is?not?defined問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue3中的createApp分析

    vue3中的createApp分析

    這篇文章主要介紹了vue3中的createApp分析,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • element-plus+Vue3實現(xiàn)表格數(shù)據(jù)動態(tài)渲染

    element-plus+Vue3實現(xiàn)表格數(shù)據(jù)動態(tài)渲染

    在Vue中,el-table是element-ui提供的強大表格組件,可以用于展示靜態(tài)和動態(tài)表格數(shù)據(jù),本文主要介紹了element-plus+Vue3實現(xiàn)表格數(shù)據(jù)動態(tài)渲染,感興趣的可以了解一下
    2024-03-03
  • 解決vue 使用setTimeout,離開當(dāng)前路由setTimeout未銷毀的問題

    解決vue 使用setTimeout,離開當(dāng)前路由setTimeout未銷毀的問題

    這篇文章主要介紹了解決vue 使用setTimeout,離開當(dāng)前路由setTimeout未銷毀的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue移動端使用canvas簽名的實現(xiàn)

    vue移動端使用canvas簽名的實現(xiàn)

    這篇文章主要介紹了vue移動端使用canvas簽名的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01

最新評論