vue打包通过image-webpack-loader插件对图片压缩优化操
vue正常打包之后一些图片文件很大,使打包体积很大,通过image-webpack-loader插件可将大的图片进行压缩从而缩小打包体积
step1
npm install image-webpack-loader --save-dev
step2
在build/webpack.base.conf.js中改如下配置
module.exports = { module: { { test: /\.(png|jpe?g|gif|svg)(\?.)?$/, // loader: 'url-loader', // options: { // limit: 100000, // name: utils.assetsPath('img/[name].[hash:7].[ext]') // } loader: ['url-loader?limit=10000&name=' + utils.assetsPath('img/[name].[hash:7].[ext]'), 'image-webpack-loader' ] }, ] }, }
补充知识vuecli3项目打包优化配置要点
一、新建项目
使用 vue-cli3 构建一个初始的Vue项目
因为使用了cli3,很多目录结构不见了,而相关配置是放在vue.config.js里面的,在根目录,新建一个vue.config.js
module.exports = {}
二、正式优化
1、将 productionSourceMap 设为 false
(1) 在vue.config.js中module.exports写入
module.exports = { productionSourceMap: false }
2、图片压缩
vue正常打包之后一些图片文件很大,使打包体积很大,通过image-webpack-loader插件可将大的图片进行压缩从而缩小打包体积
(1) 先安装依赖pm install image-webpack-loader --save-dev
(2) 在vue.config.js中module.exports写入
module.exports = { productionSourceMap: false, chainWebpack: config => { // ============压缩图片 start============ config.module .rule('images') .use('image-webpack-loader') .loader('image-webpack-loader') .options({ bypassOnDebug: true }) .end() // ============压缩图片 end============ } }
3、cdn配置(可选)
(1) 在vue.config.js 最上边写入
// 是否为生产环境 const isProduction = process.env.NODE_ENV !== 'development' // 本地环境是否需要使用cdn const devNeedCdn = false // cdn链接 const cdn = { // cdn模块名称和模块作用域命名(对应window里面挂载的变量名称) externals: { vue: 'Vue', vuex: 'Vuex', 'vue-router': 'VueRouter' }, // cdn的css链接 css: [], // cdn的js链接 js: [ 'https://cdn.staticfile./vue/2.6.10/vue.min.js', 'https://cdn.staticfile./vuex/3.0.1/vuex.min.js', 'https://cdn.staticfile./vue-router/3.0.3/vue-router.min.js' ] }
(2) 在vue.config.js module.exports chainWebpack中写入
// ============注入cdn start============ config.plugin('html').tap(args => { // 生产环境或本地需要cdn时,才注入cdn if (isProduction || devNeedCdn) args[0].cdn = cdn return args }) // ============注入cdn start============
(3) 在vue.config.js module.exports configureWebpack中写入
configureWebpack: config => { // 用cdn方式引入,则构建时要忽略相关资源 if (isProduction || devNeedCdn) config.externals = cdn.externals }
(4) 当前配置的vue.config.js
// 是否为生产环境 const isProduction = process.env.NODE_ENV !== 'development' // 本地环境是否需要使用cdn const devNeedCdn = false // cdn链接 const cdn = { // cdn模块名称和模块作用域命名(对应window里面挂载的变量名称) externals: { vue: 'Vue', vuex: 'Vuex', 'vue-router': 'VueRouter' }, // cdn的css链接 css: [], // cdn的js链接 js: [ 'https://cdn.staticfile./vue/2.6.10/vue.min.js', 'https://cdn.staticfile./vuex/3.0.1/vuex.min.js', 'https://cdn.staticfile./vue-router/3.0.3/vue-router.min.js' ] } module.exports = { productionSourceMap: false, chainWebpack: config => { // ============压缩图片 start============ config.module .rule('images') .use('image-webpack-loader') .loader('image-webpack-loader') .options({ bypassOnDebug: true }) .end() // ============压缩图片 end============ // ============注入cdn start============ config.plugin('html').tap(args => { // 生产环境或本地需要cdn时,才注入cdn if (isProduction || devNeedCdn) args[0].cdn = cdn return args }) // ============注入cdn start============ }, configureWebpack: config => { // 用cdn方式引入,则构建时要忽略相关资源 if (isProduction || devNeedCdn) config.externals = cdn.externals } }
(5) 在public index.html 写入
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="viewport" content="width=device-width,initial-scale=1.0" /> <link rel="icon" href="<%= BASE_URL %>favicon.ico" /> <!-- 使用CDN的CSS文件 --> <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.css) { %> <link href="<%= htmlWebpackPlugin.options.cdn.css[i] %>" rel="stylesheet" /> <% } %> <!-- 使用CDN的CSS文件 --> <title>cli3_base</title> </head> <body> <noscript> <strong >We're sorry but cli3_base doesn't work properly without JavaScript enabled. Please enable it to continue.</strong > </noscript> <div id="app"></div> <!-- 使用CDN的JS文件 --> <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.js) { %> <script src="<%= htmlWebpackPlugin.options.cdn.js[i] %>"></script> <% } %> <!-- 使用CDN的JS文件 --> <!-- built files will be auto injected --> </body> </html>
(6) 重启项目npm run serve
(7) 在src/router.js修改
将
Vue.use(Router)
改为
if (!window.VueRouter) Vue.use(Router)
(8) 重新启动npm run serve即可,现在的配置是开发环境,在浏览器的Network JS里面是看不到的。若想查看,请将vue.config.js里面的
// 本地环境是否需要使用cdn
const devNeedCdn = false
改为
// 本地环境是否需要使用cdn
const devNeedCdn = true
然后重启npm run serve,然后浏览器查看Network JS
Network JS
4、代码压缩
(1) 安装依赖pm i -D uglifyjs-webpack-plugin
(2) 在vue.config.js 最上边引入依赖
// 代码压缩
const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
(3) 在vue.config.js module.exports configureWebpack 里面新增
// 生产环境相关配置 if (isProduction) { // 代码压缩 config.plugins.push( new UglifyJsPlugin({ uglifyOptions: { //生产环境自动删除console press: { warnings: false, // 若打包错误,则注释这行 drop_debugger: true, drop_console: true, pure_funcs: ['console.log'] } }, sourceMap: false, parallel: true }) ) }
5、开启Gzip
(1) 安装依赖pm install --save-dev pression-webpack-plugin
(2) 在vue.config.js 顶部引入依赖
// gzip压缩
const CompressionWebpackPlugin = require('pression-webpack-plugin')
(3) 在vue.config.js module.exports configureWebpack 里面新增,直接放在代码压缩下边即可
// 生产环境相关配置 if (isProduction) { // 代码压缩 // .................. // gzip压缩 const productionGzipExtensions = ['html', 'js', 'css'] config.plugins.push( new CompressionWebpackPlugin({ filename: '[path].gz[query]', algorithm: 'gzip', test: new RegExp( '\\.(' + productionGzipExtensions.join('|') + ')$' ), threshold: 10240, // 只有大小大于该值的资源会被处理 10240 minRatio: 0.8, // 只有压缩率小于这个值的资源才会被处理 deleteOriginalAssets: false // 删除原文件 }) ) }
6、公共代码抽离
(1) 在vue.config.js module.exports configureWebpack 里面新增,直接放在gzip压缩下边即可
// 公共代码抽离 config.optimization = { splitChunks: { cacheGroups: { vendor: { chunks: 'all', test: /node_modules/, name: 'vendor', minChunks: 1, maxInitialRequests: 5, minSize: 0, priority: 100 }, mon: { chunks: 'all', test: /[\\/]src[\\/]js[\\/]/, name: 'mon', minChunks: 2, maxInitialRequests: 5, minSize: 0, priority: 60 }, styles: { name: 'styles', test: /\.(sa|sc|c)ss$/, chunks: 'all', enforce: true }, runtimeChunk: { name: 'manifest' } } } }
完整的vue.config.js
// 代码压缩 const UglifyJsPlugin = require('uglifyjs-webpack-plugin') // gzip压缩 const CompressionWebpackPlugin = require('pression-webpack-plugin') // 是否为生产环境 const isProduction = process.env.NODE_ENV !== 'development' // 本地环境是否需要使用cdn const devNeedCdn = true // cdn链接 const cdn = { // cdn模块名称和模块作用域命名(对应window里面挂载的变量名称) externals: { vue: 'Vue', vuex: 'Vuex', 'vue-router': 'VueRouter' }, // cdn的css链接 css: [], // cdn的js链接 js: [ 'https://cdn.staticfile./vue/2.6.10/vue.min.js', 'https://cdn.staticfile./vuex/3.0.1/vuex.min.js', 'https://cdn.staticfile./vue-router/3.0.3/vue-router.min.js' ] } module.exports = { productionSourceMap: false, chainWebpack: config => { // ============压缩图片 start============ config.module .rule('images') .use('image-webpack-loader') .loader('image-webpack-loader') .options({ bypassOnDebug: true }) .end() // ============压缩图片 end============ // ============注入cdn start============ config.plugin('html').tap(args => { // 生产环境或本地需要cdn时,才注入cdn if (isProduction || devNeedCdn) args[0].cdn = cdn return args }) // ============注入cdn start============ }, configureWebpack: config => { // 用cdn方式引入,则构建时要忽略相关资源 if (isProduction || devNeedCdn) config.externals = cdn.externals // 生产环境相关配置 if (isProduction) { // 代码压缩 config.plugins.push( new UglifyJsPlugin({ uglifyOptions: { //生产环境自动删除console press: { warnings: false, // 若打包错误,则注释这行 drop_debugger: true, drop_console: true, pure_funcs: ['console.log'] } }, sourceMap: false, parallel: true }) ) // gzip压缩 const productionGzipExtensions = ['html', 'js', 'css'] config.plugins.push( new CompressionWebpackPlugin({ filename: '[path].gz[query]', algorithm: 'gzip', test: new RegExp( '\\.(' + productionGzipExtensions.join('|') + ')$' ), threshold: 10240, // 只有大小大于该值的资源会被处理 10240 minRatio: 0.8, // 只有压缩率小于这个值的资源才会被处理 deleteOriginalAssets: false // 删除原文件 }) ) // 公共代码抽离 config.optimization = { splitChunks: { cacheGroups: { vendor: { chunks: 'all', test: /node_modules/, name: 'vendor', minChunks: 1, maxInitialRequests: 5, minSize: 0, priority: 100 }, mon: { chunks: 'all', test: /[\\/]src[\\/]js[\\/]/, name: 'mon', minChunks: 2, maxInitialRequests: 5, minSize: 0, priority: 60 }, styles: { name: 'styles', test: /\.(sa|sc|c)ss$/, chunks: 'all', enforce: true }, runtimeChunk: { name: 'manifest' } } } } } } }
以上这篇vue打包通过image-webpack-loader插件对图片压缩优化操作就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程