Depuis que je suis passé à Webpack 2, je ne peux pas avoir d’exclusion dans mes règles. Impossible de passer "exclure" dans "options" non plus. Quelle est la bonne façon de le faire maintenant?
Avant:
{
test: /\.js$/,
loader: 'babel-loader',
exclude: /node_modules/,
}
À présent:
{
test: /\.js$/,
use: [{ loader: 'babel-loader' }]
???
}
Toute la config:
const path = require('path');
//const autoprefixer = require('autoprefixer');
const postcssImport = require('postcss-import');
const merge = require('webpack-merge');
const CommonsChunkPlugin = require('webpack/lib/optimize/CommonsChunkPlugin');
const development = require('./dev.config.js');
const demo = require('./demo.config.js');
const test = require('./test.config.js');
const staging = require('./staging.config.js');
const production = require('./prod.config.js');
const TARGET = process.env.npm_lifecycle_event;
const PATHS = {
app: path.join(__dirname, '../src'),
build: path.join(__dirname, '../dist'),
};
process.env.BABEL_ENV = TARGET;
const common = {
entry: [
PATHS.app,
],
output: {
path: PATHS.build,
filename: 'bundle.js',
chunkFilename: '[name]-[hash].js',
},
resolve: {
alias: {
config: path.join(PATHS.app + '/config', process.env.NODE_ENV || 'development'),
soundmanager2: 'soundmanager2/script/soundmanager2-nodebug-jsmin.js',
},
extensions: ['.jsx', '.js', '.json', '.scss'],
modules: ['node_modules', PATHS.app],
},
module: {
rules: [{
test: /bootstrap-sass\/assets\/javascripts\//,
use: [{ loader: 'imports-loader', options: { jQuery: 'jquery' } }]
}, {
test: /\.woff(\?v=\d+\.\d+\.\d+)?$/,
use: [{ loader: 'url-loader', options: { limit: '10000', mimetype: 'application/font-woff' } }]
}, {
test: /\.woff2(\?v=\d+\.\d+\.\d+)?$/,
use: [{ loader: 'url-loader', options: { limit: '10000', mimetype: 'application/font-woff' } }]
}, {
test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/,
use: [{ loader: 'url-loader', options: { limit: '10000', mimetype: 'application/octet-stream' } }]
}, {
test: /\.otf(\?v=\d+\.\d+\.\d+)?$/,
use: [{ loader: 'url-loader', options: { limit: '10000', mimetype: 'application/font-otf' } }]
}, {
test: /\.eot(\?v=\d+\.\d+\.\d+)?$/,
use: [{ loader: 'file-loader' }]
}, {
test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
use: [{ loader: 'url-loader', options: { limit: '10000', mimetype: 'image/svg+xml' } }]
}, {
test: /\.js$/,
//loader: 'babel-loader',
//exclude: /node_modules/,
//use: [{ loader: 'babel-loader', options: { exclude: '/node_modules/' } }]
use: [{ loader: 'babel-loader' }]
//use: [{ loader: 'babel-loader', options: { cacheDirectory: true } }]
}, {
test: /\.png$/,
use: [{ loader: 'file-loader', options: { name: '[name].[ext]' } }]
}, {
test: /\.jpg$/,
use: [{ loader: 'file-loader', options: { name: '[name].[ext]' } }]
}, {
test: /\.gif$/,
use: [{ loader: 'file-loader', options: { name: '[name].[ext]' } }]
}],
},
};
if (TARGET === 'start' || !TARGET) {
module.exports = merge(development, common);
}
if (TARGET === 'build' || !TARGET) {
module.exports = merge(production, common);
}
if (TARGET === 'lint' || !TARGET) {
module.exports = merge(production, common);
}
Juste utiliser
module: {
rules: [
{
test: /\.jsx?$/,
include: [
path.resolve(__dirname, "app")
],
exclude: [
path.resolve(__dirname, "app/demo-files")
]
}
]
}
Pour plus de réf: https://webpack.js.org/configuration/
Voici comment nous avons résolu le même problème
{
test: /\.js$/,
use: [{
loader: 'babel-loader',
options: {
ignore: '/node_modules/'
}
}]
}
La propriété exclude
dans webpack 2
est toujours la même que celle que vous avez montrée mais que vous n'avez pas essayée, cela fonctionne uniquement comme ça
module: {
loaders: [
{
test: /\.jsx?/,
loader: 'babel-loader',
exclude: [/node_modules/]
},
{
test: /\.(jpg|png|gif|eot|woff2|woff|ttf|ico|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: 'url-loader'
},
{
test: /\.(js)$/,
loader: `babel-loader`,
exclude: [/node_modules/]
}]
}
Avez-vous pensé à utiliser externals dans webpack.config.js pour ignorer les répertoires, qui dans votre cas sont les "nœuds_modules"
https://webpack.js.org/guides/author-libraries/#external-limitations