cache-loader

Caches the result of following loaders on disk

Github星跟蹤圖

npm
node
deps
tests
coverage
chat
size

cache-loader

The cache-loader allow to Caches the result of following loaders on disk (default) or in the database.

Getting Started

To begin, you'll need to install cache-loader:

npm install --save-dev cache-loader

Add this loader in front of other (expensive) loaders to cache the result on disk.

webpack.config.js

module.exports = {
  module: {
    rules: [
      {
        test: /\.ext$/,
        use: ['cache-loader', ...loaders],
        include: path.resolve('src'),
      },
    ],
  },
};

⚠️ Note that there is an overhead for saving the reading and saving the cache file, so only use this loader to cache expensive loaders.

Options, Name, Type, n Default, Description, :-------------------:, :----------------------------------------------:, :-----------------------------------------------------:, :---------------------------------------------------------------------------------------------------------------------------------------------------------------------, cacheContext, {String}, undefined, Allows you to override the default cache context in order to generate the cache relatively to a path. By default it will use absolute paths, cacheKey, {Function(options, request) -> {String}}, undefined, Allows you to override default cache key generator, cacheDirectory, {String}, findCacheDir({ name: 'cache-loader' }) or os.tmpdir(), Provide a cache directory where cache items should be stored (used for default read/write implementation), cacheIdentifier, {String}, cache-loader:{version} {process.env.NODE_ENV}, Provide an invalidation identifier which is used to generate the hashes. You can use it for extra dependencies of loaders (used for default read/write implementation), compare, {Function(stats, dep) -> {Boolean}}, undefined, Allows you to override default comparison function between the cached dependency and the one is being read. Return true to use the cached resource, precision, {Number}, 0, Round mtime by this number of milliseconds both for stats and dep before passing those params to the comparing function, read, {Function(cacheKey, callback) -> {void}}, undefined, Allows you to override default read cache data from file, readOnly, {Boolean}, false, Allows you to override default value and make the cache read only (useful for some environments where you don't want the cache to be updated, only read from it), write, {Function(cacheKey, data, callback) -> {void}}, undefined, Allows you to override default write cache data to file (e.g. Redis, memcached), ## Examples

Basic

webpack.config.js

module.exports = {
  module: {
    rules: [
      {
        test: /\.js$/,
        use: ['cache-loader', 'babel-loader'],
        include: path.resolve('src'),
      },
    ],
  },
};

Database Integration

webpack.config.js

// Or different database client - memcached, mongodb, ...
const redis = require('redis');
const crypto = require('crypto');

// ...
// connect to client
// ...

const BUILD_CACHE_TIMEOUT = 24 * 3600; // 1 day

function digest(str) {
  return crypto
    .createHash('md5')
    .update(str)
    .digest('hex');
}

// Generate own cache key
function cacheKey(options, request) {
  return `build:cache:${digest(request)}`;
}

// Read data from database and parse them
function read(key, callback) {
  client.get(key, (err, result) => {
    if (err) {
      return callback(err);
    }

    if (!result) {
      return callback(new Error(`Key ${key} not found`));
    }

    try {
      let data = JSON.parse(result);
      callback(null, data);
    } catch (e) {
      callback(e);
    }
  });
}

// Write data to database under cacheKey
function write(key, data, callback) {
  client.set(key, JSON.stringify(data), 'EX', BUILD_CACHE_TIMEOUT, callback);
}

module.exports = {
  module: {
    rules: [
      {
        test: /\.js$/,
        use: [
          {
            loader: 'cache-loader',
            options: {
              cacheKey,
              read,
              write,
            },
          },
          'babel-loader',
        ],
        include: path.resolve('src'),
      },
    ],
  },
};

Contributing

Please take a moment to read our contributing guidelines if you haven't yet done so.

CONTRIBUTING

License

MIT

主要指標

概覽
名稱與所有者webpack-contrib/cache-loader
主編程語言JavaScript
編程語言JavaScript (語言數: 1)
平台
許可證MIT License
所有者活动
創建於2017-04-26 08:59:47
推送於2020-10-27 14:38:24
最后一次提交2020-10-27 17:38:23
發布數17
最新版本名稱v4.1.0 (發布於 2019-07-18 16:18:41)
第一版名稱v1.0.1 (發布於 2017-04-26 11:07:01)
用户参与
星數640
關注者數14
派生數51
提交數65
已啟用問題?
問題數43
打開的問題數15
拉請求數41
打開的拉請求數11
關閉的拉請求數17
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?