当前位置: 首页 > 知识库问答 >
问题:

客户端路由(使用react-router)和服务器端路由

季俭
2023-03-14

我想到的是:

  • 路线是如何解释的?例如,从主页(/Home)到帖子页(/Posts)
  • 的请求
  • 路由在服务器端还是客户端?
  • 它如何知道它是如何处理的?

共有1个答案

莘康裕
2023-03-14

注意,这个答案涵盖了React Router 0.13.x版本--即将发布的1.0版本看起来将有明显不同的实现细节

这是带有react-router的最小server.js:

var express = require('express')
var React = require('react')
var Router = require('react-router')

var routes = require('./routes')

var app = express()

// ...express config...

app.use(function(req, res, next) {
  var router = Router.create({location: req.url, routes: routes})
  router.run(function(Handler, state) {
    var html = React.renderToString(<Handler/>)
    return res.render('react_page', {html: html})
  })
})

其中routes模块导出一个路由列表:

var React = require('react')
var {DefaultRoute, NotFoundRoute, Route} = require('react-router')

module.exports = [
  <Route path="/" handler={require('./components/App')}>
    {/* ... */}
  </Route>
]
var React = require('react')
var Router = require('react-router')

var routes = require('./routes')

Router.run(routes, Router.HistoryLocation, function(Handler, state) {
  React.render(<Handler/>, document.body)
})

在本例中,我们使用HistoryLocation,它使用HistoryAPI来确保在单击后退/前进按钮时发生正确的事情。还有一个hashlocation,它更改URLhash以生成历史记录条目,并监听window.onhashchange事件以触发导航。

当您使用React-Router的 组件时,您将为它提供一个to道具,即路由的名称,加上路由所需的任何paramsquery数据。此组件呈现的有一个onclick处理程序,该处理程序最终使用您提供的链接道具调用路由器实例router.transitionto(),如下所示:

  /**
   * Transitions to the URL specified in the arguments by pushing
   * a new URL onto the history stack.
   */
  transitionTo: function (to, params, query) {
    var path = this.makePath(to, params, query);

    if (pendingTransition) {
      // Replace so pending location does not stay in history.
      location.replace(path);
    } else {
      location.push(path);
    }
  },

对于常规链接,无论您使用哪种位置类型,它最终都会调用Location.push(),这将处理设置历史记录的细节,因此使用后退和前进按钮进行导航将起作用,然后调用router.handlelocationchange(),让路由器知道它可以继续转换到新的URL路径。

然后,路由器使用新URL调用自己的router.dispatch()方法,该方法处理确定哪些配置的路由与URL匹配的细节,然后调用匹配路由的所有转换钩子。您可以在任何路由处理程序上实现这些转换挂钩,以便在即将离开或导航到路由时采取某些操作,如果事情不合您的喜好,您可以中止转换。

如果转换没有中止,最后一步是使用顶级处理程序组件和一个包含URL和匹配路由的所有细节的状态对象调用您给router.run()的回调。顶层处理程序组件实际上是router实例本身,它处理呈现匹配的最顶层路由处理程序。

每次导航到客户端上的新URL时,都会重新运行上述过程。

 类似资料:
  • 问题内容: 我一直在思考,我对客户端和服务器之间的路由感到困惑。假设我在将请求发送回Web浏览器之前使用ReactJS进行服务器端渲染,并使用react- router作为客户端路由在页面之间切换而不刷新为SPA。 我想到的是: 路线如何解释?例如,从首页()到帖子页面()的请求 路由在服务器端还是客户端去哪里? 它如何知道如何处理? 问题答案: 注意,此答案涵盖了React Router版本0.

  • 问题内容: 前锋 看来,在Meteor中,如果没有正常工作流程(根据我对服务器端路由的了解)进行某种变通,我们就无法调用服务器端路由将文件呈现到页面。我希望我对此是错误的,并且有一种简单的方法可以实现我想要做的事情… 很抱歉,如果这有点长,但是我认为在这种情况下,有必要提供更多的背景和背景信息 软件/版本 我使用的是最新的Iron Router 1. 和Meteor 1. ,首先,我使用的是Acc

  • 我想把react-route添加到我的应用程序中,我有下面的代码: 更新:已安装react-router 3.0.2并工作。

  • 在服务器端react中使用react路由器dom会创建错误。 如果url匹配我的组件路径,我将使用react router dom BrowserRouter在div中呈现我的组件。 然后使用以下代码以特定div为目标渲染我的组件: 但此代码仅在客户端react中工作。如何将此实现到服务器端?

  • 路由器用于路由客户端应用程序并定义应用程序对象的URL表示。 当Web应用程序为应用程序中的重要位置提供可链接,可收藏且可共享的URL时,需要路由器。 下表列出了可用于操作BackboneJS - Router - S.No. 方法和描述 1 extend 它扩展了主干的路由器类。 2 routes 它定义了应用程序对象的URL表示。 3 initialize 它为路由器实例化创建了一个新的构造函

  • 问题内容: 我为一项服务有不同的软件产品,需要将其部署到一台服务器上。在服务器运行Node.js和Express的同时,客户端通过react进行构建,并通过create- react-app进行构建设置。 当我从服务器为单个应用程序提供服务时,可以通过以下方式完成: 我希望能够从服务器提供多个应用程序。我该怎么办? 我尝试的是为资产连接不同的静态路径,并使用不同的名称分隔客户端,尽管这样做不起作用