精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

亚洲视频一区二区在线| 秋霞电影网一区二区| 亚洲国产欧美一区二区三区久久| 乱人伦xxxx国语对白| 精品999视频| 极品少妇xxxx偷拍精品少妇| 久久久爽爽爽美女图片| av男人的天堂av| 亚洲天堂av资源在线观看| 欧美三级免费观看| 四虎免费在线观看视频| 四虎精品一区二区三区| 蜜桃久久精品一区二区| 国内精品美女av在线播放| www.黄色在线| 国产精品115| 欧美精品777| 青青青在线播放| 日韩激情av| 国产精品视频看| 国产欧美欧洲| 国产精品乱码一区二区| 可以免费看不卡的av网站| 欧美理论片在线观看| 无码人妻aⅴ一区二区三区69岛| 无人区乱码一区二区三区| 日本道免费精品一区二区三区| 国产女教师bbwbbwbbw| av在线首页| 91色在线porny| av电影成人| 96亚洲精品久久久蜜桃| 日韩电影在线观看一区| 97超级碰碰碰| 亚洲一区二区91| 亚洲天天综合| 色偷偷9999www| 日本成人免费视频| 网友自拍区视频精品| 日韩一区二区电影在线| 国产精品嫩草影院8vv8| 搜成人激情视频| 精品成人乱色一区二区| 欧美高清中文字幕| 91麻豆免费在线视频| 国产精品久久久久久久裸模| 蜜桃999成人看片在线观看| 黑人乱码一区二区三区av| 国产东北露脸精品视频| 亚洲精品免费网站| av网站免费播放| 极品少妇xxxx精品少妇偷拍 | 日本系列第一页| 欧美日韩综合| 欧美国产日韩免费| 一区二区视频免费看| 91av精品| 久久99久久亚洲国产| 欧美高清视频一区二区三区| 午夜日韩激情| 欧美国产日韩一区| 男人天堂中文字幕| 亚洲美女黄色| 欧美在线影院在线视频| chinese国产精品| 日韩影院在线观看| 国产精品人人做人人爽| 国产老女人乱淫免费| 国产精品正在播放| 国产一区在线免费观看| 欧美91精品久久久久国产性生爱| 国产亚洲污的网站| 一区二区日本| 青青青草视频在线| 欧美日韩国产在线播放| 爱情岛论坛成人| 99国内精品久久久久| 欧美一级一级性生活免费录像| 久草福利在线观看| 老牛影视av一区二区在线观看| 日韩国产精品一区| 综合 欧美 亚洲日本| 欧美一区国产在线| 欧美亚洲日本黄色| 亚洲中文字幕在线一区| 国产精品99久久久| 蜜桃久久精品乱码一区二区 | 97视频在线免费观看| 精品黑人一区二区三区| 极品少妇一区二区三区精品视频| 国产精品视频免费一区| 国产专区在线播放| 亚洲另类一区二区| 黄色片久久久久| www一区二区三区| 亚洲精品美女视频| а天堂中文在线资源| 伊人成人网在线看| 国产精品日韩欧美综合| 空姐吹箫视频大全| 国产精品乱码一区二区三区软件| 日本男女交配视频| 香蕉成人影院| 亚洲精品97久久| 男人av资源站| 久久精品一区二区国产| 91入口在线观看| 粉嫩av在线播放| 亚洲va韩国va欧美va精品| 日韩av在线中文| 日韩mv欧美mv国产网站| 久热精品视频在线观看一区| 在线观看 亚洲| 丁香一区二区三区| 夜夜爽99久久国产综合精品女不卡 | 91精品在线视频观看| 99国产精品国产精品久久| 免费观看国产视频在线| 亚洲不卡系列| 亚洲欧美精品一区| 国产精品自拍视频一区| 国产裸体歌舞团一区二区| 亚洲国产一区二区三区在线| www.51av欧美视频| 欧美一区二区三区成人| 日本精品久久久久中文| av电影中文字幕| 亚洲精品合集| 久久久久九九九九| 国产美女免费视频| 国产精品污网站| 99久久久无码国产精品6| 欧美日韩一本| 国模精品视频一区二区| 超碰在线观看av| 亚洲色图在线播放| 天堂在线一区二区三区| 成人综合一区| 国产精品第七十二页| 日韩在线免费看| 五月天激情综合| 中国免费黄色片| 激情偷拍久久| 国产美女精品在线观看| 日韩另类在线| 精品福利一二区| 国产污视频在线观看| 国产成人激情av| 欧美日韩dvd| 亚洲不卡视频| 欧美激情视频播放| 成人午夜福利视频| 亚洲国产日韩a在线播放性色| 无码人妻丰满熟妇啪啪网站| 韩国精品一区二区三区| 国产精品国产亚洲精品看不卡15 | 国产成人精品一区二区三区视频| 777欧美精品| 老熟妇高潮一区二区三区| 久久99国产乱子伦精品免费| 四虎影院一区二区| 视频在线观看免费影院欧美meiju| 欧美肥老妇视频| 秋霞网一区二区| 色综合天天性综合| 免费在线观看a视频| 蜜桃精品视频在线观看| 国产成人亚洲综合无码| 国产精品中文字幕制服诱惑| 91av在线播放视频| 黄色毛片在线观看| 欧美日本乱大交xxxxx| 亚洲色婷婷一区二区三区| 成人免费高清视频在线观看| 日韩欧美国产免费| 日韩欧美一区二区三区在线视频 | 久久男人的天堂| 深夜福利免费在线观看| 欧美日韩在线精品一区二区三区激情 | 国产精品传媒视频| 中文字幕人妻一区| 久久不射中文字幕| 激情五月五月婷婷| 婷婷五月色综合香五月| 国产精品午夜视频| 欧美极品少妇videossex| 国产视频精品xxxx| 国产美女主播在线观看| 精品久久久久久国产| 毛片aaaaaa| 成人免费精品视频| 奇米视频888| 国产精品毛片| 亚洲小说欧美另类激情| 亚洲自拍电影| 亚洲自拍欧美另类| 欧美美女日韩| 欧美激情欧美狂野欧美精品| av在线二区| 日韩av在线导航| 国产日韩免费视频| 一区二区在线看| 欧美巨胸大乳hitomi| jvid福利写真一区二区三区| 天美一区二区三区| 日韩精品国产精品| 一女被多男玩喷潮视频| 伊人成综合网| 午夜视频久久久| 欧美调教在线| 成人三级在线| 成人影院网站ww555久久精品| 国产91精品不卡视频| 色av手机在线| 久久综合国产精品台湾中文娱乐网| 午夜视频福利在线| 日韩欧美国产高清| 在线亚洲欧美日韩| 色综合久久66| 黄色一级片免费看| 亚洲高清免费观看| 欧美精品久久久久性色| 亚洲欧美日韩国产一区二区三区 | 久久久久av| 亚洲国产精品www| 九九热线有精品视频99| 国产美女精品在线观看| 日韩最新av| 91久久久久久久| 国产成人福利夜色影视| 国产精品444| 成人av观看| 欧美一级视频免费在线观看| 24小时免费看片在线观看 | 丝袜美腿诱惑一区二区三区| 91国产中文字幕| heyzo一区| 久久久久久久久网站| 日本大片在线播放| 欧美高清视频免费观看| 日本在线观看大片免费视频| 欧美精品少妇videofree| 九色porny在线| 久久久国产视频| 91香蕉在线观看| 欧美高清videos高潮hd| 国产美女情趣调教h一区二区| 超碰97人人做人人爱少妇| av网站大全在线| 欧美日韩国产二区| 77thz桃花论族在线观看| 韩日精品中文字幕| 中文字幕在线直播| 国产精品电影网站| 国模私拍国内精品国内av| 国产欧美精品在线| 白嫩亚洲一区二区三区| 999在线观看免费大全电视剧| 草草视频在线一区二区| 国产一区高清视频| 在线日韩一区| 亚洲成人蜜桃| 欧美在线国产| 国产白丝袜美女久久久久| 美女爽到呻吟久久久久| 国产三级三级看三级| 国内精品不卡在线| 久久久久久久人妻无码中文字幕爆| hitomi一区二区三区精品| 麻豆精品免费视频| 中文字幕日本乱码精品影院| 欧美激情一区二区视频| 日韩欧美a级成人黄色| 综合久久中文字幕| 欧美一区二区三区的| 午夜黄色小视频| 日韩有码在线电影| 国产在线xxx| 国产精品久久久久久久久| 99精品视频在线免费播放| 精品一区二区三区国产| 欧美亚洲国产一区| www插插插无码免费视频网站| 毛片一区二区| 亚欧精品在线视频| 91丨porny丨在线| 国产免费美女视频| 欧美日韩国产一区在线| 国产又粗又猛又黄| 亚洲精品久久久久久久久久久久 | 免费成人网www| 一区二区三区在线视频看| 一区在线视频| 国产成人美女视频| 久久蜜桃av一区精品变态类天堂| 中文字幕观看av| 91成人国产精品| 亚洲精品国产suv一区| 在线视频中文亚洲| 精精国产xxxx视频在线野外| 国产免费成人av| 欧美人体视频| 波多野结衣 作品| 蜜臀久久99精品久久久画质超高清| 国产伦理在线观看| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 亚洲男女自偷自拍图片另类| 午夜羞羞小视频在线观看| 国产精品国产三级国产aⅴ9色| www国产精品| 中文视频一区视频二区视频三区| 香蕉视频成人在线观看| 国产精品偷伦视频免费观看了| 国产精品白丝在线| 亚洲自拍一区在线观看| 亚洲激情中文字幕| 欧美寡妇性猛交xxx免费| 成人午夜激情网| 波多野结衣在线观看一区二区三区 | 国产日韩在线一区二区三区| 天天做天天爱天天综合网| 日韩毛片在线免费看| 99re66热这里只有精品3直播| 丝袜 亚洲 另类 欧美 重口| 欧美日韩精品久久久| 国产三区四区在线观看| 欧美一级视频在线观看| 卡通动漫精品一区二区三区| 国产中文字幕乱人伦在线观看| 狠狠色综合日日| 懂色av粉嫩av蜜臀av一区二区三区| 欧美性猛交xxxx乱大交3| 四虎在线视频免费观看| 久久久久久国产免费| 风间由美一区二区av101| 日本一级黄视频| 成人免费毛片片v| 日本a在线观看| 亚洲国产精品999| 2018av在线| 久久riav二区三区| 亚洲欧美日本视频在线观看| 最近日本中文字幕| 精品国产精品三级精品av网址| 欧美一级片免费| 国模吧一区二区三区| 丝袜美腿综合| aa免费在线观看| 国产精品午夜在线观看| 亚洲一区中文字幕永久在线| 久久伊人精品一区二区三区| 国产精品视频首页| 奇米777四色影视在线看| 成人高清av在线| 国产亚洲欧美在线精品| 伊人激情综合网| 99精品美女视频在线观看热舞| 欧美少妇在线观看| 丁香婷婷综合色啪| 国产尤物在线视频| 尤物九九久久国产精品的特点| 黄色成人在线观看网站| 中文字幕色呦呦| av亚洲精华国产精华精华| 99超碰在线观看| 丝袜亚洲欧美日韩综合| 国产一区精品二区| 男女超爽视频免费播放| 久久精品人人爽人人爽| 国产精品爽爽久久| 久久露脸国产精品| 欧美女王vk| 熟妇无码乱子成人精品| 亚洲成人免费视频| av资源在线观看免费高清| 97碰碰视频| 日韩国产在线观看一区| 亚洲欧美小视频| 日韩av在线高清| 四虎精品一区二区免费| www.99热这里只有精品| 国产精品全国免费观看高清| www.爱爱.com| 日本精品性网站在线观看| 五月婷婷六月综合| 182在线视频| 欧美日韩精品一区二区三区蜜桃 | av电影在线播放| 色妹子一区二区| 影音先锋男人在线资源| 欧美日韩在线播放一区二区| 国产一区二区在线看| av中文在线播放| 欧美成人免费大片| 国产一区二区精品福利地址| 在线观看你懂的视频| 色狠狠一区二区三区香蕉| 在线观看a级片| 亚洲国产精品久久久久久女王| eeuss鲁片一区二区三区在线观看|