首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Webpack升级-模块未找到:无法解决node_modules

Webpack升级-模块未找到:无法解决node_modules
EN

Stack Overflow用户
提问于 2017-10-19 20:39:51
回答 1查看 23.5K关注 0票数 6

目前,我正在从Webpack 1升级到2,然后升级到3。在这次升级中,我一直按照1 => 22 => 3的说明执行迁移指令。

我遇到的问题是,在我的node_modules中安装的包似乎都没有在client/app/bundles中的代码中得到解决。对于所有node_modules,我得到的错误是以下结构:

未找到./node_node/alt/lib/store/StoreMixin.js\xin.js中的错误:错误:无法解析“client/node_ Module /alt/lib/store”中的“发射器”

我的理论是,在某些地方,file-loaderexpose-loaderimports-loader版本不匹配,因为如果没有适当的版本,模块就不会被导入。我已经确保所有module.rules都有以-loader模式结尾的加载器。yarn install也是成功的,没有错误。

我的依赖项和Webpack配置如下:

Package.json

代码语言:javascript
复制
"dependencies": {
    "ajv": "^5.1.5",
    "alt": "^0.17.8",
    "alt-container": "^1.0.2",
    "autoprefixer": "^6.4.0",
    "axios": "^0.7.0",
    "babel-cli": "^6.10.1",
    "babel-core": "^6.3.26",
    "babel-loader": "^7.1.2",
    "babel-plugin-syntax-decorators": "^6.3.13",
    "babel-polyfill": "^6.3.14",
    "babel-preset-es2015": "^6.3.13",
    "babel-preset-react": "^6.3.13",
    "babel-preset-stage-0": "^6.3.13",
    "babel-types": "^6.4.5",
    "body-parser": "^1.14.1",
    "chai": "^3.4.1",
    "chai-enzyme": "^0.6.1",
    "css-loader": "^0.23.1",
    "enzyme": "^2.5.0",
    "es5-shim": "^4.1.14",
    "es6-promise": "^3.0.2",
    "expose-loader": "^0.7.1",
    "fbjs": "^0.8.16",
    "file-loader": "^1.1.5",
    "fixed-data-table-2": "^0.7.11",
    "immutable": "^3.7.5",
    "imports-loader": "^0.6.5",
    "jade": "^1.11.0",
    "jquery": "^2.1.4",
    "jquery-ujs": "^1.1.0-1",
    "jsdom": "^7.0.2",
    "loader-utils": "^0.2.11",
    "lodash": "^4.11.1",
    "lodash-uuid": "^0.0.3",
    "mocha-jsdom": "^1.0.0",
    "moment": "^2.11.1",
    "postcss-loader": "^0.10.1",
    "react": "^15.6.1",
    "react-addons-test-utils": "15.4.0",
    "react-bootstrap": "^0.30.3",
    "react-dnd": "^2.5.4",
    "react-dnd-html5-backend": "^2.0.0",
    "react-dnd-test-backend": "^1.0.0",
    "react-dom": "^15.6.1",
    "react-fa": "^4.1.2",
    "react-height": "^3.0.0",
    "react-json-tree": "^0.10.9",
    "react-on-rails": "10.0.0",
    "react-onclickoutside": "^5.7.0",
    "react-overlays": "^0.6.2",
    "react-select": "^1.0.0-rc.3",
    "react-table": "^6.0.5",
    "react-textarea-autosize": "^4.0.5",
    "sass-loader": "^6.0.6",
    "sinon": "^1.17.2",
    "sinon-chai": "^2.8.0",
    "sleep": "^3.0.0",
    "source-map": "^0.6.1",
    "uglify-js": "^2.8.29",
    "url-loader": "^0.5.6",
    "webpack": "^3.1.0",
    "webpack-dev-server": "^2.9.2"
  },
  "devDependencies": {
    "babel-eslint": "^6.1.0",
    "babel-istanbul": "^0.11.0",
    "babel-plugin-react-transform": "^2.0.0",
    "bootstrap-loader": "^2.0.0",
    "bootstrap-sass": "^3.3.6",
    "eslint": "^3.3.0",
    "eslint-config-airbnb": "^10.0.1",
    "eslint-config-shakacode": "^0.0.1",
    "eslint-plugin-import": "^1.13.0",
    "eslint-plugin-jsx-a11y": "^2.1.0",
    "eslint-plugin-react": "^6.0.0",
    "esprima-fb": "^15001.1001.0-dev-harmony-fb",
    "express": "^4.13.3",
    "extract-text-webpack-plugin": "3.0.1",
    "image-webpack-loader": "^3.1.0",
    "mocha": "^2.3.3",
    "mocha-jenkins-reporter": "^0.1.9",
    "mocha-jsdom": "^1.0.0",
    "node-sass": "4.0.0",
    "react-loadable": "^5.3.0",
    "react-transform-hmr": "^1.0.1",
    "resolve-url-loader": "^1.4.3",
    "style-loader": "^0.19.0",
    "stylelint": "^7.1.0",
    "stylelint-config-standard": "^12.0.0"
}

文件结构

代码语言:javascript
复制
webpack.client.rails.config.js
app
    /assets
        /javascripts
            /generated
            -- app-bundle.js
            -- vendor-bundle.js
client
    /app
        /bundles
            /[APP ENTRY]...
    /node_modules
    webpack.client.rails.config.js
    webpack.client.base.config.js

webpack.client.rails.config.js

代码语言:javascript
复制
const webpack = require('webpack');
const path = require('path');
const config = require('./webpack.client.base.config');

const devBuild = process.env.NODE_ENV !== 'production';

const autoprefixer = require('autoprefixer');

config.output = {
  filename: '[name]-bundle.js',
  path: path.resolve('../app/assets/javascripts/generated'),
  publicPath: path.resolve('/assets/generated/'),
};

config.entry.vendor.unshift(
  'es5-shim/es5-shim',
  'es5-shim/es5-sham'
);

config.entry.vendor.push('jquery-ujs');

config.module.rules.push(
  {
    test: /\.jsx?$/,
    loader: 'babel-loader',
    exclude: /node_modules/,
  },
  {
    test: require.resolve('react'),
    loader: 'imports-loader?shim=es5-shim/es5-shim&sham=es5-shim/es5-sham',
  },
  {
    test: require.resolve('jquery-ujs'),
    loader: 'imports-loader?jQuery=jquery',
  },
  {
    test: /\.css$/,
    loader: 'style-loader!css-loader',
  },
  {
    test: /\.scss$/,
    use: [
      'style-loader',
      'css-loader',
      {
        loader: 'postcss-loader',
        options: {
          plugins: function() {
            return [autoprefixer]
          }
        }
      },
      'sass-loader',
    ],
    exclude: /assets\/stylesheets\/common\/packages\/DocumentEditor/,
  },
  {
    test: /\.scss$/,
    use: [
      'style-loader?{"singleton":true,"attrs":{"id":"document-content-stylesheet"}}',
      'css-loader',
      {
        loader: 'postcss-loader',
        options: {
          plugins: function() {
            return [autoprefixer]
          }
        }
      },
      'sass-loader',
    ],
    include: /assets\/stylesheets\/common\/packages\/DocumentEditor/,
  },
  {
    test: /\.(ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
    loader: 'file-loader',
  },
  {
    test: /\.woff(2)?(\?v=[0-9]\.[0-9]\.[0-9])?$/,
    loader: 'url-loader?limit=10000&mimetype=application/font-woff',
  }
);

module.exports = config;

if (devBuild) {
  console.log('Webpack dev build for Rails'); // eslint-disable-line no-console
  module.exports.devtool = 'eval-source-map';
} else {
  config.plugins.push(
    new webpack.optimize.DedupePlugin()
  );
  console.log('Webpack production build for Rails'); // eslint-disable-line no-console
}

webpack.client.base.config.js

代码语言:javascript
复制
const webpack = require('webpack');
const path = require('path');
const aliases = require('./aliases');

const devBuild = process.env.NODE_ENV !== 'production';
const nodeEnv = devBuild ? 'development' : 'production';

module.exports = {

  context: __dirname,
  entry: {

    vendor: [
      'babel-polyfill',
      'jquery',
    ],

    app: [
      './app/bundles/BundleOne/startup/clientRegistration',
      './app/bundles/BundleTwo/startup/clientRegistration',
      './app/bundles/BundleThree/startup/clientRegistration',
      './app/bundles/BundleFour/startup/clientRegistration',
      './app/bundles/BundleFive/startup/clientRegistration',
      './app/bundles/BundleSix/startup/clientRegistration',
      './app/bundles/BundleSeven/startup/clientRegistration',
    ],
  },
  resolve: {
    modules: [
      path.resolve('./app/bundles'),
    ],
    extensions: ['.js', '.jsx'],
    alias: aliases,
  },
  plugins: [
    new webpack.DefinePlugin({
      'process.env': {
        NODE_ENV: JSON.stringify(nodeEnv),
      },
    }),

    new webpack.optimize.CommonsChunkPlugin({
      name: 'vendor',
      filename: 'vendor-bundle.js',
      minChunks: Infinity,
    }),
  ],
  module: {
    rules: [
      { test: require.resolve('jquery'), loader: 'expose-loader?jQuery' },
      { test: require.resolve('jquery'), loader: 'expose-loader?$' },
    ],
  },
};
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-10-20 07:06:47

我认为问题在于当您在webpack.client.base.config.js中设置以下选项时

代码语言:javascript
复制
resolve: {
  modules: [
    path.resolve('./app/bundles'),
  ],
  extensions: ['.js', '.jsx'],
  alias: aliases,
},

覆盖默认的“解析模块”选项,该选项是

resolve: { modules: ['node_modules'] }

如果您希望webpack在您的bundle文件夹以及节点模块文件夹中找到模块,您应该尝试如下所示:

代码语言:javascript
复制
resolve: {
  modules: [
    path.resolve('./app/bundles'),
    'node_modules'
  ],
  extensions: ['.js', '.jsx'],
  alias: aliases,
},

编辑:另外,如果你想升级到webpack 2,你不应该看webpack 1的文档,而应该看最新的文件

票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46838540

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档