反应路由器页面呈现问题

时间:2017-04-26 09:30:08

标签: javascript reactjs rendering react-router

现在学习React尝试使用react-router进行页面路由,但由于某些原因,我总是看到空白页而不是渲染组件。 我正在使用webpack-dev-server作为开发服务器 寻找您的帮助和建议

的index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <link href="dist/css/app.css">
</head>
<body>

<div id="root"></div>

<script src="dist/js/app.js"></script>

</body>
</html>

app.js

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

import App from './Pages/App';
import Archives from './Pages/Archives';
import Features from './Pages/Features';
import Settings from './Pages/Settings';

const app = document.getElementById('root');

// ReactDOM.render(<Layout/>, app);

ReactDOM.render(
    <Router history={hashHistory}>
        <Route path="/" component={App}>
            <IndexRoute component={Features}/>
            <Route path='archives' component={Archives}/>
            <Route path='settings' component={Settings}/>
        </Route>
    </Router>
    , app);

应用组件

import React from 'react';
import { Link } from 'react-router'

export default class App extends React.Component{

    render(){
        return (
           <div>
                <h1>App</h1>
               <Link to="/archives">Archives</Link>
               <Link to="/settings">Settings</Link>
               {this.props.children}
           </div>
        );
    }
}

的package.json

{
  "name": "Planner",
  "version": "1.0.0",
  "description": "",
  "main": "webpack.config.js",
  "dependencies": {
    "babel-core": "^6.24.1",
    "babel-loader": "^7.0.0",
    "babel-plugin-add-module-exports": "^0.2.1",
    "babel-plugin-react-html-attrs": "^2.0.0",
    "babel-plugin-transform-class-properties": "^6.24.1",
    "babel-plugin-transform-decorators-legacy": "^1.3.4",
    "babel-preset-es2015": "^6.24.1",
    "babel-preset-react": "^6.24.1",
    "babel-preset-stage-0": "^6.24.1",
    "history": "^4.6.1",
    "react": "^15.5.4",
    "react-dom": "^15.5.4",
    "react-router": "^4.1.1",
    "webpack": "^2.4.1",
    "webpack-dev-server": "^2.4.4"
  },
  "devDependencies": {},
  "scripts": {
    "dev": "webpack-dev-server --content-base --inline --hot",
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC"
}

更新: Webpack配置

var debug = process.env.NODE_ENV !== "production";
var webpack = require('webpack');
var path = require('path');

module.exports = {
    context: path.join(__dirname, "src"),
    devtool: debug ? "inline-sourcemap" : null,
    entry: "./js/app.js",
    module: {
        loaders: [
            {
                test: /\.jsx?$/,
                exclude: /(node_modules|bower_components)/,
                loader: 'babel-loader',
                query: {
                    presets: ['react', 'es2015', 'stage-0'],
                    plugins: ['react-html-attrs', 'transform-decorators-legacy', 'transform-class-properties'],
                }
            }
        ]
    },
    output: {
        path: path.resolve(__dirname, 'dist/js'),
        filename: "app.js",
        publicPath: '/dist/js/'
    },
    plugins: debug ? [] : [
        new webpack.optimize.DedupePlugin(),
        new webpack.optimize.OccurenceOrderPlugin(),
        new webpack.optimize.UglifyJsPlugin({ mangle: false, sourcemap: false }),
    ],
};

0 个答案:

没有答案