В моем приложении у меня есть большое количество файлов javascript, разделенных на 4 подкаталога. Я хватаю их все и компилирую в один файл. Эти файлы не имеют функции module.exports.
Я хочу использовать веб-пакет и разбить его на 4 части. Я не хочу вручную заходить и требовать все свои файлы.
Я хотел бы создать плагин, который при компиляции просматривает деревья каталогов, затем захватывает все имена и пути файлов .js, затем запрашивает все файлы в подкаталогах и добавляет их к выходным данным.
Я хочу, чтобы все файлы в каждом каталоге были скомпилированы в модуль, который я мог бы затем запросить из моего файла точки входа или включить в ресурсы, упомянутые http://webpack.github.io/docs/plugins.html .
При добавлении нового файла я просто хочу поместить его в правильный каталог и знать, что он будет включен.
Есть ли способ сделать это с помощью webpack или плагина, который кто-то написал для этого?
источник
image-size-loader
для всех изображений, чтобы создавать заполнители с правильными пропорциями.loaders: [ { test: /\.json$/, loader: 'json' } ]
.{ test: /\.json$/, loader: 'json' }
добавляет загрузчик json для файлов .json, если вы установили загрузчик.require.context(...)
вас (например, если вы пытаетесь потребовать все в нескольких папках), webpack выдаст предупреждение. Аргументыrequire.context
должны быть константами времени компиляции.require-context
это оболочкаwebpack
, и ее образец взят изwebpack
документации на webpack.js.org/guides/dependency-management/#context-module-api, который был добавлен в 2016 году (в github.com/webpack/ webpack.js.org/commit/… ), также после того, как я написал свой ответ ... Может быть, мой ответ повлиял на авторов webpack. Обратите внимание, что они расширили его, чтобы иметь кеш.В моем файле приложения я поставил требование
require.context( "./common", // context folder true, // include subdirectories /.*/ // RegExp )("./" + expr + "")
любезно предоставлено этим сообщением: https://github.com/webpack/webpack/issues/118
Сейчас добавляются все мои файлы. У меня есть загрузчик для html и css, и он, кажется, отлично работает.
источник
expr
в этом примере?expr
- это путь к одному файлу в папке контекста. так что, если вам нужно сделать это не только для того, чтобы требовать все файлы html, это полезно. webpack.github.io/docs/context.html#context-module-apiexpr
здесь делает аргумент based, даже после просмотра документации webpack. что означает «сделать это не только для того, чтобы требовать все файлы html»? спасибоexpr
здесь имеется в видуКак насчет карты всех файлов в папке?
// { // './image1.png': '', // './image2.png': '', // }
Сделай это:
const allFiles = (ctx => { let keys = ctx.keys(); let values = keys.map(ctx); return keys.reduce((o, k, i) => { o[k] = values[i]; return o; }, {}); })(require.context('./path/to/folder', true, /.*/));
источник
Пример того, как получить карту всех изображений в текущей папке.
const IMAGES_REGEX = /\.(png|gif|ico|jpg|jpeg)$/; function mapFiles(context) { const keys = context.keys(); const values = keys.map(context); return keys.reduce((accumulator, key, index) => ({ ...accumulator, [key]: values[index], }), {}); } const allImages = mapFiles(require.context('./', true, IMAGES_REGEX));
источник
Все заслуги @splintor (спасибо).
Но это моя производная версия.
Льготы:
{module_name: exports_obj}
объект.Код (исходная версия):
function requireAll(r) { return Object.fromEntries( r.keys().map(function(mpath, ...args) { const result = r(mpath, ...args); const name = mpath .replace(/(?:^[.\/]*\/|\.[^.]+$)/g, '') // Trim .replace(/\//g, '_') // Relace '/'s by '_'s ; return [name, result]; }) ); }; const allModules = requireAll(require.context( // Any kind of variables cannot be used here '@models' // (Webpack based) path , true // Use subdirectories , /\.js$/ // File name pattern ));
Пример:
Пример вывода для возможных
console.log(allModules);
:{ main: { title: 'Webpack Express Playground' }, views_home: { greeting: 'Welcome to Something!!', title: 'Webpack Express Playground' } }
Дерево каталогов:
Код (Глубокая версия):
function jsonSet(target, path, value) { let current = target; path = [...path]; // Detach const item = path.pop(); path.forEach(function(key) { (current[key] || (current[key] = {})); current = current[key]; }); current[item] = value; return target; }; function requireAll(r) { const gather = {}; r.keys().forEach(function(mpath, ...args) { const result = r(mpath, ...args); const path = mpath .replace(/(?:^[.\/]*\/|\.[^.]+$)/g, '') // Trim .split('/') ; jsonSet(gather, path, result); }); return gather; }; const models = requireAll(require.context( // Any kind of variables cannot be used here '@models' // (Webpack based) path , true // Use subdirectories , /\.js$/ // File name pattern ));
Пример:
Результат предыдущего примера с использованием этой версии:
{ main: { title: 'Webpack Express Playground' }, views: { home: { greeting: 'Welcome to Something!!', title: 'Webpack Express Playground' } } }
источник
это работает для меня:
function requireAll(r) { r.keys().forEach(r); } requireAll(require.context('./js/', true, /\.js$/));
ПРИМЕЧАНИЕ: для этого могут потребоваться файлы .js в подкаталогах ./js/ рекурсивно.
источник