优化Vue项目的文件大小

  在使用Vue搭建项目时,常常因为引入的库太多,致使打包后的文件体积很是大,特别是vendor.js。这就形成页面第一次打开很慢,若是在浏览器中调试页面(打开控制台,禁用缓存),页面打开速度简直是不能忍受的!
下面列了一些经常使用的方法来减少文件大小,加快页面打开速度。css

首先使用webpack-bundle-analyzer分析哪些文件体积比较大html

npm install --save-dev webpack-bundle-analyzer
npm run analyz

默认会在浏览器中打开 http://127.0.0.1:8888 ,如图
vue

Vue懒加载

当打包构建应用时,Javascript 包会变得很是大,影响页面加载。若是咱们能把不一样路由对应的组件分割成不一样的代码块,而后当路由被访问的时候才加载对应组件,这样就更加高效了。
结合 Vue 的异步组件和 Webpack 的代码分割功能,轻松实现路由组件的懒加载。jquery

一、能够将异步组件定义为返回一个 Promise 的工厂函数 (该函数返回的 Promise 应该 resolve 组件自己):webpack

const Foo = () => Promise.resolve({ /* 组件定义对象 */ })

二、在 Webpack2 中,咱们可使用动态 import语法来定义代码分块点 (split point):web

import('./Foo.vue') // 返回 Promise

注意:若是您使用的是 Babel,你将须要添加 syntax-dynamic-import 插件,才能使 Babel 能够正确地解析语法。npm

结合这二者,这就是如何定义一个可以被 Webpack 自动代码分割的异步组件。element-ui

const Foo = () => import('./Foo.vue')

三、在路由配置中什么都不须要改变,只须要像往常同样使用 Foo:segmentfault

const router = new VueRouter({
  routes: [
    { path: '/foo', component: Foo }
  ]
})

把组件按组分块
有时候咱们想把某个路由下的全部组件都打包在同个异步块 (chunk) 中。只须要使用命名chunk,一个特殊的注释语法来提供chunk name (须要 Webpack > 2.4)。浏览器

const Foo = () => import(/* webpackChunkName: "group-foo" */ './Foo.vue')
const Bar = () => import(/* webpackChunkName: "group-foo" */ './Bar.vue')
const Baz = () => import(/* webpackChunkName: "group-foo" */ './Baz.vue')

Webpack 会将任何一个异步模块与相同的块名称组合到相同的异步块中。

引入压缩后的文件

有两种方式来引入:
一、提取不会改动的第三方库,使用CDN替换,在html文件中引入
二、下载第三方库,放到项目的静态文件目录(通常为/static),而后在main.js中引入

import '../static/element-ui/index.css'
import * as ElementUI from '../static/element-ui/index'
import 'font-awesome/css/font-awesome.min.css'

Vue.use(ElementUI)
Vue.use(VueRouter)

优化屡次引入的文件

若是再多个页面中引入了相同的文件,那么打包时会把改文件打包两次,分别对应到各页面文件中。
好比在多个页面中都引入了jquery, import $ from 'jquery' ,那么能够在main.js中引入一次,而后就能够直接在别的页面中使用 $ 变量了

使用模块化引入

对于Element UI或者loadsh这样的项目,一次引入的话,文件会很大,对于一些使用不到的模块,能够按需引入,例如:

import { debounce } from 'lodash'
import { throttle } from 'lodash'

// 改为以下写法

import debounce from 'lodash/debounce'
import throttle from 'lodash/throttle'

其它方法

优化文件大小还有不少方法,好比使用Gzip压缩文件,使用UglifyJS压缩代码等等。

更多优化方法能够参考:
https://jeffjade.com/2017/08/...
https://jeffjade.com/2017/08/...



欢迎订阅「K叔区块链」 - 专一于区块链技术学习

博客地址: http://www.jouypub.com
简书主页: https://www.jianshu.com/u/756c9c8ae984
segmentfault主页: https://segmentfault.com/blog/jouypub
腾讯云主页: https://cloud.tencent.com/developer/column/72548
相关文章
相关标签/搜索