Search code examples
gwtdeferred-loading

GWT: deferred loading of external JS resources


I have a widget depending on some external JS files, and I'd like to lazy load all these external resources. I've already used code splitting to lazy load the GWT code that concerns the widget, but the JS files defined in the gwt.xml, using the script tag, are loaded anyway, which is not desirable.

Is there a standard GWT way of loading these external resources on demand? I can do it myself using raw JS, but I'd rather not spend time on this too.


Solution

  • I think you'll want to take a look at the com.google.gwt.core.client.ScriptInjector class. From the javadocs:

    Dynamically create a script tag and attach it to the DOM.

    ...

    Usage with script loaded as URL:

       ScriptInjector.fromUrl("http://example.com/foo.js").setCallback(
         new Callback<Void, Exception>() {
            public void onFailure(Exception reason) {
              Window.alert("Script load failed.");
            }
            public void onSuccess(Void result) {
              Window.alert("Script load success.");
            }
         }).inject();
    

    This code can of course be invoked from within your split points, or indeed anywhere in your code.