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

vue項目實現(xiàn)減少app.js和vender.js的體積操作

 更新時間:2020年11月12日 09:28:32   作者:Angrybird233  
這篇文章主要介紹了vue項目實現(xiàn)減少app.js和vender.js的體積操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

配置webpack中externals來減少打包后vendor.js的體積

在日常的項目開發(fā)中,我們會用到各種第三方庫來提高效率,但隨之帶來的問題就是打包后的vendor.js體積過大,導致加載時空白頁時間過長,給用戶的體驗太差。為此我們需要減少vendor.js的體積,從本質上來解決這種問題。

webpack的外部擴展(externals)可以有效的解決。

externals 配置選項提供了「從輸出的 bundle 中排除依賴」的方法。相反,所創(chuàng)建的 bundle 依賴于那些存在于用戶環(huán)境(consumer's environment)中的依賴。防止將某些 import 的包(package)打包到 bundle 中,而是在運行時(runtime)再去從外部獲取這些擴展依賴(external dependencies)。

webpack之externals官方參考文檔傳送門,請戳這里→ externals

下面就以Vue項目為例,介紹一下externals的使用。項目中引用了vue、vue-router、axios、element-ui、qs等第三方庫,那么我們的目標就是把這些從輸出的 bundle 中排除依賴。

1、在/build/webpack.base.conf.js中,配置externals

// externals中的key是后面需要require的名字,value是第三方庫暴露出來的方法名
module.exports = {
 //...
 externals: {
 'vue': 'Vue',
 'vue-router': 'VueRouter',
 'axios': 'axios',
 'element-ui': 'Element',
 'qs': 'Qs'
 }
}

2、在/src/main.js和/src/router/index.js中,移除上面與之相關的import引入,改為require方式引入

// /src/main.js
// 移除
import Vue from 'vue'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import axios from 'axios'
import Qs from 'qs'
Vue.use(ElementUI)
// 添加
const Vue = require('vue')
const ElementUI = require('element-ui')
const axios = require('axios')
const Qs = require('qs')
// /src/router/index.js
// 移除
import Router from 'vue-router'
Vue.use(Router)
// 添加
const Router = require('vue-router')

3、在/index.html中,通過CDN引入相應的js文件和css文件(CDN地址:https://www.bootcdn.cn)

.選用unpkg來作為第三方提供.如我想要axios包則輸入網(wǎng)址為 https://unpkg.com/axios/ (末尾加斜杠代表你要查詢該庫的所有版本列表).然后你可以選擇對應的版本如https://unpkg.com/axios@0.18.0/index.js 。其中 @0.18.0為庫的版本號,若不寫則默認最新版本.

<html>
 <head>
 <meta charset="utf-8">
 <meta name="viewport" content="width=device-width,initial-scale=1.0">
 <link  rel="external nofollow" rel="stylesheet">
 <title>配置webpack中externals來減少打包后vendor.js的體積</title>
 </head>
 <body>
 <div id="app"></div>
 <script src="https://cdn.bootcss.com/vue/2.5.15/vue.min.js"></script>
 <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script>
 <script src="https://cdn.bootcss.com/axios/0.18.0/axios.min.js"></script>
 <script src="https://cdn.bootcss.com/element-ui/2.3.8/index.js"></script>
 <script src="https://cdn.bootcss.com/qs/6.5.2/qs.min.js"></script>
 </body>
</html>

4 代碼打包成壓縮包,瀏覽器支持自動解壓的將會加載壓縮包

在config\index.js中進行修改

productionGzip: true,

//需要下載相應的包 npm install --save-dev compression-webpack-plugin

補充知識:Vue打包之后會出現(xiàn)map文件,體積很大

build命令后占體積最大的竟然是.map文件,webpack如何設置不讓編譯出.map文件呢?

解決辦法:去config/index.js中改一個參數(shù):

productionSourceMap:false

把這個改為false。不然在最終打包的文件中會出現(xiàn)一些map文件

map文件的作用:項目打包后,代碼都是經過壓縮加密的,如果運行時報錯,輸出的錯誤信息無法準確得知是哪里的代碼報錯。

有了map就可以像未加密的代碼一樣,準確的輸出是哪一行哪一列有錯。

以上這篇vue項目實現(xiàn)減少app.js和vender.js的體積操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • element表單使用校驗之校驗失效問題詳解

    element表單使用校驗之校驗失效問題詳解

    最近工作中遇到了element表單校驗失敗的情況,通過查找相關資料終于解決了,所以下面這篇文章主要給大家介紹了關于element表單使用校驗之校驗失效問題的相關資料,需要的朋友可以參考下
    2022-10-10
  • 關于@click.native中?.native?的含義與使用方式

    關于@click.native中?.native?的含義與使用方式

    這篇文章主要介紹了關于@click.native中?.native?的含義與使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 解決vue一個頁面中復用同一個echarts組件的問題

    解決vue一個頁面中復用同一個echarts組件的問題

    這篇文章主要介紹了解決vue一個頁面中復用同一個echarts組件的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • 自定義Vue組件打包、發(fā)布到npm及使用教程

    自定義Vue組件打包、發(fā)布到npm及使用教程

    這篇文章主要介紹了自定義Vue組件打包、發(fā)布到npm及使用教程 ,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • vue3使用mqtt的示例代碼

    vue3使用mqtt的示例代碼

    這篇文章主要介紹了vue3使用mqtt的實例代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • Vue中watch監(jiān)聽首次不生效的解決辦法

    Vue中watch監(jiān)聽首次不生效的解決辦法

    在 Vue 中,watch 屬性用于觀察和響應 Vue 實例上數(shù)據(jù)的變動,然而,默認情況下,watch 確實不會觸發(fā)組件創(chuàng)建時的變動,這里有幾種方式可以處理或繞過這個問題,需要的朋友可以參考下
    2024-09-09
  • vue 設置 input 為不可以編輯的實現(xiàn)方法

    vue 設置 input 為不可以編輯的實現(xiàn)方法

    今天小編就為大家分享一篇vue 設置 input 為不可以編輯的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • Vue3+Spring Framework框架開發(fā)實戰(zhàn)

    Vue3+Spring Framework框架開發(fā)實戰(zhàn)

    這篇文章主要為大家介紹了Vue3+Spring Framework框架開發(fā)實戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • vue通過路由實現(xiàn)頁面刷新的方法

    vue通過路由實現(xiàn)頁面刷新的方法

    本篇文章主要介紹了vue通過路由實現(xiàn)頁面刷新的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • vue?proxytable代理根路徑的同時增加其他代理方式

    vue?proxytable代理根路徑的同時增加其他代理方式

    這篇文章主要介紹了vue?proxytable代理根路徑的同時增加其他代理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評論