Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/webpack/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Reactjs 使用webpack、react、react dom时无法分析文件_Reactjs_Webpack_React Router_Babeljs - Fatal编程技术网

Reactjs 使用webpack、react、react dom时无法分析文件

Reactjs 使用webpack、react、react dom时无法分析文件,reactjs,webpack,react-router,babeljs,Reactjs,Webpack,React Router,Babeljs,在过去的几个小时里,我一直在努力解决这个问题,但我仍然无法解决这个问题。我想我已经尝试了几乎所有的实现,但是我仍然没有让它工作 错误消息 ERROR in ./app/main.js Module parse failed: /Users/DS/Code/tryouts/react-boilerplate/app/main.js Unexpected token (5:16) You may need an appropriate loader to handle this file type.

在过去的几个小时里,我一直在努力解决这个问题,但我仍然无法解决这个问题。我想我已经尝试了几乎所有的实现,但是我仍然没有让它工作

错误消息

ERROR in ./app/main.js
Module parse failed: /Users/DS/Code/tryouts/react-boilerplate/app/main.js Unexpected token (5:16)
You may need an appropriate loader to handle this file type.
SyntaxError: Unexpected token (5:16)
    at Parser.pp.raise (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:923:13)
    at Parser.pp.unexpected (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:1490:8)
    at Parser.pp.parseExprAtom (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:333:12)
    at Parser.pp.parseExprSubscripts (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:228:19)
    at Parser.pp.parseMaybeUnary (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:207:17)
    at Parser.pp.parseExprOps (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:154:19)
    at Parser.pp.parseMaybeConditional (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:136:19)
    at Parser.pp.parseMaybeAssign (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:112:19)
    at Parser.pp.parseExprList (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:660:23)
    at Parser.pp.parseSubscripts (/Users/DS/Code/tryouts/react-boilerplate/node_modules/webpack/node_modules/acorn/dist/acorn.js:252:29)
这是我的webpack.config.js

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

var config = {
  context: path.join(__dirname, 'app'),
  entry: [
    './main.js',
  ],
  output: {
    path: path.join(__dirname, 'www'),
    filename: 'bundle.js',
  },
  resolve: {
    extensions: ['', '.js', '.jsx']
  },
  module: {
    loaders: [
      {
        test: /src\/.+.js$/,
        exclude: /node_modules/,
        // loaders: ['babel', 'babel-loader?presets[]=react,presets[]=es2015'],
        loaders: ['babel', 'babel-loader']
      }
    ],
  },
  resolveLoader: {
    root: [
      path.join(__dirname, 'node_modules'),
    ],
  },
  resolve: {
    root: [
      path.join(__dirname, 'node_modules')
    ],
  },
};
module.exports = config;
import React from 'react';
import ReactDOM from 'react-dom';
import App from './App';

ReactDOM.render(<App />, document.getElementById('app')); <= OFFENDING LINE
import React from 'react';
import { Router, Route, Link, IndexRoute, hashHistory, browserHistory } from 'react-router';
import Counter from './Counter';

export default class App extends React.Component {
    render() {
        return (

            <div>
                <Counter />
            </div>
        );
    }
}
这是我的包。json

{
  "name": "react-boilerplate",
  "version": "1.0.0",
  "description": "This is just a simple folder structure template to use for my `React` projects.",
  "keywords": [],
  "scripts": {
    "compile": "webpack",
    "start": "node server.js",
    "test": "jest"
  },
  "repository": {
    "type": "git",
    "url": "git+https://github.com/dantesolis/react-boilerplate.git"
  },
  "author": "D/S",
  "license": "MIT",
  "main": "index.js",
  "bugs": {
    "url": "https://github.com/dantesolis/react-boilerplate/issues"
  },
  "homepage": "https://github.com/dantesolis/react-boilerplate#readme",
  "devDependencies": {
    "babel": "^6.5.2",
    "babel-core": "^6.10.4",
    "babel-loader": "^6.2.4",
    "babel-preset-react": "^6.11.1",
    "jest-cli": "^13.2.3",
    "webpack": "^1.13.1"
  },
  "jest": {
    "scriptPreprocessor": "./tools/preprocessor.js",
    "unmockedModulePathPatterns": [
      "react"
    ],
    "testPathDirs": [
      "./src/",
      ""
    ]
  },
  "dependencies": {
    "babel-core": "^6.11.4",
    "babel-loader": "^6.2.4",
    "babel-preset-es2015": "^6.9.0",
    "babel-preset-react": "^6.11.1",
    "express": "^4.14.0",
    "react": "^15.2.1",
    "react-dom": "^15.2.1",
    "react-router": "^2.6.0",
    "webpack": "^1.13.1",
    "webpack-dev-middleware": "^1.6.1"
  }
}
Main.js

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

var config = {
  context: path.join(__dirname, 'app'),
  entry: [
    './main.js',
  ],
  output: {
    path: path.join(__dirname, 'www'),
    filename: 'bundle.js',
  },
  resolve: {
    extensions: ['', '.js', '.jsx']
  },
  module: {
    loaders: [
      {
        test: /src\/.+.js$/,
        exclude: /node_modules/,
        // loaders: ['babel', 'babel-loader?presets[]=react,presets[]=es2015'],
        loaders: ['babel', 'babel-loader']
      }
    ],
  },
  resolveLoader: {
    root: [
      path.join(__dirname, 'node_modules'),
    ],
  },
  resolve: {
    root: [
      path.join(__dirname, 'node_modules')
    ],
  },
};
module.exports = config;
import React from 'react';
import ReactDOM from 'react-dom';
import App from './App';

ReactDOM.render(<App />, document.getElementById('app')); <= OFFENDING LINE
import React from 'react';
import { Router, Route, Link, IndexRoute, hashHistory, browserHistory } from 'react-router';
import Counter from './Counter';

export default class App extends React.Component {
    render() {
        return (

            <div>
                <Counter />
            </div>
        );
    }
}
从“React”导入React;
从“react dom”导入react dom;
从“./App”导入应用程序;

ReactDOM.render(,document.getElementById('app')) 您需要将
entry
['main.js']
更改为[
'main.js'
],因为您提到了
main.js
,它的第一个字母是大写的,正如我在
网页
配置中看到的那样,您的应用程序代码位于
app
文件夹中,没有任何关于
src
文件夹的内容,因此您需要将
RegExp
/src\/.+.js$/
更改为
/\.js$/

 {
   test: /\.js$/,
   exclude: /node_modules/,
   loaders: ['babel', 'babel-loader?presets[]=react,presets[]=es2015']
 }

感谢@Alexander T,有
main的东西;js
是一个打字错误。真正解决这个问题的是更改
测试:/\.js$/,
。我以为那只是测试文件?再次感谢你,在过去的3个小时里,我一直在绞尽脑汁