在使用vue搭建项目时,经常由于引入的库太多,导致打包后的文件体积非常大,特别是vendor.js。这就造成页面第一次打开很慢,如果在浏览器中调试页面(打开控制台,禁用缓存),页面打开速度简直是不能忍受的!
下面列了一些常用的方法来减小文件大小,加快页面打开速度。
首先使用webpack-bundle-analyzer分析哪些文件体积比较大
npm install --save-dev webpack-bundle-analyzernpm run analyz
默认会在浏览器中打开 http://127.0.0.1:8888 ,如图
vue懒加载当打包构建应用时,javascript 包会变得非常大,影响页面加载。如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件,这样就更加高效了。
结合 vue 的异步组件和 webpack 的代码分割功能,轻松实现路由组件的懒加载。
1、可以将异步组件定义为返回一个 promise 的工厂函数 (该函数返回的 promise 应该 resolve 组件本身):
const foo = () => promise.resolve({ /* 组件定义对象 */ })
2、在 webpack2 中,我们可以使用动态 import语法来定义代码分块点 (split point):
import('./foo.vue') // 返回 promise
注意:如果您使用的是 babel,你将需要添加 syntax-dynamic-import 插件,才能使 babel 可以正确地解析语法。
结合这两者,这就是如何定义一个能够被 webpack 自动代码分割的异步组件。
const foo = () => import('./foo.vue')
3、在路由配置中什么都不需要改变,只需要像往常一样使用 foo:
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 会将任何一个异步模块与相同的块名称组合到相同的异步块中。
引入压缩后的文件有两种方式来引入:
1、提取不会改动的第三方库,使用cdn替换,在html文件中引入
2、下载第三方库,放到项目的静态文件目录(一般为/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压缩代码等等。
相关推荐:
js如何来导出以及导入excel?js导入导出excel的方法(纯代码)
js中使用template模板引擎实现的一个例子(代码)
vue中响应式数据的简单介绍(图文)
以上就是vue项目中文件大小的优化方法介绍的详细内容。