Skip to content

electrode-samples/example-above-the-fold-hapijs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 

Repository files navigation

example-above-the-fold-hapijs

  • This repo is an example hapi.js app with Above-the-fold-only-server-render module fully integrated
  • The step-by-step instructions on building it from scratch can be found below

Hapijs Server

git clone https://github.com/electrode-samples/hapi-react-redux-starter.git hapiApp
cd hapiApp
npm install

Above The Fold Only Server Render

above-the-fold-only-server-render is a React component for optionally skipping server side rendering of components outside above-the-fold (or inside of the viewport). This component helps render your components on the server that are above the fold and the remaining components on the client.

above-the-fold-only-server-render helps increase performance both by decreasing the load on renderToString and sending the end user a smaller amount of markup.

By default, the above-the-fold-only-server-render component is an exercise in simplicity; it does nothing and only returns the child component.

Install

  • Add the above-the-fold-only-server-render component:
npm install above-the-fold-only-server-render --save
  • Add the hapiApp/source/components/above-the-fold/above-the-fold.js file:
import React, { Component } from "react";
import { AboveTheFoldOnlyServerRender } from "above-the-fold-only-server-render";

class AboveTheFold extends Component {
  render() {
    return (
      <div>
        <h3>Above-the-fold-only-server-render: Increase Your Performance</h3>
        <AboveTheFoldOnlyServerRender skip={true}>
          <div className="renderMessage" style={{color: "blue"}}>
            <p>This will skip server rendering if the 'AboveTheFoldOnlyServerRender'
              lines are present, or uncommented out.</p>
            <p>This will be rendered on the server and visible if the 'AboveTheFoldOnlyServerRender'
              lines are commented out.</p>
            <p>Try manually toggling this component to see it in action</p>
            <p>
              <a href="https://github.com/electrode-io/above-the-fold-only-server-render"
                 target="_blank">Read more about this module and see our live demo
              </a>
            </p>
          </div>
        </AboveTheFoldOnlyServerRender>
      </div>
    );
  }
}

export default AboveTheFold;
  • Add the above-the-fold route in hapiApp/source/routes.js:
import AboveTheFold from "./components/above-the-fold/above-the-fold";

<Route path="above-the-fold" component={AboveTheFold} />
  • You can tell the component to skip server side rendering either by passing a property: skip={true} or by setting up skipServerRender in your app context and passing the component a contextKey prop.

  • The easiest way to demo this component is actually going to be in your node_modules folder. Navigate to hapiApp/node_modules/above-the-fold-only-server-render/lib/components/above-the-fold-only-server-render.js line 29:

var SHOW_TIMEOUT = 50;
  • You are going to change line 29 to slow down the SHOW_TIMEOUT so you can see the component wrapper in action. Change this to:
var SHOW_TIMEOUT = 3000;
  • Run the commands below and test it out in your app:
NODE_ENV=development npm start
  • Navigate to localhost:3000/above-the-fold

  • The code in the <h3> tag that are above the <AboveTheFoldOnlyServerRender skip={true}></AboveTheFoldOnlyServerRender> will render first. The contents of <AboveTheFoldOnlyServerRender> should render on the client side after the SHOW_TIMEOUT delay.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published