6
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:
Related: https://answall.com/q/158683/5878
– Woss