React Hot Loader不反映浏览器的变化

时间:2016-09-03 12:52:40

标签: javascript reactjs npm react-hot-loader

我正在研究一个反应项目。我正在尝试使用反应热装载机。项目中的所有内容都可以正常工作,但是当我在组件中进行任何更改时,我无法在浏览器中看到更改。我按照官方文档设置了热装载机。但它没有用。我的内容虽然在浏览器(localhost:3000)中加载。我应该怎么做才能让热装载机开始显示更改。这是我的文件。

Browser Console

App.js

import React from 'react';
import Userlist from '../containers/user-list';
import UserDetail from '../containers/user-detail';
require('../../scss/style.scss');
import getMuiTheme from 'material-ui/styles/getMuiTheme';
import MuiThemeProvider from 'material-ui/styles/MuiThemeProvider';
import RaisedButton from 'material-ui/RaisedButton';


const App = () => (
    <MuiThemeProvider>
        <div>
            <RaisedButton label="Default" />
            <h2>
                Usernamess
            </h2>
            <Userlist/>
            <hr/>
            <h2>
                User Detail
            </h2>
            <hr/>
            <UserDetail/>
        </div>
    </MuiThemeProvider>
);

export default App;

webpack.config.js

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

module.exports = {
    devtool: 'eval',
    entry: [
        'webpack-dev-server/client?http://localhost:3000',
        'webpack/hot/only-dev-server',
        './dev/js/index.js'
    ],
    module: {
        loaders: [
            {
                test: /\.js$/,
                loaders: ['react-hot', 'babel'],
                include: path.join(__dirname, 'dev')
            },
            {
                test: /\.scss/,
                loader: 'style-loader!css-loader!sass-loader'
            }
        ]
    },
    output: {
        path: path.join(__dirname, 'dist'),
        filename: 'bundle.js',
        publicPath: '/static/'
    },
    plugins: [
        new webpack.HotModuleReplacementPlugin()
    ]
};

的package.json

{
  "name": "react-redux-template",
  "version": "1.0.0",
  "main": "index.js",
  "scripts": {
    "start": "node server.js",
    "lint": "eslint src"
  },
  "license": "ISC",
  "dependencies": {
    "babel-core": "^6.10.4",
    "babel-loader": "^6.2.4",
    "babel-polyfill": "^6.9.1",
    "babel-preset-es2015": "^6.9.0",
    "babel-preset-react": "^6.11.1",
    "babel-register": "^6.9.0",
    "cross-env": "^1.0.8",
    "css-loader": "^0.23.1",
    "expect": "^1.20.1",
    "material-ui": "^0.15.4",
    "node-libs-browser": "^1.0.0",
    "node-sass": "^3.8.0",
    "react": "^15.1.0",
    "react-addons-test-utils": "^15.1.0",
    "react-dom": "^15.1.0",
    "react-redux": "^4.4.5",
    "react-tap-event-plugin": "^1.0.0",
    "redux": "^3.5.2",
    "redux-logger": "^2.6.1",
    "redux-promise": "^0.5.3",
    "redux-thunk": "^2.1.0",
    "sass-loader": "^4.0.0",
    "style-loader": "^0.13.1",
    "webpack": "^1.13.1",
    "webpack-dev-middleware": "^1.6.1",
    "webpack-dev-server": "^1.14.1",
    "webpack-hot-middleware": "^2.11.0"
  },
  "devDependencies": {
    "babel-plugin-react-transform": "^2.0.2",
    "babel-preset-stage-0": "^6.5.0",
    "react-transform-hmr": "^1.0.4",
    "react-hot-loader": "^1.3.0"
  }
}

server.js

   var webpack = require('webpack');
var WebpackDevServer = require('webpack-dev-server');
var config = require('./webpack.config');

new WebpackDevServer(webpack(config), {
  publicPath: config.output.publicPath,
  hot: true,
  historyApiFallback: true
}).listen(3000, 'localhost', function (err, result) {
  if (err) {
    return console.log(err);
  }

  console.log('Listening at http://localhost:3000/');
});

Project Structure

1 个答案:

答案 0 :(得分:0)

来自热门加载器官方线程https://github.com/gaearon/react-hot-loader/blob/master/docs/Troubleshooting.md

的摘要

&#34;以下模块无法热更新:(他们需要完全重新加载!)

如果在编辑根组件时收到此警告,可能是因为您没有从中导出任何内容,并从那里调用React.render。将您的根组件放在一个单独的文件(例如App.jsx)中,并从您调用React.render的index.js中获取它。&#34;

所以我在App.js中进行了更改

export default class App extends Component {
    render() {
        return (
            <MuiThemeProvider>
                <div>
                    <RaisedButton label="Default" />
                    <h2>
                        Usernamess
                    </h2>
                    <Userlist/>
                    <hr/>
                    <h2>
                        User Deta
                    </h2>
                    <hr/>
                    <UserDetail/>
                </div>
            </MuiThemeProvider>
        );
    }
}