【发布时间】:2013-12-28 14:01:48
【问题描述】:
我对 ReactJS 比较陌生,并且被易于实现服务器端渲染以减少“第一次发推文的时间”所吸引。我正在运行一个 Node-Express-React 堆栈,它使用 React 的 renderComponentToString 在服务器上预渲染标记。
当组件可以同步呈现时它工作得很好,但是在实现 ajax 填充的组件时我正在努力(但这适用于组件初始化期间的任何异步操作,例如 websocket)。
以 React 网站上的示例为例:http://facebook.github.io/react/tips/initial-ajax.html
componentDidMount: function() {
$.get(this.props.source, function(result) {
var lastGist = result[0];
this.setState({
username: lastGist.user.login,
lastGistUrl: lastGist.html_url
});
}.bind(this));
它不会在服务器上工作,因为使用 renderComponentToString 时不会触发 componentDidMount。 这个简单的情况可以通过在客户端和服务器上使用相同的 HTTP 请求包装器(而不是使用 jQuery 的 $.get)来解决,并通过在实例化组件之前预取数据并将其作为道具传递。
然而,在一个实际的、复杂的应用程序中,异步依赖可能会变得非常复杂,并且预取并不真正适合构建 React 结构的后代方法。 如何在 React 中实现异步初始化模式,该模式可以在服务器上呈现而无需实际安装任何东西(即没有 DOM 模拟 la PhantomJS,这是使用 renderComponentToString 的全部意义)?
【问题讨论】:
标签: javascript reactjs