vue項(xiàng)目實(shí)現(xiàn)減少app.js和vender.js的體積操作
配置webpack中externals來減少打包后vendor.js的體積
在日常的項(xiàng)目開發(fā)中,我們會(huì)用到各種第三方庫來提高效率,但隨之帶來的問題就是打包后的vendor.js體積過大,導(dǎo)致加載時(shí)空白頁時(shí)間過長,給用戶的體驗(yàn)太差。為此我們需要減少vendor.js的體積,從本質(zhì)上來解決這種問題。
webpack的外部擴(kuò)展(externals)可以有效的解決。
externals 配置選項(xiàng)提供了「從輸出的 bundle 中排除依賴」的方法。相反,所創(chuàng)建的 bundle 依賴于那些存在于用戶環(huán)境(consumer's environment)中的依賴。防止將某些 import 的包(package)打包到 bundle 中,而是在運(yùn)行時(shí)(runtime)再去從外部獲取這些擴(kuò)展依賴(external dependencies)。
webpack之externals官方參考文檔傳送門,請戳這里→ externals
下面就以Vue項(xiàng)目為例,介紹一下externals的使用。項(xiàng)目中引用了vue、vue-router、axios、element-ui、qs等第三方庫,那么我們的目標(biāo)就是把這些從輸出的 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中,移除上面與之相關(guān)的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引入相應(yīng)的js文件和css文件(CDN地址:https://www.bootcdn.cn)
.選用unpkg來作為第三方提供.如我想要axios包則輸入網(wǎng)址為 https://unpkg.com/axios/ (末尾加斜杠代表你要查詢該庫的所有版本列表).然后你可以選擇對應(yīng)的版本如https://unpkg.com/axios@0.18.0/index.js 。其中 @0.18.0為庫的版本號(hào),若不寫則默認(rèn)最新版本.
<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 代碼打包成壓縮包,瀏覽器支持自動(dòng)解壓的將會(huì)加載壓縮包
在config\index.js中進(jìn)行修改
productionGzip: true,
//需要下載相應(yīng)的包 npm install --save-dev compression-webpack-plugin
補(bǔ)充知識(shí):Vue打包之后會(huì)出現(xiàn)map文件,體積很大
build命令后占體積最大的竟然是.map文件,webpack如何設(shè)置不讓編譯出.map文件呢?
解決辦法:去config/index.js中改一個(gè)參數(shù):
productionSourceMap:false
把這個(gè)改為false。不然在最終打包的文件中會(huì)出現(xiàn)一些map文件
map文件的作用:項(xiàng)目打包后,代碼都是經(jīng)過壓縮加密的,如果運(yùn)行時(shí)報(bào)錯(cuò),輸出的錯(cuò)誤信息無法準(zhǔn)確得知是哪里的代碼報(bào)錯(cuò)。
有了map就可以像未加密的代碼一樣,準(zhǔn)確的輸出是哪一行哪一列有錯(cuò)。
以上這篇vue項(xiàng)目實(shí)現(xiàn)減少app.js和vender.js的體積操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue解析剪切板圖片并實(shí)現(xiàn)發(fā)送功能
這篇文章主要介紹了Vue解析剪切板圖片并實(shí)現(xiàn)發(fā)送功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02
利用Vue實(shí)現(xiàn)移動(dòng)端圖片輪播組件的方法實(shí)例
輪播圖是前端很常用的一個(gè)網(wǎng)頁特效,幾乎所有的網(wǎng)站或多或少都會(huì)用到這個(gè)特效。下面這篇文章主要給大家介紹了關(guān)于利用Vue實(shí)現(xiàn)移動(dòng)端圖片輪播組件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。2017-08-08
vue項(xiàng)目打包之后接口出現(xiàn)錯(cuò)誤的問題及解決
這篇文章主要介紹了vue項(xiàng)目打包之后接口出現(xiàn)錯(cuò)誤的問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
Vue Transition實(shí)現(xiàn)類原生組件跳轉(zhuǎn)過渡動(dòng)畫的示例
本篇文章主要介紹了Vue Transition實(shí)現(xiàn)類原生組件跳轉(zhuǎn)過渡動(dòng)畫的示例,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08
適用于 Vue 的播放器組件Vue-Video-Player操作
這篇文章主要介紹了適用于 Vue 的播放器組件Vue-Video-Player操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
vue引入微信sdk 實(shí)現(xiàn)分享朋友圈獲取地理位置功能
這篇文章主要介紹了h5 vue引入微信sdk 實(shí)現(xiàn)分享朋友圈,分享給朋友,獲取地理位置功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07

