Как правильно установить контекст для веб-пакета DLLPlugin

У меня есть проект, где мой код является каталогом приложений. Оба /app и / node_modules находятся в одном каталоге.

В моем конфиге веб-пакета и контекст, и разрешение root установлены в каталог приложения.

В моих файлах.jsx, независимо от того, какая папка в /app, я могу импортировать любой узел node_module, используя

import {item} из 'module-name'

Теперь я создал новый файл веб-пакета для DLL. Контекст в его DLLPlugin снова устанавливается в каталог приложения. И когда я импортирую dll в веб-пакет проекта, я снова использую путь к приложению как контекст в DllReferencePlugin.

Я не вижу, в чем здесь дело, но app.js по-прежнему содержит весь код DLL. Я уверен, что проблема в неправильном контексте, но я не уверен, с чего начать.

Я не могу понять из документов, потому что это действительно не говорит, что мне нужно делать.

Мои файлы веб-пакетов указаны ниже (оба находятся в каталоге web/webpack/web).

var path = require('path');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var InlineEnviromentVariablesPlugin = require('inline-environment-variables-webpack-plugin');
var CopyWebpackPlugin = require('copy-webpack-plugin');
var webpack = require('webpack');
var HappyPack = require('happypack');
var happyThreadPool = HappyPack.ThreadPool({ size: 4 });


var assetsPath = path.join(__dirname, '..', '..', 'public');
var publicPath = '/';

var babelrc = {
      'presets': ['es2015', 'react', 'stage-0'],
      'plugins': [
        'transform-decorators-legacy',
        'transform-object-assign',
        'transform-object-entries',
        'transform-react-remove-prop-types',
        'transform-react-constant-elements'
      ]
    };



var commonLoaders = [
  {
    test: /\.js$|\.jsx$/,
    loader: 'happypack/loader?id=babel',
    exclude: [
      path.join(__dirname, '..', '..', '..', 'node_modules'),
      path.join(__dirname, '..', '..', '..', 'node_modules', 'react-d3-shape', '.babelrc')
    ],
    include: [
      path.join(__dirname, '..', '..', '..', 'app'),
      path.join(__dirname, '..', '..', '..', 'node_modules', 'react-d3-shape', 'lib', 'components', 'pie.js')
    ]
  },
  { test: /\.json$/, loader: 'happypack/loader?id=json' },
  {
    test: /\.(png|jpg|jpeg|gif|svg|eot|ttf|woff|woff2)$/,
    loader: 'url',
    query: {
        name: '[hash].[ext]',
        limit: 10000,
    }
  },
  {
    test: /\.css$/, exclude: ['/vendors/'],
    loader: ExtractTextPlugin.extract('style-loader', 'css-loader?module&importLoaders=1&localIdentName=[name]--[local]-[hash:base64:5]!postcss-loader')
  }
];


function createHappyPlugin(id, loaders) {
  return new HappyPack({
    id: id,
    loaders: loaders,
    threadPool: happyThreadPool,
    cache: true,
    verbose: true,
  });
}


var postCSSConfig = function() {
  return [
    require('postcss-import')(),
    require('postcss-mixins')(),
    require('postcss-custom-media')(),
    require('postcss-simple-vars')(),
    require('postcss-nested')(),
    require('autoprefixer')({
      browsers: ['last 2 versions', 'IE > 8']
    }),
    require('postcss-reporter')({
      clearMessages: true
    })
  ];
};

module.exports = [
  {
    name: 'browser',
    context: path.join(__dirname, '..', '..', '..', 'app'),
    entry: {
      app: './client'
    },
    output: {
      path: assetsPath,
      filename: '[name].js',
      publicPath: publicPath
    },

    module: {
      loaders: commonLoaders
    },
    resolve: {
      root: [path.join(__dirname, '..', '..', '..', 'app')],
      extensions: ['', '.js', '.jsx', '.css']
    },
    plugins: [
        new ExtractTextPlugin('styles/bundled-modules.css'),
        new CopyWebpackPlugin([
            { from: 'fonts/', to: 'fonts/' },
            { from: '_web/css/global/fonts.css', to: 'styles/fonts.css' },
            { from: '_web/css/vendors', to: 'styles/vendors' },
        ]),
        new webpack.DllReferencePlugin({
          context: path.join(__dirname, '..', '..', '..'),
          manifest: path.join(assetsPath, "vendor-manifest.json"),
          content: ['./client.jsx']
        }),
        new webpack.DefinePlugin({
          __DEVCLIENT__: false,
          __DEVSERVER__: false,
          __PLATFORM_WEB__: true,
          __PLATFORM_IOS__: false
        }),
        new InlineEnviromentVariablesPlugin({ NODE_ENV: 'production' }),
        createHappyPlugin('babel', ['babel-loader?'+JSON.stringify(babelrc)]),
        createHappyPlugin('json', ['json-loader'])
    ],
    postcss: postCSSConfig
  }, {
    name: 'server-side rendering',
    context: path.join(__dirname, '..', '..', '..', 'app'),
    entry: {
      server: './server'
    },
    target: 'node',
    output: {
      path: assetsPath,
      filename: 'server.js',
      publicPath: publicPath,
      libraryTarget: 'commonjs2'
    },
    module: {
      loaders: commonLoaders
    },
    resolve: {
      root: [path.join(__dirname, '..', '..', '..', 'app')],
      extensions: ['', '.js', '.jsx', '.css']
    },
    plugins: [
        new webpack.optimize.OccurenceOrderPlugin(),
        new ExtractTextPlugin('styles/bundled-modules.css'),
        new CopyWebpackPlugin([
          { from: 'images/', to: 'images/' },
          { from: 'fonts/', to: 'fonts/' },
          { from: '_web/css/global/fonts.css', to: 'styles/fonts.css' },
        ]),
        new webpack.DefinePlugin({
          __DEVCLIENT__: false,
          __DEVSERVER__: false,
          __PLATFORM_WEB__: true,
          __PLATFORM_IOS__: false
        }),
        new InlineEnviromentVariablesPlugin({ NODE_ENV: 'production' }),
        createHappyPlugin('babel', ['babel-loader?'+JSON.stringify(babelrc)]),
        createHappyPlugin('json', ['json-loader'])
    ],
    postcss: postCSSConfig
  }
];

var path = require('path');
var webpack = require('webpack')

var assetsPath = path.join(__dirname, '..', '..', 'public');

module.exports = {
  entry: {
    vendor: [
             'classnames',
             'd3',
             'devour-client',
             'jquery',
             'moment',
             'nuka-carousel',
             'passport',
             'passport-google-oauth',
             'react',
             'react-addons',
             'react-autosuggest',
             'react-cookie',
             'react-d3-basic',
             'react-d3-core',
             'react-dom',
             'react-helmet',
             'react-image-gallery',
             'react-intercom',
             'react-markdown',
             'react-masonry-component',
             'react-modal',
             'react-paginate',
             'react-places-autocomplete',
             'react-redux',
             'react-router',
             'react-router-redux',
             'react-router-scroll',
             'react-slider',
             'react-transform-hmr',
             'react-waypoint',
             'redux',
             'redux-logger',
             'redux-mock-store',
             'redux-persist',
             'redux-responsive',
             'redux-thunk'
    ]
  },
  module: {
    loaders: [{ test: /\.json$/, loader: 'json-loader' }]
  },
  output: {
    path: assetsPath,
    filename: '[name].js',
    library: '[name]',
  },

  plugins: [
    new webpack.DllPlugin({
      path: path.join(assetsPath, "[name]-manifest.json"),
      context: path.join(__dirname, '..', '..', '..', 'app'),
      name: '[name]'
    }),
  ],
}

1 ответ

Убедитесь, что DllReferencePlugin имеет то же самое context а также name как файл, создаваемый DllPluginи что это дает фактическое manifest объект (как описывают документы) requireв файле манифеста:

new DllReferencePlugin({  
   context: path.join(__dirname, '..', '..', '..', 'app'),
   manifest: require(path.join(assetsPath, "vendor-manifest.json")),
   name: './vendor.js'
}),
Другие вопросы по тегам