Renderuję stronę serwera po stronie ReactJS + Router , a wiele z moich komponentów wykonuje wywołanie REST w celu wygenerowania treści. Ta zawartość nie zostanie wysłana jako strona serwera HTML, ponieważ jest to połączenie asynchroniczne.Po stronie serwera asynchronicznego ReactJS dla wyszukiwarek
składnik, który mógłby wyglądać następująco:
import React from 'react'
import ReactDOM from 'react-dom'
// Imports omitted
export default class MyPage extends React.Component {
constructor() {
super();
this.state = {items: []};
fetch("http://mywebservice.com/items").then((response) => {
response.json().then((json) => {
this.setState({items: json.items})
}).catch((error) => {});
});
}
render() {
if (this.state.items && this.state.items.length > 0) {
var rows = [];
// Go through the items and add the element
this.state.items.forEach((item, i) => {
rows.push(<div key={item.id}></div>);
});
return <div>
<table>
{rows}
</table>
</div>;
}
else {
return <span>Loading...</span>
}
}
}
wyszukiwarka będzie wskaźnik "Loading ...", a ja oczywiście chcą moich elementów (przedmiotów), indeksowane. Czy istnieje sposób na rozwiązanie tego problemu?
Dzięki! Znalazłem również to: https://github.com/ryanflorence/async-props – ianaz