I managed to get my React app with React Router v4 working with an express server running liquid.js similar to handlebars the solution would work the same way for any other template engine.
In your React App.js make sure you have the React Router v4 installed and set up like this:
import React, { Component } from 'react';
import { TransitionGroup, CSSTransition } from "react-transition-group";
import 'foundation-sites';
import {
BrowserRouter as Router,
Route,
Switch
} from "react-router-dom";
import './assets/css/foundation.min.css';
import './assets/css/settings.scss';
import './assets/css/structure.css';
import './assets/css/owl-slider.css';
import './assets/fonts/fontawesome/all.css';
// ## COMPONENTS
import Header from './components/Header/header';
import Footer from './components/Footer/footer';
// ## PAGES
import HomePage from './components/Pages/Home/homePage';
import AboutPage from './components/Pages/About/aboutPage';
import ServicesPage from './components/Pages/Services/services';
import ContactPage from './components/Pages/Contact/contact';
class App extends Component {
render() {
return (
<Router>
<div className="App page-a blur" id="page" data-toggler=".blur" >
<Header/>
<div className="pageWrapper">
<Route render={({ location }) => (
<TransitionGroup>
<CSSTransition key={location.key} classNames="pageTransition" timeout={500}>
<Switch location={location}>
<Route exact path="/" exact component={HomePage} />
<Route path="/services" render={props => <ServicesPage {...props}/>} />
<Route path="/about" component={AboutPage} />
<Route path="/contact" component={ContactPage} />
<Route render={() => <div>Not Found</div>} />
</Switch>
</CSSTransition>
</TransitionGroup>
)}/>
</div>
<Footer footerMessage="Liliana Alves // Sport & Soft Tissue Therapist"/>
</div>
</Router>
);
}
}
export default App;
The above code will make sure that when the user navigates your React app and the routes are doing their job sending the user to a page they navigate, refresh or enter in the URLs manually.
In your express server app.js you want to define the main access root "/" to your react app "Do not use a wildcard * (asterisk) this will not work!" :
app.get('/', (req, res) => {
res.status(200).sendFile(path.join(__dirname+'/react-site/build/index.html'));
}); //THE REQUEST CONTENT
Then if you would have a 404 in your express it would redirect your user back to React to handle the 404s using React Router, this method is done using an express error handler:
app.use((req, res, next) => {
const error = new Error('Not Found'); //Error object
error.status = 404;
//res.render('./404'); by default in express applications you would render a 404 page
res.status(200).sendFile(path.join(__dirname+'/react-site/build/index.html'));
next(error);
});
I spent a decent time research to get it working if anybody thinks this should be improved or it might need more support in the error function please let me know.