Cómo cargar todos los archivos en un directorio usando el paquete web sin requerir declaraciones

Tengo una gran cantidad de archivos Javascript divididos en 4 subdirectorios en mi aplicación. En gruñido los agarro a todos y los compilo en un solo archivo. Estos archivos no tienen una función module.exports.

Quiero usar el paquete web y dividirlo en 4 partes. No quiero ingresar manualmente y requerir todos mis archivos.

Me gustaría crear un complemento que en la comstackción recorra los árboles de directorios, luego tome todos los nombres de archivos .js y las rutas, luego requiera todos los archivos en los subdirectorios y los agregue a la salida.

Quiero que todos los archivos de cada directorio se compilen en un módulo que podría requerir de mi archivo de punto de entrada, o incluir en los activos que menciona http://webpack.github.io/docs/plugins.html .

Al agregar un nuevo archivo, solo deseo colocarlo en el directorio correcto y saber que se incluirá.

¿Hay alguna manera de hacer esto con un paquete web o un complemento que alguien haya escrito para hacer esto?

Esto es lo que hice para lograr esto:

function requireAll(r) { r.keys().forEach(r); } requireAll(require.context('./modules/', true, /\.js$/)); 

En mi archivo de aplicación terminé poniendo el requerimiento

 require.context( "./common", // context folder true, // include subdirectories /.*/ // RegExp )("./" + expr + "") 

cortesía de esta publicación: https://github.com/webpack/webpack/issues/118

Ahora está agregando todos mis archivos. Tengo un cargador para html y css y parece funcionar muy bien.

¿Qué tal un mapa de todos los archivos en una carpeta?

 // { // './image1.png': '', // './image2.png': '', // } 

Hacer esto:

 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, /.*/)); 

esto funciona para mí:

 function requireAll(r) { r.keys().forEach(r); } requireAll(require.context('./js/', true, /\.js$/)); 

NOTA: esto puede requerir archivos .js en subdirectorios de ./js/ recursivamente.

Ejemplo de cómo obtener un mapa de todas las imágenes en la carpeta actual.

 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));