Tutorial

[FIX] BigPipe messing with your Javascript? Easy fix

In Drupal 8, BigPipe was introduced as an ajax renderer for our pages. While its presence is nice and good and it is making our pages super fast, it is messing with development easily. For me, it was messing with my Jquery in front-end. Sometimes it run nicely, and sometimes it refused to run. It took me a solid whole to realise that the BigPipe was the cause of all the struggle. Because it renders the page sooner with HTML placeholders and replace them with normal blocks via AJAX, document.ready was run before the blocks were actually present on the website.

So classic document.ready in jquery, or window.load does not work, what does then?

Pridal/a lubo dňa Ne, 07/19/2020 - 02:42
The workaround

You should avoid writing code in window.load or document.ready function when writing javascript in Drupal 8. I stumbled across this issue thread on Drupal.org and it works like a charm!

Example code

This code should run only once, just place it in your theme javascript file and you should be fine.

var checkReadyState = setInterval(() => {
  if (document.readyState === "complete") {
    clearInterval(checkReadyState);
    console.log('Page is loaded.');
    /* Put your code logic here */
    (function ($){
     /* Put jQuery code logic here */
    })(jQuery);
  }
}, 100);
Fixed!

Now you should be ready to go. Rock some Drupal 8 then!

Might interest you

Module
This list was fetched from Zapper, with their /v1/token-list endpoint. Which you can effectively try yourself at Swagger UI website. But I…
Tutorial
A small bug in Superfish Drupal module causes it to open the submenus on mobile devices but in the same time open the parent link. Which is…

Recommended

Article
32 views
For the past few days I am trying to comprehend why / how this blockchain even gained it'…
Tutorial
97 views
This sketch is quite easy, I used Arduino Nano with OLED 0.96″ display 128×64 resolution…
Tutorial
159 views
While working on a fairly complex website with very complex views setup, including tens…
Tutorial
14 views
In this case we have two options, either we use hook_user_presave() or we can create new…
Tutorial
15 views
When using Swiftmailer under Drupal 8 / 9 it automatically sets the headers for sender to…
Tutorial
7 views
Yes, IOS / Safari is the new internet explorer. Amount of time I spend on debugging…
Tutorial
43 views
There is a very handy function in Drupal 8 / 9, allowing developers refresh view when…
Tutorial
22 views
Often, when doing SEO checkups, SEO specialist come up with adding Schema.org…
Tutorial
175 views
I needed to test my contracts against USDC contract, specifically I needed ERC-721 mint…
Tutorial
85 views
If you are a newbie like I am and struggling with setting the proper MYSQL my.cnf config…
Tutorial
25 views
I had trouble to set this up properly, because documentation is quite misleading or often…
Article
72 views
As the title says, DO NOT in any circumstances install ANY bitcoin price extension to ANY…
Tutorial
278 views
This is (or should be) a working example of sending some Ether between two addresses.…
Module
45 views
This list was fetched from Zapper, with their /v1/token-list endpoint. Which you can…
Tutorial
143 views
In the last months I am being pretty much bombarded by my clients with asking what…