jQuery getScript method's internal process
Asked Answered
I

2

5

I am trying to understand the internal process of getScript. I am aware that it uses $.get method interally.I was thinking that jQuery puts a script tag reference into the DOM for being able execute that js file but I couldn't find script references of loaded scripts by getScript in the DOM .

So how does jQuery execute loaded scripts without script tag references in the DOM?

$.getScript('gallery.js') is exactly same thing with $('<script src="gallery.js">').appendTo('body') ?

Ironware answered 10/7, 2011 at 15:56 Comment(0)
E
7

This is the interesting part in the source code.

jQuery seems to just receive the text and evaluates it in global scope:

converters: {
    "text script": function( text ) {
        jQuery.globalEval( text );
        return text;
    }
}

In case you load the script from a different domain, jQuery adds a new script tag:

head.insertBefore( script, head.firstChild );

but removes it once the code was loaded:

// Remove the script
if ( head && script.parentNode ) {
    head.removeChild( script );
}
Eolithic answered 10/7, 2011 at 16:5 Comment(1)
Even jQuery remove added scripts. Try this $('<script src="sample.js">').appendTo('body');Ironware
A
5

Luke, use the source.

(note these links are to an old commit)

Alby answered 10/7, 2011 at 15:59 Comment(3)
@ZMorek yes. This answer is 18 months old, and jQuery has continued active development. I've updated to link to a revision from back then.Alby
@MattBall - can/would you update it again please? :)Polonaise
You found the source, but I don't know that you've used the source to answer "how". And that's really the most important part of the source: the using. Anybody can just find them (though I have to admit I'm really happy that you did). (apologies to Jerry)Gondolier

© 2022 - 2024 — McMap. All rights reserved.