How to do the Facebook content upload technique?

5

How does Facebook do this by loading your page? It loads the content bit by bit and not all at once like most sites, StackOverflow is an example that loads.

  • How do you call this loading technique? (if you have a name)
  • How can I do it in JavaScript or jQuery?

    
asked by anonymous 19.02.2017 / 22:50

1 answer

11

When it comes to large companies such as Facebook, Google, etc. it is very difficult to conclude how they make their applications. But I think it's a lot like the lazy load technique, or a free translation, lazy loading. The technique is to load the page elements only when they enter the visible field of the user, and if the content is large or the user connection is slow, the loading is done asynchronously. An AJAX request is made and displays the element only when you have the content loaded completely. One caution that is always well discussed in this case is not to keep the user's screen blank while the request is made, as it may feel that the page is not responding and close. To get around this, a slightly lighter version of the content (or generic in the case of Facebook) is usually displayed and replaced when the content itself is ready.

Example

For example, if you want to display an image on your site, but this image is giant, 4k, with a resolution of 7680 × 4320, it will usually take a long time to load completely. Then we can edit the image, generating a much lighter version of 600 × 338, reducing the pixel density to the maximum, so we can display it while the original is loaded. For comparison purposes, the original image has a size of 1 MB, while the reduced size is 8.7 kB, that is, a reduction of 99.9913%.

$(() => {
  
  var img = $("img");
  
  $.get("https://gist.githubusercontent.com/acwoss/aeaf1264e0948bbb0965eed3e8647e31/raw/0c418cd3f4f92d8228637af34c48ed616adc4ab7/tiger4k.png", (data) => {
    img.fadeOut(400, () => {
      img.attr("src", data);
    }).fadeIn(2000);
  });
});
img {
  width: 600px;
  height: 338px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script><imgsrc="" />

In the example above, I display the low-resolution image along with the page, encoded in base 64 just to be a string and be transferred along with the page and not through an extra request. When the entire DOM is loaded, I make an asynchronous call to fetch the original image. When it is ready, I display it, making a small animation fade so that the replacement is not so abrupt.

This technique is very important for pages in a blog, for example, because the user will be able to start reading the text before the images are loaded and, mainly, there will be no variation of the position of the text when they are loaded, because there is the reduced quality version of the image already on the page, occupying exactly the space that the original image will occupy.

Note on arrow functions

The notation used () => {} is called arrow functions , introduced in the ECMAScript 2015 (ES6) standard, and is basically a new way to define anonymous functions.

Do, in jQuery:

$(() => {...});

It's the same as:

$(function () {...});

How it's usually done.

If you want to read more about:

20.02.2017 / 00:14