Webpack babel es6给出了错误的反应路由器1.0"模块未找到"?

时间:2015-11-29 03:19:14

标签: reactjs ecmascript-6 webpack

我在使用react-router时遇到以下错误,它所引用的错误看起来像是在我的应用程序代码之外,但是反应路由器库本身:

ERROR in ./~/react-router/lib/Router.js
Module not found: Error: Cannot resolve module 'history/lib/createHashHistory' in /Users/kmartinez/apache/www/reactroutesample/node_modules/react-router/lib
 @ ./~/react-router/lib/Router.js 25:35-75

ERROR in ./~/react-router/lib/useRoutes.js
Module not found: Error: Cannot resolve module 'history/lib/Actions' in /Users/kmartinez/apache/www/reactroutesample/node_modules/react-router/lib
 @ ./~/react-router/lib/useRoutes.js 15:25-55

ERROR in ./~/react-router/lib/useRoutes.js
Module not found: Error: Cannot resolve module 'history/lib/useQueries' in /Users/kmartinez/apache/www/reactroutesample/node_modules/react-router/lib
 @ ./~/react-router/lib/useRoutes.js 17:28-61

ERROR in ./~/react-router/lib/match.js
Module not found: Error: Cannot resolve module 'history/lib/createMemoryHistory' in /Users/kmartinez/apache/www/reactroutesample/node_modules/react-router/lib
 @ ./~/react-router/lib/match.js 13:37-79

ERROR in ./~/react-router/lib/match.js
Module not found: Error: Cannot resolve module 'history/lib/useBasename' in /Users/kmartinez/apache/www/reactroutesample/node_modules/react-router/lib
 @ ./~/react-router/lib/match.js 17:29-63

当我使用" JSX"时,一切正常。语法,但只要我加入" babel-es2015-preset"进入我的webpack并想开始切换到ES6 / ES2015,我得到了上面的错误。是什么给了什么?

module.exports = {
    entry: './app/App.js',
    output: {
        filename: 'public/bundle.js',
    },
    module: {
        loaders: [
            {
                test: /\.jsx?$/,
                exclude: /(node_modules|bower_components)/,
                loader: 'babel',
                query: {
                    presets: ['es2015','react']
                }

            }
        ]
    }
}

我正在使用反应路由器,反应和babel的最新版本。 Package.json包含以下内容:

    "babel-core": "^6.2.1",
    "babel-loader": "^6.2.0",
    "babel-preset-es2015": "^6.1.18",
    "react-dom": "^0.14.3",
    "webpack": "^1.12.9",
"react": "^0.14.3",
    "react-dom": "^0.14.3",
    "react-router": "^1.0.0",
"babel-preset-react": "^6.1.18",

我当前的代码在某些文件中包含JSX语法,在其他文件中包含ES6 / ES2015导入语法。如果有更好的加载器集或者我错误配置了webpack,请提供建议!

我的App.js中唯一的行是:

import React from 'react';
import ReactDOM from 'react-dom';
import {Router, Route} from 'react-router';

如果我注释掉第三行,那么首先提到的错误就会消失,但我需要使用react-router!

3 个答案:

答案 0 :(得分:24)

我假设你使用npm 3+。并且React Router的安装文档声明:

  

请注意,您还需要安装历史记录包,因为它是React Router的对等依赖项,并且不会在npm 3 +中自动为您安装。

运行npm install history,你应该很好。

答案 1 :(得分:0)

错误告诉您问题:

  

无法解析模块' history / lib / createHashHistory'

react-router取决于history模块here,似乎您没有安装它。

可能最容易

rm -rf node_modules
npm install

确保正确安装所有依赖项。

答案 2 :(得分:-1)

这是一个节点错误。通过进入project/node_modules/react-router/并运行npm install history来解决此问题。