Isomorphic JavaScript, also known as Universal JavaScript, describes JavaScript applications which run both on the client and the server.
Mechanism
Isomorphic JavaScript works in the context of a single-page application. In a typical SPA, most of the application logic, including routing, is encapsulated in a bundled JavaScript file that is sent to the client. While this frees up the server, as it does not have to handle so many requests, it also makes the initial load slow for the client, as the entire application needs to be sent over to the client. With Isomorphic JavaScript, when a client web page is first requested from the server, the view of the page is generated on the server, similar to server-side dynamic web pages, and sent over to the client. The client can then render the view immediately. After the initial view is rendered, the complete SPA is downloaded in the background, and subsequent actions are handled client-side.
Name
The naming of the term 'Isomorphic JavaScript' has been a matter of controversy. The term 'isomorphic' was first coined by Charlie Robbins from Nodejitsu, in one of the company's blog posts. Spike Brehm, a software engineer from Airbnb, wrote another blog post using the same term. However, others have proposed to use the term Universal JavaScript instead.
Benefits
Better user experience: By rendering important parts of the application with the real data on the server-side, an isomorphic application can show a meaningful initial page. On the other hand, client rendering application can’t show any meaningful information until it fetches all external data it needs. In the meantime, the only thing a user will see is a loading indicator.
Faster overall loading time: Although an isomorphic application will be slower in responding an initial page compared to a client rendering application, overall completion time to the final user interface is faster because data access on the server-side is much faster than client-side API requests.
More predictable SEO and Site Indexing: In order to index content that JavaScript apps render on client-side, Googlebot must run those JavaScript apps inside a full browser environment and capture the rendered DOM. This involves complex browser compatibility issues. Also, because JavaScript apps can make AJAX requests for further rendering, Googlebot must have a policy that controls apps’ network access. These are why getting your JavaScript app indexed properly by Googlebot is still challenging.
Frameworks
There have been several isomorphic JavaScript frameworks and libraries created, most notably Meteor and React. Others includes , , , , , and .