vue-cli 首屏加载优化问题
程序员文章站
2022-06-20 08:12:06
使用 vue-cli构建的项目,在 默认情况下 ,执行 npm run build 会将所有的js代码打包为一个整体,
打包位置是 dist/static/j...
使用 vue-cli构建的项目,在 默认情况下 ,执行 npm run build
会将所有的js代码打包为一个整体,
打包位置是 dist/static/js/app.[contenthash].js
类似下面的路由代码
router/index.js 路由相关信息,该路由文件引入了多个 .vue组件 import personal from '@/components/page/personal' import message from '@/components/personnal/message' import settings from '@/components/personnal/settings' import setlanguage from '@/components/personnal/children/setlanguage'
npm run build
会打包成一个app.[contenthash].js
,这个文件会非常大,影响加载速度。
所以我们需要分模块打包,把我们想要组合在一起的组件打包到一个 chunk块中去
分模块打包需要下面这样使用 webpack的 require.ensure
,并且在最后加入一个 chunk名,
相同 chunk名字的模块将会打包到一起。
const personal = r=>require.ensure([],()=>r(require('@/components/page/personal')),'personal'); const message = r=>require.ensure([],()=>r(require('@/components/personnal/message')),'personal'); const settings = r=>require.ensure([],()=>r(require('@/components/personnal/settings')),'personal'); const setlanguage = r=>require.ensure([],()=>r(require('@/components/personnal/children/setlanguage')),'personal');
根据 chunname的不同, 上面的四个组件, 将会被分成3个块打包,最终打包之后与组件相关的js文件会分为3个 (除了app.js,manifest.js, vendor.js)
总结
以上所述是小编给大家介绍的vue-cli 首屏加载优化问题,希望对大家有所帮助