Выбор комплекта webpack dll через режим видимости
В примерах веб-пакета, в частности
- https://github.com/webpack/webpack/tree/master/examples/dll
- https://github.com/webpack/webpack/tree/master/examples/dll-user
Мы можем создать пакет, который зависит от уже готовых библиотек. Приведенные примеры работают как надо. То есть мы сначала перейдем к examples/dll
и беги node build.js
создавать библиотеки. Затем мы перейдем к examples/dll-user
и беги node build.js
создать наши окончательные пакеты, которые ссылаются на ранее связанные библиотеки.
Мой вопрос заключается в следующем. Предположим, что в examples/dll
мы модифицируем файл конфигурации, чтобы он выглядел следующим образом:
var path = require("path");
var webpack = require("../../");
module.exports = {
entry: {
alpha: ["./alpha", "./a", "module"],
beta: ["./beta", "./b", "module"]
},
output: {
path: path.join(__dirname, "js"),
filename: "MyDll.[name].js",
library: "[name]_[hash]"
},
plugins: [
new webpack.DllPlugin({
path: path.join(__dirname, "js", "[name]-manifest.json"),
name: "[name]_[hash]"
})
]
};
То есть мы добавили module
к beta
длл. Теперь мы должны dll, которые имеют module
, Давайте скомпилируем dll и перейдем к dll-user
пример. Здесь мы хотели бы сделать пакет, из которого мы можем выбрать библиотеку, которая будет module
, Попробуем добавить еще одну строку в пример
console.log(require("../dll/alpha"));
console.log(require("../dll/a"));
console.log(require("beta/beta"));
console.log(require("beta/b"));
console.log(require("module"));
console.log(require("beta/module"));
В этом случае я хочу иметь возможность использовать module
который находится в beta
длл. К сожалению, мне не повезло. Это результат, который я получаю после попытки:
jmlopez in ~/Downloads/webpack-master/examples/dll-user$ node build.js
{ [Error: Command failed: /bin/sh -c node ../../bin/webpack.js --display-reasons --display-chunks --display-modules --display-origins --output-public-path "js/" -p ./example.js js/output.js
]
killed: false,
code: 2,
signal: null,
cmd: '/bin/sh -c node ../../bin/webpack.js --display-reasons --display-chunks --display-modules --display-origins --output-public-path "js/" -p ./example.js js/output.js' }
Hash: bd42dda7e56ebfd7cd32
Version: webpack 2.1.0-beta.6
Time: 68ms
Asset Size Chunks Chunk Names
output.js 4.26 kB 0 [emitted] main
chunk {0} output.js (main) 504 bytes [rendered]
> main [7] ./example.js
[7] ./example.js 210 bytes {0} [built] [1 error]
+ 7 hidden modules
ERROR in ./example.js
Module not found: Error: Can't resolve 'beta/module' in '/Users/jmlopez/Downloads/webpack-master/examples/dll-user'
@ ./example.js 8:12-34
{ [Error: Command failed: /bin/sh -c node ../../bin/webpack.js --display-reasons --display-chunks --display-modules --display-origins --output-public-path "js/" --output-pathinfo ./example.js js/output.js
]
killed: false,
code: 2,
signal: null,
cmd: '/bin/sh -c node ../../bin/webpack.js --display-reasons --display-chunks --display-modules --display-origins --output-public-path "js/" --output-pathinfo ./example.js js/output.js' }
Есть ли способ указать библиотеку, которую должен использовать пакет? Я думал scope
вариант в DllReferencePlugin
бы сделать трюк, но это не так.
РЕДАКТИРОВАТЬ: Обратите внимание, что добавление ./a
в бета-версию DLL, а затем с помощью require('beta/a')
в примере работает. Кажется, что веб-пакету сложно понять, что такое node_modules.
1 ответ
У меня была похожая проблема при создании моей DLL с использованием модуля из NPM. Для меня было исправлено указание полного пути из манифеста, а не только имени модуля.
index.js - модуль, использующий DLL
var angular = require('alpha/node_modules/angular-wrapper/lib/index');
require('alpha/node_modules/angular-ui-router/release/angular-ui-router');
Делает требование в проекте, который вы используете DLL, выглядит немного уродливо, но это работает.
webpack.conf - модуль с использованием DLL
new webpack.DllReferencePlugin({
scope: 'alpha',
context: path.join(__dirname,'./node_modules/@company/ng1dll/dist/'),
manifest: require('./node_modules/@company/ng1dll/dist/angular-manifest.json')
})
Примечание: я загружаю свой модуль через частный пакет NPM.
webpack.conf - создание DLL
module.exports = {
entry: {
beta: ["./beta", "./b"],
angular: ['angular-wrapper','angular-ui-router']
},
output: {
path: path.join(__dirname, "dist"),
filename: "[name].js",
library: "[name]_lib"
},
plugins: [
new webpack.DllPlugin({
path: path.join(__dirname, "dist", "[name]-manifest.json"),
name: "[name]_lib"
})
]
}
manifest.json
{
"name": "angular_lib",
"content": {
"./node_modules/angular-wrapper/lib/index.js": 1,
"./node_modules/angular-wrapper/node_modules/angular/index.js": 2,
"./node_modules/angular-wrapper/node_modules/angular/angular.js": 3,
"./node_modules/angular-ui-router/release/angular-ui-router.js": 4
}
}