2017-06-14 84 views
2

我正在運行的服務器本地主機,並得到誤差bundle.js:1未捕獲的SyntaxError:意外令牌< 在輸出bundle.js是index.html文件的HTML代碼。這是設置我的webpack.config文件。你能告訴我設置有什麼問題嗎?的WebPack錯誤bundle.js:1未捕獲的SyntaxError:意外令牌<

import path from 'path'; 
import webpack from 'webpack'; 

export default { 
    devtool: 'eval-source-map', 
    entry: [ 
    'webpack-hot-middleware/client', 
    path.join(__dirname, '/client/index.js') 
    ], 
    output: { 
    path: '/', 
    publicPath: '/' 
    }, 
    plugins: [ 
    new webpack.NoEmitOnErrorsPlugin(), 
    new webpack.optimize.OccurrenceOrderPlugin(), 
    new webpack.HotModuleReplacementPlugin() 
    ], 
    module: { 
    loaders: [ 
     { 
     test: /\.js$/, 
     include: path.join(__dirname, 'client'), 
     loaders: ['react-hot-loader', 'babel-loader' ] 
     } 
    ] 
    }, 
    resolve: { 
    extensions: ['.js'] 
    }  
} 

的index.html

<html> 

<head> 
    <meta charset="UTF-8"> 
    <title>Site</title> 
    <meta content="width=device-width, initial-scale=1" name="viewport" /> 
</head> 

<body> 
    <h1>Hello bla bla bla</h1> 
    <div id="app"></div> 

    <script src="bundle.js"></script> 
</body> 

</html> 

服務器/ index.js

import express from 'express'; 
import path from 'path'; 

import webpack from 'webpack'; 
import webpackMiddeleware from 'webpack-dev-middleware'; 
import webpackHotMiddleware from 'webpack-hot-middleware'; 
import webpackConfig from '../webpack.config'; 


let app = express(); 

const compiler = webpack(webpackConfig); 

app.use(webpackMiddeleware(compiler, { 
    hot: true, 
    publicPath: webpackConfig.output.publicPath, 
    noInfo: true 
})); 
app.use(webpackHotMiddleware(compiler)); 

app.get('/*', (req, res)=>{ 
    res.sendFile(path.join(__dirname, './index.html')); 
}); 

app.listen('3000',()=>{console.log('Running on port 3000')}); 

客戶機/ index.js

import React from 'react'; 
import { render } from 'react-dom'; 
import App from './components/App'; 

render(<App/>, document.getElementById('app')); 

組件/ App.js

import React from 'react'; 

class App extends React.Component { 
    render(){ 
    return (
     <h1>Hello</h1> 
    ); 
    } 
} 

export default App; 

的package.json:

{ 
    "name": "xxxxx", 
    "version": "1.0.0", 
    "description": "xxxxxxxxxx", 
    "main": "index.js", 
    "scripts": { 
    "server": "nodemon --watch server --exec babel-node -- server/index.js", 
    "test": "echo \"Error: no test specified\" && exit 1" 
    }, 
    "repository": { 
    "type": "git", 
    "url": "xxxxxxxxxxxxx" 
    }, 
    "keywords": [ 
    " 
    ], 
    "author": "xxxxxxxxx", 
    "license": "ISC", 
    "bugs": { 
    "url": "xxxxxxxxxxxxxxxxxxxxxxx" 
    }, 
    "homepage": "xxxxxxxxxxxxxxxxxxxx", 
    "dependencies": { 
    "babel-cli": "^6.24.1", 
    "express": "^4.15.3", 
    "react": "^15.5.4", 
    "react-dom": "^15.5.4" 
    }, 
    "devDependencies": { 
    "babel-loader": "^7.0.0", 
    "babel-preset-es2015": "^6.24.1", 
    "babel-preset-react": "^6.24.1", 
    "nodemon": "^1.11.0", 
    "react-hot-loader": "^1.3.1", 
    "webpack": "^2.6.1", 
    "webpack-dev-middleware": "^1.10.2", 
    "webpack-hot-middleware": "^2.18.0" 
    } 
} 

.babelrc

{ 
    "presets": [ "es2015", "react" ] 
} 

謝謝。

+0

怎麼是你'客戶端/ index.js'?我在問題的主體中添加了 – enapupe

+0

。 –

+0

這很可能是您缺少對JSX的支持。 – enapupe

回答

0

您正在使用多個入口點但未設置輸出。

http://webpack.github.io/docs/configuration.html#entry

+0

對不起,但是如何設置輸出?我添加了輸出:{ path:'/' publicPath:'/' } –

+0

嘗試在您的輸出中添加文件名:{path:'/'publicPath:'/'filename:'bundle.js'}並檢查如果正如enapupe在評論中所說的那樣正確設置路徑路線。爲什麼你需要'webpack-hot-middleware/client'作爲入口點? – Tuko90

+0

hm ...是的,我添加了文件名:'bundle.js',現在工作。我需要webpack-hot-middleware/client在瀏覽器上更改數據而無需重新加載頁面 –

2

bundle.js SRC在script標籤是錯誤的。它返回你的主要index.html,這就是爲什麼你會得到這個錯誤 - JS解析器試圖解析一個HTML文件。

必須斜線添加到您的腳本源: <script src="/bundle.js"></script>

如果不工作,你必須仔細檢查你output配置。

+0

我有同樣的問題,我認爲你指出了正確的方向。我在HTML文件中複製了腳本標記 因爲你可以看起來很好。 我想知道如果我配置了webpack把bundle放到'public'文件夾中'publicPath'應該包含什麼值?目前我有'publicPath:'/'' – SuperManEver

+0

@SuperManEver你應該打開一個新的問題並分享你的webpack配置等。 – enapupe

0

我已通過添加filename項目對象輸出解決了這個問題:

output: { 
path: '/', 
filename: 'bundle.js' 
}, 
相關問題