How to load Facebook content?

Asked

Viewed 875 times

6

How does Facebook do this with loading your page? It uploads content gradually and not all at once like most websites, Stackoverflow is an example that loads once and for all.

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

inserir a descrição da imagem aqui inserir a descrição da imagem aqui

  • 1

    Related: https://answall.com/q/158683/5878

2 answers

11


When it comes to large companies such as Facebook, Google, etc. it is very difficult to conclude how they make their applications. However, I believe it is something very similar to the technique Lazy load, or in a free translation, lazy loading. The technique is to load the page elements only when they enter the user’s visible field, and if the content is large or the user’s connection is slow, the upload is done asynchronously. An AJAX request is made and displays the element only when it has the content fully loaded. One caution that is always well discussed in this case is to not keep the user screen blank while the request is being made, as the same may find that the page is not responding and close. To get around this, a much lighter version of 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 the site, but this image is giant, 4k, with resolution 7680 4320, it will usually take a while to fully upload. Then we can edit the image, generating a much lighter version, 600 338, reducing the pixel density to the maximum, so that we can display it while the original is loaded. For comparison purposes, the original image has a size of 1 MB, while the reduced 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>
<img src="" />

In the above example, I display the low-resolution image along with the page, encoded in base 64 precisely to be a string and be transferred along with the page and not through an extra request. When the whole DOM is loaded, I make an asynchronous call to search for the original image. When this one’s ready, I’ll display it, doing a little animation fade so that the replacement is not so sudden.

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


Note on Arrow functions

The rating used () => {} is called Arrow functions, introduced in Ecmascript standard 2015 (ES6), and is basically a new way to define anonymous functions.

Do, in jQuery:

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

Is the same as:

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

As is usually done.

If you want to read more about:

  • What $(() => { and () = { do? What would they be?

  • 1

    I added a note at the end of the reply on this.

  • 1

    @Andersoncarloswoss in reality , there is a difference yes... Enaqunto in a function (){ } the this refers to who sent it, in an Arrow Function o this will always be the object window. There is a stackoverflow thread here -> http://stackoverflow.com/questions/22939130/when-should-i-use-arrow-functions-in-ecmascript-6 .

  • 2

    @I'mBlueDaBaDee, Yes, indeed. I did not want to get into this merit because in the answer nor did I use the this, then they worked as anonymous functions. I passed a link to if the AP wanted to study more, but thanks for the comment. I’ll embed your link in the reply.

0

There are several ways to do this, but all the facebook homepage is loaded through ajax and PHP I believe, good at least was. Where simplistically and just as an example it takes the div or Section that contains the posts, and if the end of this div divEmSi.getBoundingClientect().bottom is less than the end of the window interior window.innerHeight + window.innerHeight / 2 Obs: the sum would be for it to always load a little before arriving at the end, load the posts coming in ajax from the database. obviously I simplified an extremely giant code with more functionality and performance, more and basically.

If you are referring to animation, and all done with css.

And if you are referring to Lazy-Loader that would be to load any content only when it is visible on the screen this technique is called Lazy-loading. There are also various ways to do it. An example:

function lazyLoad() {
        let lazyImage = document.querySelectorAll('.lazy_img');
        addEventListener("scroll", function () {
            lazyImage.forEach(element => {
                let elementS = element.getBoundingClientRect().top,
                    elementDv = window.innerHeight + window.innerHeight / 2;
                if (elementS < elementDv && elementS > 0) {
                    element.src = element.getAttribute('data-src');
                }
            });

        }, true)

    }
    lazyLoad();

Browser other questions tagged

You are not signed in. Login or sign up in order to post.