Vue項目打包編譯優(yōu)化方案
1. 不生成.map文件
默認(rèn)情況下,當(dāng)我們執(zhí)行 npm run build
命令打包完一個項目后,會得到一個dist目錄,里面有一個js目錄,存放了該項目編譯后的所有js文件。
我們發(fā)現(xiàn)每個js文件都有一個相應(yīng)的 .map 文件,它們僅是用來調(diào)試代碼的,可以加快打包速度,但會增大打包體積,線上我們是不需要這個代碼的。這里我們需要配置不生成map文件。
- vue-cli2
config/index.js文件中,找到 productionSourceMap: true 這一行,將 true 改為 false。
- vue-cli3
在 vue.config.js 中編寫以下內(nèi)容:
module.exports = { productionSourceMap: false }
2. 按需引入第三方包
默認(rèn)情況下,在打包完后的js文件中,vendor.xxx.js 這個文件是非常大的,它主要是我們用到的第三方包(vue、vue-router、vuex、axios、element-ui等等)。這里面的大部分是我們要用到的功能,而像 element-ui 這種,明顯可以按塊來分,我們只是用到了里面的個別組件,完全可以把它按需取出,沒必要全部打包。
在 element-ui 的官網(wǎng),介紹了按需引入的方法,借助 babel-plugin-component,我們可以只引入需要的組件,以達(dá)到減小項目體積的目的。
3. 路由懶加載
默認(rèn)情況下,在打包完后的js文件中,app.xxx.js 這個文件是非常大的,它主要是我們編寫的一些組件。那么無法避免的問題就是:當(dāng)用戶訪問網(wǎng)頁的時候,第一次的請求要加載整個 app.xxx.js,當(dāng)我們的項目比較復(fù)雜的時候,這個文件也是相當(dāng)大的。
接下來我們要做的,就是路由懶加載。也就是當(dāng)訪問一個頁面的時候,只加載當(dāng)前組件相關(guān)的js資源,訪問其它頁面的時候,再加載相應(yīng)的組件代碼。
通過vue提供的路由懶加載功能,我們能將原來的一個 app.xxx.js 文件,分塊分成多個。
?、?首先根據(jù)官網(wǎng)的說明,我們需要安裝一個插件
npm install --save-dev @babel/plugin-syntax-dynamic-import
?、?然后在 babel.config.js 中配置如下內(nèi)容(網(wǎng)上說的是 .babelrc 文件,這是以前的配置格式):
module.exports = { presets: ["@vue/app"], plugins: ["@babel/plugin-syntax-dynamic-import"] };
?、?接下來修改路由加載組件部分的代碼。
這是我們原來的路由寫法:
router.js
import Vue from "vue"; import Router from "vue-router"; import Home from "./views/Home.vue"; import About from "./views/About.vue"; import Form from "./views/Form.vue"; import Table from "./views/Table.vue"; import NavMenu from "./views/NavMenu.vue"; Vue.use(Router); export default new Router({ mode: "history", base: process.env.BASE_URL, routes: [ { path: "/", name: "home", component: Home }, { path: "/about", name: "about", component: About }, { path: "/form", name: "myForm", component: Form }, { path: "/table", name: "myTable", component: Table }, { path: "/nav_menu", name: "myNavMenu", component: NavMenu } ] });
這是我們修改完的路由寫法:
router.js
import Vue from "vue"; import Router from "vue-router"; const Home = () => import("./views/Home.vue"); const About = () => import("./views/About.vue"); const Form = () => import("./views/Form.vue"); const Table = () => import("./views/Table.vue"); const NavMenu = () => import("./views/NavMenu.vue"); Vue.use(Router); export default new Router({ mode: "history", base: process.env.BASE_URL, routes: [ { path: "/", name: "home", component: Home }, { path: "/about", name: "about", component: About }, { path: "/form", name: "myForm", component: Form }, { path: "/table", name: "myTable", component: Table }, { path: "/nav_menu", name: "myNavMenu", component: NavMenu } ] });
更細(xì)節(jié)的內(nèi)容參見官方文檔
以上就是Vue項目打包編譯優(yōu)化方案的詳細(xì)內(nèi)容,更多關(guān)于vue項目打包優(yōu)化的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue中el-tree樹全部展開或收起的實現(xiàn)示例
本文主要介紹了Vue中el-tree樹全部展開或收起的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07vue全局引入公共的scss和@mixin與@include的使用方式
這篇文章主要介紹了vue全局引入公共的scss和@mixin與@include的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02vue router下的html5 history在iis服務(wù)器上的設(shè)置方法
這篇文章主要介紹了vue router下的html5 history在iis服務(wù)器上的設(shè)置方法,需要的朋友參考下吧2017-10-10Vue組件庫ElementUI實現(xiàn)表格加載樹形數(shù)據(jù)教程
這篇文章主要為大家詳細(xì)介紹了Vue組件庫ElementUI實現(xiàn)表格加載樹形數(shù)據(jù)教程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-06-06詳解本地Vue項目請求本地Node.js服務(wù)器的配置方法
本文只針對自己需要本地模擬接口于是搭建一個本地node服務(wù)器供自己測試使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-03-03