国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Webpack 刪除重復(fù)文件的一種優(yōu)化思路

Little_XM / 2520人閱讀

摘要:方法一中的插件就是在階段刪除目標(biāo)文件夾。而想要優(yōu)化該插件,思路就是在階段刪除上一次打包后留下的廢棄文件。

場景

很多人使用webpack打包文件,為了防止瀏覽器緩存,經(jīng)常會這樣設(shè)置:

output: {
        path: path.resolve(__dirname, "./dist"),
        filename: "bundle-[hash:5].js"
    }

給文件hash編碼后加在文件名后面,只要文件修改,都會生成不同的文件名。但是,經(jīng)過多次打包后,往往會遇到這樣的情況:

/dist目錄
|--  bundle-6ece9.js
|--  bundle-b41c3.js
|--  bundle-d303d.js
|--  index.html
|--  style-6ece9.css
|--  style-b41c3.css
|--  style-d303d.css

除了我們的index.html如海邊的礁石一般巍然不動,js、css文件都仿佛拉幫結(jié)派,一茬一茬的。該怎么刪除這些重復(fù)的文件呢?

解決方法一

很多人都推薦使用“clean-webpack-plugin”插件,它能在Webpack編譯之前就刪除所有文件。
優(yōu)點(diǎn):輕量級插件,配置簡單。
缺點(diǎn):在大型項(xiàng)目中,如果只改變了一個文件卻需要刪除其他所有未改變的文件,這些文件數(shù)量不定但對性能還是有一定影響,因此這個插件性能上還有提升空間。

解決方法二

寫過Webpack插件的前端同行,可能知道compiler對象以及相關(guān)的事件鉤子。

在此介紹兩種與本文相關(guān)的鉤子:

compile:開始編譯,在創(chuàng)建 compilation 對象之前;

done:所有的編譯過程已完成。

方法一中的clean-webpack-plugin插件就是在compile階段刪除目標(biāo)文件夾。而想要優(yōu)化該插件,思路就是在done階段刪除上一次打包后留下的廢棄文件。

這時有一個新的問題,在done階段,項(xiàng)目中所有文件都編譯完成,存放在dist文件夾中了,怎么區(qū)分哪些是這次打包產(chǎn)生的新文件,哪些是上一次打包產(chǎn)生的舊文件呢?

這里,再介紹一下compilation對象。

compilation 對象代表了一次單一的版本 webpack 構(gòu)建和生成編譯資源的過程,compilation 對象可以訪問所有的模塊和它們的依賴(大部分是循環(huán)依賴)。

了解compilation對象的概念后,介紹一下它的一個屬性assets。compilation.assets的值是一個對象,其中每一屬性名都是本次打包產(chǎn)生的文件的文件名,打印出來如下:

assets:
{ 
    "bundle-a82da.js":
    {
        existsAt: "...distundle-a82da.js" 
    },
    "style-cc549.css":
        ConcatSource {
            children: [Object],
            existsAt: "...diststyle-cc549.css",
            emitted: true 
        },
    "index.html":
    { 
        source: [Function: source],
        size: [Function: size],
        existsAt: "...distindex.html",
        emitted: true 
    } 
}

因此,通過assets屬性我們就解決了如何區(qū)分本次打包與之前打包產(chǎn)生的文件的問題。只需要遍歷一次dist目錄所有文件,若assets對象中不包含該文件的文件名,那就說明這是“前朝余孽”,直接斬立決。

核心代碼如下:

buildDir = this.buildDir;
compiler.plugin("done", function (compat) {
    //獲取資源數(shù)組對象
    const newlyCreatedAssets = compat.compilation.assets;
    const unlinked = [];
    fs.readdir(path.resolve(buildDir), (err, files) => {
        files.forEach(file => {
            //刪除當(dāng)前打包資源組中不存在的文件
            if (!newlyCreatedAssets[file]) {
                fs.unlink(path.resolve(buildDir + file));
                unlinked.push(file);
            }
        });
        if (unlinked.length > 0) {
            console.log("刪除文件: ", unlinked);
        }
    });
});

使用時只需要傳入目標(biāo)文件夾的目錄url即可,如“./dist/”。

插件

為了方便的使用,我做了一個插件上傳到npm倉庫。

1.初始化npm

npm init

2.安裝模塊

npm i webpack-remove-hashed-files --save-dev

3.修改webpack.config.js

const removeFiles = require("webpack-remove-hashed-files");
//你的打包目標(biāo)文件夾
//your distnation folder
const buildDir = "./dist/";
//……修改plugins
//...modify plugins
plugins:[
    new removeFiles(buildDir)
]

源碼請看我的github倉庫

總結(jié)

我的方法主要是判斷文件是否為本次打包產(chǎn)生來減少文件刪除的時間,但是相比較于clean-webpack-plugin插件,功能還缺少刪除白名單和文件名正則匹配等,這些都會在我有空的時間添加。

另外可能有的同行覺得clean-webpack-plugin不能滿足某些需求,不妨試試我的這款插件,也許有意外之喜。

參考

看清楚真正的 Webpack 插件
如何編寫一個插件?

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/90256.html

相關(guān)文章

  • webpack打包分析與性能優(yōu)化

    摘要:打包分析與性能優(yōu)化背景在去年年末參與的一個項(xiàng)目中,項(xiàng)目技術(shù)棧使用,生產(chǎn)環(huán)境全量構(gòu)建將近三分鐘,項(xiàng)目業(yè)務(wù)模塊多達(dá)數(shù)百個,項(xiàng)目依賴數(shù)千個,并且該項(xiàng)目協(xié)同前后端開發(fā)人員較多,提高構(gòu)建效率,成為了改善團(tuán)隊(duì)開發(fā)效率的關(guān)鍵之一。 webpack打包分析與性能優(yōu)化 背景 在去年年末參與的一個項(xiàng)目中,項(xiàng)目技術(shù)棧使用react+es6+ant-design+webpack+babel,生產(chǎn)環(huán)境全量構(gòu)建將...

    joy968 評論0 收藏0
  • 借助webpack對項(xiàng)目進(jìn)行分析優(yōu)化

    摘要:由于項(xiàng)目的不斷擴(kuò)大,只會影響我們定位功能和問題的速度,因此對冗余文件進(jìn)行清理,是很重要的。我們在項(xiàng)目中使用的,自動將各個圖標(biāo)進(jìn)行。 進(jìn)入公司之后,接手的便是前人留下來的一個大項(xiàng)目。慶幸的是整個項(xiàng)目擁有完善的產(chǎn)品功能文檔,但是由于項(xiàng)目過于龐大,老舊。包含了打包過慢,冗余文件過多等諸多問題。想要快速的解決這些問題,想要完全把功能重構(gòu)一遍的話,成本太高了。一個一個文件來過,時間成本也比較大。...

    Me_Kun 評論0 收藏0
  • 前端面試題大集合:來自真實(shí)大廠的532道面試題(只有題,沒有答案)

    答案自己谷歌或百度找。 一、來源背景 面試題是來自微博@牛客網(wǎng)發(fā)布的真實(shí)大廠前端面經(jīng)題目,我一直在收集題目長期一個一個的記錄下來的,可能會有重復(fù),但基本前端的面試大綱和需要掌握的知識都在其中了,面試題僅做學(xué)習(xí)參考,學(xué)習(xí)者閱后也要用心鉆研其中的原理,重要知識需要系統(tǒng)學(xué)習(xí)、透徹學(xué)習(xí),形成自己的知識鏈。 二、532道前端真實(shí)大廠面試題 express和koa的對比,兩者中間件的原理,koa捕獲異常多種情...

    Kerr1Gan 評論0 收藏0
  • 前端面試題大集合:來自真實(shí)大廠的532道面試題(只有題,沒有答案)

    答案自己谷歌或百度找。 一、來源背景 面試題是來自微博@牛客網(wǎng)發(fā)布的真實(shí)大廠前端面經(jīng)題目,我一直在收集題目長期一個一個的記錄下來的,可能會有重復(fù),但基本前端的面試大綱和需要掌握的知識都在其中了,面試題僅做學(xué)習(xí)參考,學(xué)習(xí)者閱后也要用心鉆研其中的原理,重要知識需要系統(tǒng)學(xué)習(xí)、透徹學(xué)習(xí),形成自己的知識鏈。 二、532道前端真實(shí)大廠面試題 express和koa的對比,兩者中間件的原理,koa捕獲異常多種情...

    lushan 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<