Я просто понял, что если вы загружаете модули динамически с помощью require.ensure()
, webpack не будет анализировать и блокировать зависимости вместе. Это имеет смысл в некотором роде, что можно утверждать, что веб-пакет не может знать, когда такие модули будут переданы, но можем ли мы заставить webpack выполнять работу в любом случае?
Пример:
app.js
require.ensure([ 'module1.js' ], ( require ) => {
// at some point
require( 'module1.js' );
}, 'Module1');
require.ensure([ 'module2.js' ], ( require ) => {
// at some point
require( 'module2.js' );
}, 'Module2');
module1.js
let io = require( 'socket.io-client' );
module2.js
let io = require( 'socket.io-client' );
Результатом этой компиляции является то, что оба этих модуля получают всю библиотеку socket-io, "связанную" с их кусками. Мое первоначальное ожидание состояло в том, что CommonsChunkPlugin поймает те requires
и поместит эту большую библиотеку в общий фрагмент.
new webpack.optimize.CommonsChunkPlugin( 'common' ),
Не работает. Конечно, я всегда мог "разрешить" эту зависимость вручную, но я надеялся, что веб-пакет каким-то образом может сделать трюк?