簡體   English   中英

客戶端的React(同構)鏈接未渲染路由

[英]React (Isomorphic) Link Not Rendering Route on Client Side

所以,我已經為此苦苦掙扎了好幾天了。

可行的方法:應用程序在服務器端的加載就很好。 route / index.jsx(這是我的服務器端路由文件)可以很好地加載頁面。 console.log('News'); 在客戶端JavaScript控制台和服務器的節點頁面加載日志上均顯示“ News ”日志。 我最初可以加載任何頁面。

問題:一旦頁面加載完畢,然后單擊標題中的鏈接,URL欄中的地址就會更改,但是UI不會更新,並且如果沒有console.log('Home')如果要導航到“ News我將導航到“主頁”,反之亦然;如果沒有console.log('News');我將沒有console.log('News'); 發生在客戶端或服務器上。

我有以下文件。

Routes / Index.jsx-服務器端渲染

var router = require('express').Router();
var React = require('react');
var ReactDOMServer = require('react-dom/server');
var StaticRouter = require('react-router-dom').StaticRouter;
var Redux = require('redux');
var Provider = require('react-redux').Provider;
var App = require('../views/app.jsx');

function reducer(state) { return state; }

router.get('*', function(req, res) {
  var initialState = { title: 'Home' };
  const store = Redux.createStore(reducer, initialState);
  var context = {};

  var html = ReactDOMServer.renderToString(
      <Provider store={store}>
        <StaticRouter location={req.url} context={context}>
          {require('../views/app.jsx')}
        </StaticRouter>
      </Provider>
    );

  var windowprops = store.getState();
  windowprops = JSON.stringify(windowprops).replace(/</g, '\\u003c');
  var frame = '<!DOCTYPE html><html><head><link rel="stylesheet" type="text/css" href="/css/layout.css" /><title>'+store.getState().title+' | Lunar Realm</title></head><body><div id="root">'+html+'</div><script>window.PROPS = '+windowprops+'</script><script src="/bundle.js"></script></body></html>';

  if(context.status >= 400) {
    res.status(context.status).send(frame);
  } else if (context.url) {
    res.redirect(context.status, context.url);
  } else {
    res.send(frame);
  }
});
module.exports = router;

意見/ app.jsx

var React = require('react');
var ReactRouter = require('react-router-dom');
var Route = ReactRouter.Route;
var Layout = require('../views/Layout.jsx');
var Redirect = ReactRouter.Redirect;
var Switch = ReactRouter.Switch;

module.exports = (
    <Layout>
      <Switch>
        <Route exact path='/' component={require('./Index.jsx')} />
        <Route exact path='/news' component={require('./News.jsx')} />
      </Switch>
    </Layout>
);

Client.JS-對於WebPack

var ReactDOM = require('react-dom');
var React = require('react');
var Routes = require('./routes/routes.jsx');
var Redux = require('redux');
var Provider = require('react-redux').Provider;

function reducer(state) { return state; }

var store = Redux.createStore(reducer, window.PROPS);

ReactDOM.render(
    <Provider store={store}>
        {Routes}
    </Provider>, document.getElementById('root')
);

Routes.JSX-用於前端路由

var React = require('react');
var ReactRouter = require('react-router-dom');
var BrowserRouter = ReactRouter.BrowserRouter;
var Router = ReactRouter.Router;
var Route = ReactRouter.Route;
var Redirect = ReactRouter.Redirect;
var Switch = ReactRouter.Switch;
var Layout = require('../views/Layout.jsx');

import createHistory from 'history/createBrowserHistory';
var history = createHistory();

module.exports = (
  <BrowserRouter>
    <Layout>
      <Switch>
        <Route exact path="/" component={require('../views/Index.jsx')} />
        <Route exact path='/news' component={require('../views/News.jsx')} />
        <Route component={require('../views/404.jsx')} />
      </Switch>
    </Layout>
  </BrowserRouter>
);

views / News.jsx-版式的子代

var React = require('react');

var News = React.createClass({
  render: function(){
    console.log('news');
    return(
      <div id="canvas-section-news" className="canvas-section">
        News
      </div>
    );
  }
});

module.exports = News;

有人可以幫我弄清楚為什么我的UI不更新嗎? 我應該注意,我的節點日志和瀏覽器的JavaScript控制台都沒有任何錯誤。

我的package.json中的依賴項

"dependencies": {
    "babel-loader": "^6.4.1",
    "babel-plugin-transform-class-properties": "^6.23.0",
    "babel-plugin-transform-runtime": "^6.23.0",
    "babel-polyfill": "^6.23.0",
    "babel-preset-es2015": "^6.24.0",
    "babel-preset-react": "^6.23.0",
    "babel-preset-stage-0": "^6.22.0",
    "babel-register": "^6.24.0",
    "express": "^4.15.2",
    "history": "^4.6.1",
    "mongoose": "*",
    "react": "^15.4.2",
    "react-dom": "^15.4.2",
    "react-redux": "^5.0.3",
    "react-router": "^4.0.0",
    "react-router-dom": "^4.0.0",
    "redux": "^3.6.0",
    "webpack": "^2.3.3"
  }

好的,我知道了。 我使用React Connect()函數的方式存在問題。 確保正確使用它!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM