小編給大家分享一下vue代碼壓縮優化方式有哪些,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
如果不需要生產環境的 source map,可以將其設置為 false 以加速生產環境構建。
設置為false打包時候不會出現.map文件
module.exports = {
productionSourceMap: false
}安裝uglifyjs-webpack-plugin插件,可以去除項目中console.log和debugger
npm install uglifyjs-webpack-plugin --save
const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
// 生產環境相關配置
if (isProduction) {
// 代碼壓縮
config.plugins.push(
new UglifyJsPlugin({
uglifyOptions: {
//生產環境去除console等信息
compress: {
warnings: false, // 若打包錯誤,則注釋這行
drop_debugger: true,//是否移除debugger
drop_console: true,
pure_funcs: ['console.log']//移除console
}
},
sourceMap: false,
parallel: true
})
)
}安裝 image-webpack-loader 插件,可以將大圖片進行壓縮從而縮小打包體積
npm install image-webpack-loader --save
chainWebpack: config => {
// ============壓縮圖片 start============
config.module
.rule('images')
.use('image-webpack-loader')
.loader('image-webpack-loader')
.options({ bypassOnDebug: true })
.end()
// ============壓縮圖片 end============
}開啟gzip壓縮,可以優化http請求,提高加載速度
npm install compression-webpack-plugin --save-dev
const CompressionPlugin = require("compression-webpack-plugin");
// 開啟gzip壓縮
config.plugins.push(new CompressionPlugin({
algorithm: 'gzip',
test: new RegExp("\\.(" + ["js", "css"].join("|") + ")$"), // 匹配文件擴展名
// threshold: 10240, // 對超過10k的數據進行壓縮
threshold: 5120, // 對超過5k的數據進行壓縮
minRatio: 0.8,
cache: true, // 是否需要緩存
deleteOriginalAssets:false // true刪除源文件(不建議);false不刪除源文件
}))最近被某大公司大佬虐了,要求混淆用vuecli3寫的代碼(啥敏感信息都沒有,混淆個什么混淆...)
1、安裝 “uglifyjs-webpack-plugin”
cnpm i --save uglifyjs-webpack-plugin
沒有安裝cnpm的同學可以用npm
2、在項目根目錄下創建一個名為 vue.config.js的文件
3、在vue.config.js中引入uglifyjs-webpack-plugin
const UglifyPlugin = require('uglifyjs-webpack-plugin')4、在vue.config.js中配置uglifyjs-webpack-plugin
module.exports = {
configureWebpack: (config) => {
if (process.env.NODE_ENV == 'production') {
// 為生產環境修改配置
config.mode = 'production'
// 將每個依賴包打包成單獨的js文件
let optimization = {
minimizer: [new UglifyPlugin({
uglifyOptions: {
warnings: false,
compress: {
drop_console: true,
drop_debugger: false,
pure_funcs: ['console.log']
}
}
})]
}
Object.assign(config, {
optimization
})
} else {
// 為開發環境修改配置
config.mode = 'development'
}
}
};這就可以了,接下來大家可以打包試試了
cnpm run build
如果報錯的話,估計是uglifyjs-webpack-plugin版本又更新了,可能需要修改配置中的 “minimizer”節點
看完了這篇文章,相信你對“vue代碼壓縮優化方式有哪些”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。