怎么优化vue-cli2的构建速度?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。
一、动态路由
1、修改 src/router/index.js
import Vue from 'vue'
import Router from 'vue-router'
// webpackChunkName 打包后的文件名
const Menu = () => import(/* webpackChunkName: 'Menu' */ '@/pages/menu/index.vue')
export default new Router({
routes: [
{
path: '/',
name: 'Menu',
component: Menu
}
]
})
2、配置 .babelrc(可选)
{
...
"comments": true, // 输出编译信息
"plugins": ["transform-vue-jsx", "transform-runtime"]
}
3、修改 build/webpack.prod.conf.js
output: {
path: config.build.assetsRoot,
filename: utils.assetsPath('js/[name].[chunkhash].js'),
chunkFilename: utils.assetsPath('js/[name].js') // 使用webpackChunkName定义的文件名
},
二、启用 uglifyjs-webpack-plugin 缓存
new UglifyJsPlugin({
parallel: true, // 并行
cache: true // 缓存
}),
三、关闭 source-map
修改 src/config/index.js 中 productionSourceMap 值
productionSourceMap:false
四、公用库提取
1、安装 clean-webpack-plugin add-asset-html-webpack-plugin
yarn add clean-webpack-plugin add-asset-html-webpack-plugin@2.1.0 --dev
2、build 目录下创建 webpack.dll.conf.js
const webpack = require('webpack')
const path = require('path')
const CleanWebpackPlugin = require('clean-webpack-plugin')
const dllPath = path.resolve(__dirname, '../src/assets/dll') // dll文件存放的目录
process.env.NODE_ENV = 'production' // NODE_ENV 设置为 production 减少依赖
module.exports = {
entry: { // 把 vue 相关模块的放到一个单独的动态链接库
vue: ['babel-polyfill', 'vue', 'vue-router', 'vuex', 'axios', 'element-ui']
},
output: {
filename: '[name]-[hash].dll.js', // 生成vue.dll.js
path: dllPath,
library: '_dll_[name]'
},
plugins: [
new CleanWebpackPlugin(['*.js'], { // 清除之前的dll文件
root: dllPath
}),
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify(process.env.NODE_ENV) // 设置环境变量
}
}),
new webpack.DllPlugin({
name: '_dll_[name]', // manifest.json 描述动态链接库包含了哪些内容
path: path.join(__dirname, './', '[name].dll.manifest.json')
}),
// 压缩代码
new webpack.optimize.UglifyJsPlugin({
compress: {
warnings: false,
pure_funcs: ['console.log']
},
sourceMap: false
})
]
}
3、在 package.json 中新增 dll 构建命令
"scripts": {
"dll": "webpack --config build/webpack.dll.conf.js" // dll打包命令
},
4、修改 build/webpack.prod.conf.js
const AddAssetHtmlPlugin = require('add-asset-html-webpack-plugin')
plugins: [
// 引用 manifest.json
new webpack.DllReferencePlugin({
manifest: require('./vue.dll.manifest.json')
}),
// 将 dll 注入到 生成的 html 模板中
new AddAssetHtmlPlugin({
filepath: path.resolve(__dirname, '../src/assets/dll/*.js'), // dll文件位置
publicPath: config.build.assetsPublicPath + utils.assetsPath('dll/'), // dll 引用路径
outputPath: config.build.assetsPublicPath + utils.assetsPath('dll/'), // dll最终输出的目录
includeSourcemap: false
// hash: true,
}),
...
]
五、编译
yarn run dll // 运行一次生成 dll 文件即可,下次构建时不必运行
yarn run build
关于怎么优化vue-cli2的构建速度问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。