精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Vite插件:自動打包壓縮圖片和轉webp

開發
最近寫頁面的時候,用webp優化圖片大小,就想著有沒有相關插件可以開發和打包的時候自動幫我轉化和壓縮。因為用vite打包工具,就去社區找相關插件,可沒找到一個比較符合我要求的,就打算自己工作摸魚寫一個吧。

倉庫

github: github.com/illusionGD/…[1]

需求

  • 能壓縮圖片,壓縮質量能配置
  • 能自動轉webp格式,并且打包后能把圖片引用路徑的后綴改成.webp
  • 支持開發環境和生產環境
  • 不影響原項目圖片資源,開發要無感,使用簡單

技術棧

  • sharp:圖片壓縮、格式轉換
  • @vitejs/plugin-vue:vite插件開發

實現思路

生產環境

生產環境要考慮兩個功能:
1、壓縮圖片:這個比較簡單,在generateBundle鉤子函數里面處理圖片的chunk中的buffer就可以了

image.png

export default function ImageTools() {
    return {
        // hook
      async  generateBundle(_options, bundle) {
          for (const key in bundle){
              // 過濾圖片key
              const { ext } = parse(key)
              if (!/(png|jpg|jpeg|webp)$/.test(ext)) {
                  continue
              }
              
              // 處理圖片buffer
              if (chunk.source && chunk.source instanceof Buffer) {
                   // 壓縮圖片,這里就省略邏輯了,可以去看sharp文檔
                  const pressBuffer = await pressBufferToImage(chunk.source) 
                  // 替換處理后的buffer
                  chunk.source = pressBuffer
                }
          }
      }
    }
}

2、轉webp格式: 還是在generateBundle中,直接copy一份圖片的chunk,替換chunk的source和fileName,再添加到bundle中輸出

export default function ImageTools() {
    return {
        // hook
      async  generateBundle(_options, bundle) {
          for (const key in bundle){
              // 過濾圖片key
              ...
              // 處理圖片buffer
              ...
              
              /*webp相關邏輯*/
              // 克隆原本的chunk
              const webpChunk = structuredClone(chunk)
              // 生成webp的buffer, 邏輯省略
              const webpBuffer = await toWebpBuffer(chunk.source)
              
              // 更改新chunk的source和fileName
              webpChunk.source = webpBuffer
              
              const ext = extname(path)
              const webpName = key.replace(ext, '.wep')
              webpChunk.fileName = webpName
              
              // 添加到bundle中
              bundle[webpName] = webpChunk
          }
      }
    }
}

3、**替換路徑后綴為.webp**:這里就有點麻煩,需要考慮圖片的引入方式和打包的產物,解析產物去替換了

引入方式:

  • css:background、background-image
  • 組件、html文件中的標簽:img、source、<div style="background-image: url('')"></div><div style="background: url('')"></div>
  • import:import 'xxx/xxx/xx.png'

產物, 以vue為例:
css中引入的,打包后還是在css中 image.png image.png 組件中的標簽引入,打包后是在js中 image.png

html文件中的標簽:就在html中 

image.png

知道產物后就比較好替換了,我這里采用一種比較巧妙的方法,不需要轉ast就能精準替換路徑后綴:
先在generateBundle中收集打包后圖片的名稱和對應的webp名稱:

image.png

再替換上述產物文件中的圖片后綴:

function handleReplaceWebp(str: string) {
  let temp = str
  for (const key in map) { // 這里的map就是上述圖片中的對象
    temp = temp.replace(new RegExp(key, 'g'), map[key])
  }
  return temp
}
export default function ImageTools() {
    return {
        // hook
      async  generateBundle(_options, bundle) {
          for (const key in bundle){
              // 過濾圖片key
              ...
              // 處理圖片buffer
              ...
              // 替換js和css中的圖片后綴
             if (/(js|css)$/.test(key) && enableWebp) {
              if (/(js)$/.test(key)) {
                chunk.code = handleReplaceWebp(chunk.code)
              } else if (/(css)$/.test(key)) {
                chunk.source = handleReplaceWebp(chunk.source)
              }
            }
          }
      },
      
      // 替換html中的圖片后綴
      async writeBundle(opt, bundle) {
          for (const key in bundle) {
            const chunk = bundle[key] as any
            if (/(html)$/.test(key)) {
              const htmlCode = handleReplaceWebp(chunk.source)
              writeFileSync(join(opt.dir!, chunk.fileName), htmlCode)
            }
          }
        }
    }
}

好了,這就是生產環境大概實現思路了,接下來看開發環境中如何轉webp

開發環境

有人可能認為,開發環境并不需要壓縮和轉webp功能,其實不然,開發環境主要是為了看圖片處理后的效果,是否符合預期效果,不然每次都要打包才能看,就有點麻煩了.

開發環境主要考慮以下兩點:

  1. 和生產環境一樣,需要做壓縮和轉webp處理
  2. 需要加入緩存,避免每次熱更都進行壓縮和轉webp

壓縮和轉webp處理
這里就比較簡單了,不需要處理bunlde,在請求本地服務器資源hook中(configureServer) 處理并返回圖片資源就行:

export default function ImageTools() {
    return {
        // hook
     configureServer(server) {
         server.middlewares.use(async (req, res, next) => {
            if (!filterImage(req.url || '')) return next()

            try {
              const filePath = decodeURIComponent(
                path.resolve(process.cwd(), req.url?.split('?')[0].slice(1) || '')
              )
                
              // 過濾圖片請求
              ...
              
              const buffer = readFileSync(filePath)
              // 處理圖片壓縮和轉webp,返回新的buffer,邏輯省略
              const newBuffer = await pressBufferToImage(buffer)
             
              if (!newBuffer) {
                next()
              }

              res.setHeader('Content-Type', `image/webp`)
              res.end(newBuffer)
            } catch (e) {
              next()
            }
          })
    }
}

緩存圖片
這里的思路:

  • 第一次請求圖片時,緩存對應圖片的文件,并帶上hash值
  • 每次請求時都對比緩存文件的hash,有就返回,沒有就繼續走圖片處理邏輯

詳細代碼就不貼了,這里只寫大概邏輯

export function getCacheKey({ name, ext, content}: any, factor: AnyObject) {
  const hash = crypto
    .createHash('md5')
    .update(content)
    .update(JSON.stringify(factor))
    .digest('hex')
  return `${name}_${hash.slice(0, 8)}${ext}`
}

export default function ImageTools() {
    return {
        // hook
     configureServer(server) {
         server.middlewares.use(async (req, res, next) => {
            if (!filterImage(req.url || '')) return next()

            try {
              const filePath = decodeURIComponent(
                path.resolve(process.cwd(), req.url?.split('?')[0].slice(1) || '')
              )
                
              // 過濾圖片請求
              ...
              const { ext, name } = parse(filePath)
              const file = readFileSync(filePath)
              // 獲取圖片緩存的key,就是圖片hash的名稱
              const cacheKey = getCacheKey(
                {
                  name,
                  ext,
                  content: file
                },
                { quality, enableWebp, sharpConfig, enableDevWebp, ext } // 這里傳生成hash的因子,方便后續改配置重新緩存圖片
              )
              const cachePath = join('node_modules/.cache/vite-plugin-image', cacheKey)

              // 讀緩存
              if (existsSync(cachePath)) {
                return readFileSync(cachePath)
              }
             
              // 處理圖片壓縮和轉webp,返回新的buffer
              const buffer = readFileSync(filePath)
              // 處理圖片壓縮和轉webp,返回新的buffer,邏輯省略
              const newBuffer = await pressBufferToImage(buffer)
              // 寫入緩存
              writeFile(cachePath, newBuffer, () => {})
              ...
          })
    }
}

效果

這里就爬幾張原神的圖片展示了(原神,啟動!!)

開發環境: image.png

生產環境:

image.png image.png image.png image.png

總結

  • 以上就是大致思路了,代碼僅供參考
  • GitHub: vite-plugin-image-tools[2]
  • 后續打算繼續維護這個倉庫并更新更多圖片相關功能的,有問題歡迎提issue呀~

原文: https://juejin.cn/post/7489043337288794139

參考資料

[1] https://github.com/illusionGD/vite-plugin-image-tools

[2] https://github.com/illusionGD/vite-plugin-image-tools

責任編輯:龐桂玉 來源: web前端進階
相關推薦

2023-08-29 08:19:19

PicGo插件開發

2010-03-12 15:10:16

Ubuntu壓縮圖片

2016-11-02 18:43:02

javascripthtml5vue.js

2020-08-05 16:09:52

javascript壓縮圖片前端

2021-06-22 06:52:46

Vite 插件機制Rollup

2020-05-07 19:21:53

WebP圖片編輯工具開源

2010-10-12 13:57:43

GoogleWebP

2021-09-05 15:55:05

WebP圖片格式瀏覽器

2022-05-19 09:48:07

webp瀏覽器

2021-11-27 07:09:39

P 圖工具工具應用軟件

2021-05-24 05:36:31

壓縮圖片應用壓縮工具

2009-06-05 16:43:54

Page Speed網頁加速Google

2022-06-30 10:38:53

Lepton無損壓縮圖片圖片質量

2022-10-20 16:04:26

模型質量

2024-07-17 09:23:58

Vite插件機制

2022-01-24 12:38:58

Vite插件開發

2023-11-22 08:21:25

Android開發場景

2025-05-09 08:40:42

插件頁面Vite

2024-02-01 08:38:19

項目代碼CICD

2009-09-05 10:26:20

Linux壓縮打包命令Linux命令
點贊
收藏

51CTO技術棧公眾號

日本三日本三级少妇三级66| 欧美成人福利视频| 欧美国产综合视频| 91丨九色丨海角社区| 日韩久久精品网| 91精品啪在线观看国产60岁| 日本大胆人体视频| 日韩电影免费| 精品一区二区三区久久久| 欧美日韩成人在线观看| www.av欧美| 精品视频在线观看网站| 偷拍亚洲欧洲综合| 色综合久久av| 五月激情婷婷综合| 精品一区二区在线播放| 97精品国产97久久久久久免费| 久久视频精品在线观看| 粉嫩精品导航导航| 欧美三级日韩在线| 26uuu成人网一区二区三区| 亚洲国产一区二区三区四区| 中文字幕第38页| av福利导福航大全在线| 国产精品久99| 久久亚裔精品欧美| www.激情五月.com| 久久精品久久99精品久久| 91tv亚洲精品香蕉国产一区7ujn| 999久久久国产| 午夜精品福利影院| 日韩亚洲欧美综合| 日本黄色的视频| 日产福利视频在线观看| 亚洲影视资源网| 不卡中文字幕在线| 国产对白叫床清晰在线播放| 99精品国产99久久久久久白柏| 成人免费在线网址| 中国老头性行为xxxx| 国产亚洲福利| 91精品国产乱码久久久久久蜜臀| 人妻久久一区二区| 久久精品青草| 最近更新的2019中文字幕| 人人妻人人藻人人爽欧美一区| 高潮久久久久久久久久久久久久| 欧美日韩精品三区| 欧美婷婷精品激情| 3d性欧美动漫精品xxxx软件| 大桥未久av一区二区三区| 男女日批视频在线观看| 丝袜在线视频| 亚洲永久免费av| www.污污视频| www.污视频| 99久久久国产精品无码网爆| 四虎精品永久在线| 91tv官网精品成人亚洲| 国产亚洲成av人片在线观看桃| 在线观看免费视频国产| 澳门精品久久国产| 精品国产精品一区二区夜夜嗨| 97人人模人人爽人人澡| 欧美经典影片视频网站| 日韩欧美在线1卡| 制服.丝袜.亚洲.中文.综合懂| 国产精品日本一区二区不卡视频 | 手机在线免费看毛片| 国产精品成人a在线观看| 久久精品国产91精品亚洲| 大地资源高清在线视频观看| 综合久久久久| 欧美高清性猛交| 日韩精品一区二区在线播放| 免费精品视频| 国产精品免费观看在线| 国产又粗又大又爽| www香蕉视频| 韩国成人精品a∨在线观看| 91亚洲午夜在线| 亚洲xxxx天美| 99国产欧美另类久久久精品| 久久美女性网| 亚洲护士老师的毛茸茸最新章节| 国产模特精品视频久久久久| 亚洲乱码国产乱码精品精| 全黄一级裸体片| 不卡中文一二三区| 久久综合久中文字幕青草| 久草福利资源在线观看| 亚洲欧美日韩国产| 国产精品免费久久久久久| 国产伦理一区二区| 99这里只有久久精品视频| 欧美日韩在线观看一区二区三区| 尤物视频在线免费观看| 亚洲精品成人精品456| 无码中文字幕色专区| 欧美一级二级视频| 日韩欧美国产电影| 免费人成又黄又爽又色| 中文字幕av亚洲精品一部二部| 91干在线观看| 91麻豆视频在线观看| av一区二区三区在线| 亚洲欧洲中文| 精品捆绑调教一区二区三区| 一本大道综合伊人精品热热 | 中文一区二区| 成人黄色在线免费| 蜜桃视频在线观看视频| 一区二区三区视频在线观看 | 国产综合成人久久大片91| 国产一级特黄a大片99| 91社区在线观看| 激情av一区二区| 国产资源中文字幕| 欧美极品中文字幕| 久久久久久亚洲精品| 亚洲一级特黄毛片| 91女神在线视频| 国产91在线亚洲| 欧洲亚洲精品| 亚洲欧美日韩第一区| 精品亚洲永久免费| 国产一区在线视频| 亚洲国产欧美一区二区三区不卡| 在线观看爽视频| 精品久久久久久无| 欧美激情精品久久| 精品一区二区免费看| 欧洲一区二区在线| 日韩精品美女| 亚洲电影第1页| 天天操天天操天天操天天操天天操| 国产偷自视频区视频一区二区| 国产精品毛片一区视频| 91高清在线观看视频| 欧美剧在线免费观看网站 | 日本孕妇大胆孕交无码| 99视频一区二区| 99久久免费观看| 美国十次综合久久| 久久国产精彩视频| 国产内射老熟女aaaa∵| 中国av一区二区三区| wwwwww.色| 欧美一区电影| 国产日韩欧美日韩大片| yw在线观看| 欧美午夜精品久久久| 日韩免费成人av| 日韩电影一二三区| 亚洲成色最大综合在线| 成人精品动漫| xxxxx成人.com| 97在线视频人妻无码| 综合久久综合久久| 四虎成人在线播放| 亚洲情侣在线| 国产chinese精品一区二区| 欧美hdxxx| 亚洲国产欧美一区| 成人午夜视频在线播放| 国产偷国产偷亚洲高清人白洁 | av最新在线| 日韩精品亚洲视频| 青青国产在线视频| 国产精品初高中害羞小美女文| 国产大片一区二区三区| 欧美日韩一卡| 牛人盗摄一区二区三区视频| 99久久婷婷国产综合精品首页| xvideos国产精品| 高h调教冰块play男男双性文| 欧美日韩亚洲91| 日韩av毛片在线观看| 国产99久久久久| 亚洲爆乳无码专区| 亚洲视频电影在线| 国产精品三区www17con| 欧美日韩精品免费观看视完整| 中文字幕在线日韩| 人人妻人人澡人人爽精品日本| 日韩欧美极品在线观看| www成人啪啪18软件| 国产99久久久国产精品潘金| 亚洲午夜无码av毛片久久| 欧洲乱码伦视频免费| 91pron在线| 日韩欧美一区二区三区免费观看| 久久精品国产精品| 香蕉视频免费看| 欧美日韩日日夜夜| 国产午夜福利片| 欧美国产乱子伦| av av在线| 黄一区二区三区| 成人一级片网站| 欧美精品三级| 亚洲春色在线视频| 久久香蕉精品香蕉| 亚洲一区免费网站| 成人日韩精品| 97碰碰碰免费色视频| 男人天堂久久久| 亚洲女人天堂色在线7777| 国产suv精品一区二区69| 91福利国产成人精品照片| 久久久久成人网站| 国产精品美日韩| 精品人妻一区二区三区香蕉| 国产一区二区三区久久悠悠色av| 国产又大又硬又粗| 亚洲国产日本| 97在线免费视频观看| 日韩av网站在线播放| 盗摄系列偷拍视频精品tp| 国产成人久久久| 黄色在线看片| 中文字幕在线观看亚洲| 少妇喷水在线观看| 欧美一区二区三区不卡| 毛片在线免费播放| 欧美日韩中国免费专区在线看| 国产盗摄一区二区三区| 国产精品三区在线| 欧美电影院免费观看| 国产成人激情小视频| 暧暧视频在线免费观看| 欧美xxxx做受欧美| 国产写真视频在线观看| 中文字幕亚洲情99在线| 国产高清免费在线播放| 亚洲欧美日韩精品久久奇米色影视 | 精品精品久久| 欧美午夜视频在线| 九九视频免费观看视频精品 | 天堂网在线观看国产精品| 日韩偷拍一区二区| 欧美美女一区| 午夜精品区一区二区三| 精品国产一区二区三区久久久蜜臀 | 丝袜连裤袜欧美激情日韩| 国产 高清 精品 在线 a | 欧美下载看逼逼| 妖精视频一区二区三区免费观看| 麻豆91蜜桃| 视频一区欧美| 欧美一区二区影视| 欧美男gay| 日韩区国产区| 国产日产精品一区二区三区四区的观看方式 | 狠狠操狠狠色综合网| 国产一二三四区| 亚洲欧美中日韩| 久久嫩草捆绑紧缚| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 国产精品二区一区二区aⅴ污介绍| 国产精品九九九九九| 99re这里只有精品6| 中文字幕第3页| 久久夜色精品国产噜噜av| 亚洲男人在线天堂| xf在线a精品一区二区视频网站| 中文字幕被公侵犯的漂亮人妻| 91伊人久久大香线蕉| 久久中文字幕人妻| 亚洲欧洲一区二区三区| 丝袜美腿小色网| 一区二区三区产品免费精品久久75| 福利所第一导航| 亚洲国产日韩a在线播放| 日本三级午夜理伦三级三| 欧美日韩另类在线| 精品无码一区二区三区的天堂| 色婷婷综合中文久久一本| 日韩特级黄色片| 精品视频在线免费观看| 国产精品午夜福利| 欧美日韩精品福利| 日本高清视频网站| 精品无码久久久久久国产| 国产三级在线观看| 久久中文字幕在线| caoprom在线| 日本久久中文字幕| 2020国产精品小视频| 99国产精品久久久久老师| 高清欧美性猛交xxxx黑人猛| 久久成人在线视频| 中文字幕 日韩有码| 欧美综合久久久| 国产按摩一区二区三区| 亚洲福利视频免费观看| 免费黄网站在线观看| 久久久极品av| sm久久捆绑调教精品一区| 国产精品嫩草影院一区二区| 国产性生活视频| 日韩精品每日更新| 色阁综合伊人av| 北条麻妃在线| 欧美日韩高清在线观看| 欧美aa视频| 99久久国产免费免费| 亚洲自拍电影| 美女黄色片网站| 久久婷婷一区| www.日本久久| www.欧美色图| 极品久久久久久| 91久久线看在观草草青青| 在线观看中文字幕av| 日韩精品免费视频| 亚洲精品承认| 热草久综合在线| 日本精品视频| 水蜜桃一区二区三区| 性欧美精品高清| 手机看片国产精品| 国产人成亚洲第一网站在线播放 | 色综合久久88| 在线观看精品| 国产一区自拍视频| 欧美区一区二| 午夜剧场在线免费观看| 91在线观看地址| 97免费在线观看视频| 欧美高清你懂得| 四虎在线免费看| 91精品国产91| 婷婷视频一区二区三区| 欧美一区观看| 国产精品试看| 97中文字幕在线观看| 一区二区在线观看视频| 亚洲视频一区二区三区四区| 亚洲精品资源在线| 成人av三级| 久久精彩视频| 黄色成人精品网站| 国产乱国产乱老熟300部视频| 日韩一区欧美小说| 国产免费一区二区三区免费视频| 亚洲小视频在线观看| 欧美aa在线| 欧美日韩一区二区三区免费| 一本色道久久综合一区| www.四虎精品| 五月天国产精品| 色屁屁草草影院ccyycom| 国内精品久久久久伊人av| 亚洲一区二区三区四区电影| 四虎免费在线观看视频| 国产高清亚洲一区| 2021亚洲天堂| 欧美剧在线免费观看网站| 精品美女在线观看视频在线观看| 成人精品视频99在线观看免费| 婷婷成人基地| 性生活一级大片| 樱桃视频在线观看一区| 亚洲精品国产一区二| 久久久免费在线观看| 成人短视频软件网站大全app| 国产一级黄色录像片| 国产高清一区日本| 五月天婷婷激情| 国产一区二区三区丝袜| 久久天堂影院| 777久久精品一区二区三区无码| 国产精品自拍三区| 天天操天天射天天爽| 日韩久久精品成人| 欧美第一视频| 在线观看av的网址| 成人黄色av网站在线| 国产一区免费看| 精品国内亚洲在观看18黄 | 国产亚洲毛片| 蜜臀久久99精品久久久久久| 宅男在线国产精品| 调教一区二区| 欧美日韩在线播放一区二区| 久久国产精品区| 欧美一级高潮片| 日韩成人激情视频| 午夜av成人| 国产精品久久久久9999爆乳| 99精品桃花视频在线观看| 久久人妻免费视频| 日韩网站免费观看高清| 日韩视频在线直播| 又色又爽又高潮免费视频国产| 1000部国产精品成人观看| 午夜在线视频观看| 国产精品入口夜色视频大尺度| 一区二区三区午夜视频|