With $.getScript I can load js files on the fly. Is it possible to \"unload\" some of these files ?
I have a ajax-based administrative panel. I have 3 sections. When
As pointed by Nick Craver it is hard to understand the reason of why you would want to do that.
However if there would be a valid reason to do so. I would put all the code of loaded script in a class. And when i would like to unload this, i would just assign it to null. eg.
//external file:
o1=new Object();
o1.function1=function(){
//blah blah blah
};
o1.function2=function(){
//blah blah blah
};
o1.var1=1;
//and if when i'll need to get rid of all of this i can just
o1=null;
I think that there are valid reasons to load and unload scripts. I have written a monitoring tool where content is swapped in and out of the center <div> all the time. Each load requires new functions to be attached to the just loaded content. If you (un)load js specific to the (un)loaded content, then the memory footprint stays small. And you can re-use previously defined function names for slightly different responses, while writing generic xhtml.
Assume a <div> with info on a peace of data. The user wants to edit that specific record so the <div> content is replaced by a form with all kinds of behaviors on buttons, checkboxes, etc. The form is subitted and the <div> is replaced with the original content but reflecting the changes. The form is gone and so is the need for any associated behavior.
I.m.h.o. loading in a certain <div> on your page x.htm + x.css + x.js and replacing them when other content and behavior is needed is by far preferrable over re-analyzing the new content and attach all possible responses even if certain nodes or classes are missing in the new content.
Instead of large javascript files, a set of pluggable js modules keeps my code well-organized and the maintenance of ajax behaviors relatively easy. Support for such a scheme in jQuery would be a tremendous help (for me).
What I would do in this case would be to make all your JavaScript code part of an object structure then simply set the object to null once done with it.
var myObj = {
"property1": true,
"property2": "Hello my name is Sam.",
"mynamedfunction": function(){
//do stuff
},
"othernamedfunction": function(){
//do other stuff
}
};
Once done set myObj=null;
So rather than loading and unloading a file you are loading and unloading an object as needed! So you would load the file containing the object in, but then set the object to null once done with it, you can even load it in again after destroying it this way.
"Unloading", if it were really possible, wouldn't make much sense here. Let's take a step back and look at why you don't load all the files to begin with:
Now look at it from the other side, you have loaded them, which means both of the above have already happened, you paid the request cost of getting them and what they've done. Also, what effect they had on the page can't be generically undone. Just by removing a <script>
doesn't remove the functions it declared, event handlers it attached, etc.
In short, why are you trying to unload? If it's to remove the effects, well that one's not easy, not in a generic way anyway. If it's to lighten the page...there's no benefit here, you'll actually just incur the cost of removing the element, with no benefit for the client on the JavaScript side of things.
You can simply append and remove js files from head:
$('script').last().remove();`//remove last file from html file
$('head').append('<script src=""></script>'); //add js file