日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue打包通過image-webpack-loader插件對圖片壓縮優化操作

瀏覽:95日期:2022-10-30 17:12:28

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) 先安裝依賴:cnpm 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’// 本地環境是否需要使用cdnconst devNeedCdn = false// cdn鏈接const cdn = { // cdn:模塊名稱和模塊作用域命名(對應window里面掛載的變量名稱) externals: { vue: ’Vue’, vuex: ’Vuex’, ’vue-router’: ’VueRouter’ }, // cdn的css鏈接 css: [], // cdn的js鏈接 js: [ ’https://cdn.staticfile.org/vue/2.6.10/vue.min.js’, ’https://cdn.staticfile.org/vuex/3.0.1/vuex.min.js’, ’https://cdn.staticfile.org/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’// 本地環境是否需要使用cdnconst devNeedCdn = false// cdn鏈接const cdn = { // cdn:模塊名稱和模塊作用域命名(對應window里面掛載的變量名稱) externals: { vue: ’Vue’, vuex: ’Vuex’, ’vue-router’: ’VueRouter’ }, // cdn的css鏈接 css: [], // cdn的js鏈接 js: [ ’https://cdn.staticfile.org/vue/2.6.10/vue.min.js’, ’https://cdn.staticfile.org/vuex/3.0.1/vuex.min.js’, ’https://cdn.staticfile.org/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='http://m.b3g6.com/bcjs/<%= BASE_URL %>favicon.ico' /> <!-- 使用CDN的CSS文件 --> <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.css) { %> <link href='http://m.b3g6.com/bcjs/<%= 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 withoutJavaScript 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='http://m.b3g6.com/bcjs/<%= 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) 安裝依賴:cnpm 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: {//生產環境自動刪除consolecompress: { warnings: false, // 若打包錯誤,則注釋這行 drop_debugger: true, drop_console: true, pure_funcs: [’console.log’]} }, sourceMap: false, parallel: true }) )}

5、開啟Gzip

(1) 安裝依賴:cnpm install --save-dev compression-webpack-plugin

(2) 在vue.config.js 頂部引入依賴

// gzip壓縮

const CompressionWebpackPlugin = require(’compression-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 }, common: {chunks: ’all’,test: /[/]src[/]js[/]/,name: ’common’,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(’compression-webpack-plugin’)// 是否為生產環境const isProduction = process.env.NODE_ENV !== ’development’// 本地環境是否需要使用cdnconst devNeedCdn = true// cdn鏈接const cdn = { // cdn:模塊名稱和模塊作用域命名(對應window里面掛載的變量名稱) externals: { vue: ’Vue’, vuex: ’Vuex’, ’vue-router’: ’VueRouter’ }, // cdn的css鏈接 css: [], // cdn的js鏈接 js: [ ’https://cdn.staticfile.org/vue/2.6.10/vue.min.js’, ’https://cdn.staticfile.org/vuex/3.0.1/vuex.min.js’, ’https://cdn.staticfile.org/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 compress: { 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 }, common: { chunks: ’all’, test: /[/]src[/]js[/]/, name: ’common’, 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插件對圖片壓縮優化操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品亚洲成在人线| 久久国产高清| 国产精品99久久久久久董美香| 自拍自偷一区二区三区| 一区二区国产精品| 亚洲图片久久| 日韩精品欧美大片| 青青草伊人久久| 国产精品嫩模av在线| 国产精品久久国产愉拍| 精品视频在线一区二区在线| 国产成人久久| 国产成人a视频高清在线观看| 精品国产欧美日韩| 国产欧洲在线| 欧美色图一区| 日韩在线观看一区二区| 亚洲欧美激情诱惑| 亚洲精品黄色| 国产精品tv| 国产白浆在线免费观看| 久久高清免费| 日韩中文字幕区一区有砖一区| 日韩高清不卡在线| 精品九九久久| 99热国内精品| 亚洲深夜福利在线观看| 欧美一区=区三区| 国产一区一一区高清不卡| 国产精品久久久久av电视剧| 999在线观看精品免费不卡网站| 亚洲a级精品| 成人精品视频| 国产亚洲精品自拍| 国产美女视频一区二区| 青青青免费在线视频| 日韩午夜免费| 国产剧情一区二区在线观看| 国产福利电影在线播放| 中文精品在线| 在线日韩欧美| 日韩av中文字幕一区二区三区| 国产毛片精品| 91精品一区二区三区综合| 爽好多水快深点欧美视频| 国产私拍福利精品视频二区| 成人黄色av| 欧美在线黄色| 青草综合视频| 日本在线高清| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美日本久久| 久久伦理在线| 国产精品流白浆在线观看| 亚洲手机在线| 国产精品亲子伦av一区二区三区| 在线日韩视频| 亚洲a级精品| 日韩高清中文字幕一区二区| 视频国产精品| 99免费精品| 日韩精品导航| 免费在线观看日韩欧美| 在线视频精品| 蜜桃视频一区二区三区在线观看| 日韩成人精品一区| 天堂va蜜桃一区二区三区| 久久久久午夜电影| 在线午夜精品| 米奇777超碰欧美日韩亚洲| 国产欧美日韩视频在线| 国产一区亚洲| 国产专区精品| 日本久久二区| 视频一区中文字幕精品| 中文字幕一区二区三区四区久久| 老司机精品在线| 免费精品一区| 欧美综合国产| 香蕉久久国产| 国产精品一在线观看| 亚洲欧美日韩高清在线| 国产日本精品| 视频一区欧美精品| 日本激情一区| 国产精品s色| 三级欧美在线一区| 日韩欧美另类一区二区| 久久av电影| 日本国产一区| 美女久久网站| 五月天综合网站| 亚洲1234区| 麻豆成全视频免费观看在线看| 国产精品国码视频| 日本aⅴ亚洲精品中文乱码 | 一区二区三区四区日本视频| 国产区精品区| 日韩av中文字幕一区二区| 婷婷精品进入| 久久久精品午夜少妇| 日韩国产专区| 青青青免费在线视频| 精品一区二区三区免费看| 欧美韩一区二区| 国产精品男女| 国产精品黄色片| 欧美在线首页| 日韩中文字幕视频网| 日韩中文字幕麻豆| 久久最新视频| 中文欧美日韩| 九一国产精品| 欧美另类专区| 欧美日韩水蜜桃| 高清av一区二区三区| 成人羞羞视频播放网站| 久久久久网站| 亚洲国产专区校园欧美| 91精品成人| 视频在线观看一区二区三区| 中文字幕免费精品| 日韩高清不卡一区| 国产精品嫩模av在线| 免费日韩成人| 久久久久久色 | 亚洲午夜精品久久久久久app| 亚洲美女久久精品| 99精品视频精品精品视频| 91成人精品视频| 免费久久99精品国产| 日本99精品| 久久99视频| 在线亚洲人成| 日韩视频一区| 日韩精品亚洲aⅴ在线影院| 国产欧美日韩一区二区三区在线| 麻豆91在线播放| 成人免费电影网址| 香蕉成人久久| 国产日韩在线观看视频| 欧美a在线观看| 91视频精品| 99热免费精品| 欧美一区=区三区| 成人国产精品久久| 亚洲二区视频| 日韩手机在线| 高清精品久久| 欧美精品黄色| 欧美视频二区| jizzjizz中国精品麻豆| 国产伊人精品| 日本一区福利在线| 国产精品99一区二区三区| 国精品一区二区三区| 视频在线观看国产精品| 国产麻豆一区二区三区精品视频| 日韩成人精品一区二区| 亚洲一区二区三区高清不卡| 欧美日韩99| 久久久久久久久丰满| 亚洲3区在线| 日产午夜精品一线二线三线| 欧美在线影院| 国产精区一区二区| 成人羞羞在线观看网站| 视频一区视频二区在线观看| 久久成人av| 亚洲精品在线观看91| 国产精品网站在线看| 亚洲成人精品| 日韩国产欧美视频| 午夜精品久久久久久久久久蜜桃| 中文字幕一区二区三区四区久久| 九九99久久精品在免费线bt| 欧美日韩国产精品一区二区亚洲| 国产人成精品一区二区三| 日韩网站中文字幕| 日韩欧美三区| 久久久久国产| 国产亚洲第一伦理第一区| 欧美/亚洲一区| 国产精品久久久免费| 日韩天堂av| 福利一区二区三区视频在线观看| 亚洲欧美不卡| 韩国久久久久久| 欧美日韩精品一区二区三区视频 | 日韩在线免费| 日韩高清在线一区| 欧美99久久| 精品三级av在线导航| 亚洲精品视频一二三区| 日本高清不卡一区二区三区视频| 97久久精品| 六月婷婷一区| 久久久久国产| 国产成人黄色| 国产欧美日本|