- Issue created by @ashetkar
- Status changed to Postponed: needs info
almost 2 years ago 2:57pm 24 January 2023 There is a syntax error with JavaScript on that site. Turn off JavaScript aggregation to find out the full details.
- Status changed to Active
almost 2 years ago 12:21am 27 January 2023 - ๐บ๐ฆUkraine cosolom
I also have this. I use advagg. When I disabled aggregation on /admin/config/development/performance I don't have error. But with enabled (even if Advagg js minification disabled) I see the error in console and any view edit page is broken
- ๐จ๐ฆCanada lindsay.wils
I am also having this error. Disabled AddVagg didnt fix the issue, I had to disable both AdvAgg AND core js minification, so this does not seem to be isolated to this module.
- ๐จ๐ฆCanada lindsay.wils
I was able to fix my issue by just adding core/loadjs to my theme libraries dependencies
- Assigned to mmd
- @mmd opened merge request.
- Issue was unassigned.
- Status changed to Needs review
almost 2 years ago 12:49pm 1 February 2023 - ๐บ๐ฆUkraine mmd
The issue is related to default Drupal aggregation. The Loadjs library is used in drupal.ajax to add Js files. Added weight to loadjs file to move up the code in the aggregation file.
- ๐บ๐ธUnited States ekorotkin
I created a patch that is working well for me on Core 9.5.3. I am attaching it here for use while we wait for the code to be added to the core branches.
Hope it works for you all.
- Status changed to Postponed: needs info
almost 2 years ago 1:05am 14 February 2023 Someone please add clear steps to reproduce to the issue summary so we can characterize the bug and test the solutions.
Just to be clear: we don't comment out lines. Just change the code as needed.
Someone please add clear steps to reproduce to the issue summary so we can characterize the bug and test the solutions.
- ๐บ๐ธUnited States ekorotkin
My issue that I was seeing was the following:
- Drupal Core 9.5.3
- Running PHP 7.4 and MySQL 5.7
- Poll Module installed at version 8.x-1.5When placing a new poll styled in my theme in the footer of a site, the poll would not display at all for anonymous users. It worked perfectly fine for logged in users.
The console error was "Uncaught ReferenceError: loadjs is not defined in site"
Let me know if you need more information.
Interesting! Please add those steps to the issue summary, then we can remove the tag and move this along.
Can you reproduce that on https://simplytest.me/ ? Thatโs a quick way to ensure the bug reproduction is valid. Itโs admin/admin to log in one of those sites.
Thank you!
- Status changed to Needs work
almost 2 years ago 11:42am 15 February 2023 - ๐ง๐ชBelgium herved
Same here with views_infinite_scroll 2.0.1 (drupal 9.5.x, PHP 8.0).
When logged in it works though. I noticed the loadjs library gets added much later as anonymous.
The patch seems to solve the issue.
I will investigate further when I have some time. - ๐บ๐ธUnited States ekorotkin
Seems the poll module is not available on https://simplytest.me
That is unfortunate. I commented on #3314942: Missing project(s) from dropdown โ .
It looks like infinite scroll is available.
- ๐ซ๐ทFrance nod_ Lille
could be similar to #1988968-322: Drupal.ajax does not guarantee that "add new JS file to page" commands have finished before calling said JS โ ?
Is the dependency to loadjs declared properly in the libraries that uses it as said in #9? Using weight is usually a indication that dependencies are not declared properly
- ๐ณ๐ฑNetherlands askibinski
Stumbled upon this issue when having the same problem. Can confirm setting the proper dependency fixes the issue, so this issue is probably works as designed.
- ๐ง๐ชBelgium herved
Interesting, in my case it is not a dependency missing but some custom JS behaviors had the "use strict" directive directly in the file, in the global scope as follows:
"use strict"; (function ($, Drupal, once) { // some custom JS behavior. })(jQuery, Drupal, once);
Moving this directive within the function solves the issue.
I guess this is due to the fact that loadjs doesn't declare itself usingvar
?loadjs = function() {...}();
Why is it like this?
- ๐บ๐ธUnited States kevinquillen
I was getting this in 9.5.0 on a site. I had to disable aggregation and clear the cache. After that I could use the core media library modal again.
- ๐ฑ๐ปLatvia biguzis
By adding
core/loadjs
in custom theme, error was gone (same as #9) - ๐ฉ๐ชGermany Anybody Porta Westfalica
Just ran into this issue. For me it occurs when adding any JS asset via asset_injector โ .
Adding a
console.log('X');
is enough.I created an issue there: ๐ Getting "loadjs is not defined" error when adding any JS asset Closed: won't fix
But I guess this issue is the root cause. - ๐ง๐ชBelgium herved
Glad to hear @Anybody!
I think a lot of people are having this issue because of that.
Raising/changing the dependencies is only a workaround which pushes the loadjs definition above the strict directive.To anyone who had or have this issue: please double check and ensure that you do not have any
"use strict"
in the global scope. - ๐จ๐ดColombia diarcastro
I think the problem is because the variable is not defined and if we run JS in a strict mode that error jumps.
I just created a simple patch to fix the issue and the fix is only defining the variable.
It worked for me on Drupal 9.5.x. - last update
almost 2 years ago 30,322 pass - ๐ฉ๐ชGermany Anybody Porta Westfalica
Well #30 is definitely the case and it's something that can happen in any library or module and break the site. So I'm not against looking for fixes like #32, but
It should then happen in the loadjs library I guess (https://github.com/muicss/loadjs ?)
Code-wise I don'tvar loadjs
would be correct, instead I'd tend towindow.loadjs
?But proof me wrong and I guess there's a reason for the current implementation (hopefully)? ;)
- ๐จ๐ดColombia diarcastro
@Anybody (#33) having that the loadjs script is loaded in the global scope we don't need to use `window.loadjs = ...` because `var loadjs = ...` will be in the same scope and `window.loadjs === loadjs`, so we don't need to define the variable directly in the window object.
And you are right that's fix should be done in the LoadJS Library instead.
I made a quick example here https://codepen.io/diarcastro/pen/BaqQwxg
- ๐บ๐ธUnited States fskreuz
Can confirm #31.
In our case, we have compiled JS in modules/themes whose output automatically gets a file-level
"use strict";
. This makes sense if the compiled JS is evaluated on its own (e.g. added via its own script tag, or eval'ed on its own).But since that compiled JS is added as a library, it is subject to aggregation. Drupal aggregation is just a simple "concat a bunch of JS" operation, which means ANY JS that's aggregated together with one that has a file-level
"use strict";
is evaluated in strict mode entirely - and will break some arbitrary library that wasn't expecting it.Also, for regular scripts, "sloppy mode" is the browser's default execution mode while strict mode is opt-in. Although strict mode is encouraged, one cannot assume all scripts are written in strict mode. This may be the case for loadjs.
- https://developer.mozilla.org/en-US/docs/Glossary/Sloppy_mode
- https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Strict...So to sum it up:
- Aggregation can cause scripts declaring strict mode to be concatenated with ones that don't expect strict mode, breaking the latter.
- Therefore JS included in libraries SHOULD NOT have a file-level"use strict";
to avoid breakage.
- Any JS that is explicitly enforcing strict mode should move"use strict";
from a file-level to a function-level (e.g. wrap your script in an IIFE with"use strict";
)
- No changes are needed for loadjs. Instead, fix the code introducing"use strict";
with the suggestion above. - ๐ฉ๐ชGermany thomaswalther Rhein-Main Area
#9 worked for me: addding theme dependancy "core/loadjs"
- ๐จ๐ฆCanada joseph.olstad
Just hit this, was driving me bonkers. I'm going to try the latest patch.
- ๐จ๐ฆCanada joseph.olstad
Patch #32 works for us, thank you!
I do not know how exactly to reproduce the issue because it only affected some of our environments, very strange. The patch #32 fixes the glitch.
- Status changed to Needs review
over 1 year ago 6:29am 18 October 2023 - ๐ฉ๐ชGermany Anybody Porta Westfalica
Settings this to NR for #32, still I'm not enough JS expert to tell about possible side effects. Is here someone who can tell?
@joseph.olstad did you grep your code for #30 / #35 as root cause?
Still I think it would be better to be safe this can't happen even with strict mode enabled in global space. We now have clear steps to reproduce described in #30-35
- Status changed to Needs work
over 1 year ago 2:58pm 18 October 2023 - ๐บ๐ธUnited States smustgrave
Will need a test case but not sure we should be patching an asset library. Could be wrong there but I really doubt it.
- ๐จ๐ฆCanada joseph.olstad
@Anybody,
I did grep my code for #30 / #35 as a root cause, wow, that was intense!The fix should be done in the loadjs library, all you have to do is try to fix this in your project without the patch and then lose your marbles.
The simple fix proposed by patch #32 vastly improves "developer experience".
Hi there,
I was updating Drupal-recommended from 10.2.0 to 10.3.1. Everything went smooth, in exception for the "loadjs is not defined".
I followed what you guys did here, but the patch is not being installed (load_js-define_variable-3336143-43.patch) #43.
I also tried to modify the loadjs.min.js file by myself, adding "var" as per the patch, but I still receive the error.Is there something I am missing?
Dear anybody ,
I grep in my code, and I noticed I have many js with "use strict" at file level, like:
drupal/core/assets/vendor/jquery.ui/ui/data.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/disable-selection.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/focusable.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/form-reset-mixin.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/form.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/ie.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/jquery-patch.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/jquery-patch.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/keycode.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/labels.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/plugin.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/safe-active-element.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/safe-blur.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/scroll-parent.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/unique-id.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/version.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widget.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/autocomplete.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/button.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/checkboxradio.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/controlgroup.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/dialog.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/draggable.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/menu.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/mouse.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/resizable.js:"use strict";
drupal/core/assets/vendor/jquery/jquery.js:"use strict";
drupal/core/scripts/js/ckeditor5-check-plugins.js:"use strict";
drupal/core/scripts/js/ckeditor5-check-plugins.js:"use strict";Do you think I should proceed with moving all the "use strict" at the "functional level" as suggested? It doesn't seem to me to be the best solution.
N.B.: disabling the aggregation I don't receive the error, but seems like some components work differently as they should.Dear anybody,
yes, I grep on my code, and i found all these files having the "use script" at the file level:
drupal/core/assets/vendor/jquery.ui/ui/data.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/disable-selection.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/focusable.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/form-reset-mixin.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/form.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/ie.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/jquery-patch.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/jquery-patch.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/keycode.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/labels.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/plugin.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/safe-active-element.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/safe-blur.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/scroll-parent.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/unique-id.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/version.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widget.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/autocomplete.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/button.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/checkboxradio.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/controlgroup.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/dialog.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/draggable.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/menu.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/mouse.js:"use strict";
drupal/core/assets/vendor/jquery.ui/ui/widgets/resizable.js:"use strict";
drupal/core/assets/vendor/jquery/jquery.js:"use strict";
drupal/core/scripts/js/ckeditor5-check-plugins.js:"use strict";
drupal/core/scripts/js/ckeditor5-check-plugins.js:"use strict";Do I have to modify all of them, moving the "use script" at functional level? It doesn't seem to be the best solution..
- ๐บ๐ธUnited States fskreuz
- The "use strict" on the jQuery UI scripts are inside IIFEs, so those should be safe when aggregated.
- ckeditor5-check-plugins.js is only used in build tooling, i.e. Node.js (it has a note in the script), so its file-level "use strict" is irrelevant.The problem might be elsewhere. Check your custom and contrib modules and themes.
I'm sorry, you are right.
there is only a file in drupal/core/assets/vendor/shepherd/shepherd.min.js that begins with 'use strict'.I also noticed that loadjs.min.js is not in Unix format but in Windows format, which is different from all the other js being used. Changing it will not affect the error that is displayed, nevertheless.