How to run/load a separate javascript file selectively from inside javascript?

前端 未结 4 403
生来不讨喜
生来不讨喜 2021-01-24 16:01

I have 3 JavaScript files that I would like to load from an index.html file. I\'m choosing among them by using if statements which I only know how to d

4条回答
  •  花落未央
    2021-01-24 16:38

    UPDATE

    Things were already changing when I initially wrote this answer, but they have continued to change to the point where this answer is not somewhat obsolete. Please consult The 2014 Guide to Responsive Web Design as there are now ways to use media queries in a stylesheet to get the responsive layout you're looking for. Frameworks like Foundation and Bootstrap now offer responsive layouts and take care of a lot of the heavy lifting for you, so you can spend time designing your site instead of coding its plumbing.

    ORIGINAL ANSWER

    There are a few ways, but here's one (from dynamically loading an external JavaScript or CSS file, found by Google searching for "dynamic load javascript"):

    function loadjsfile(filename){
       var fileref = document.createElement('script');
       fileref.setAttribute('type', 'text/javascript');
       fileref.setAttribute('src', filename);
       if (typeof fileref !== 'undefined') {
          document.getElementsByTagName('head')[0].appendChild(fileref);
       }
    }
    
    loadjsfile("storybook.js"); //dynamically load and add this .js file
    

    Another way is, instead of dynamically loading the file, just load all the content you want in one file. Then, call the correct script. While this could be criticized for loading the entire file, what happens if your user changes his screen size? Maybe you want both resources loaded. Changing screen size is not so far-fetched as people resize windows, or even move a window to a different monitor with a different resolution.

    // storybook800.js
    function for800() {
       return {
          // all your module's stuff
       };
    };
    
    // storybook1600.js
    function for1600() {
       return {
          // all your module's stuff
       };
    };
    
    // main document
    var storybook;
    if (window.innerHeight === 800) {
       storybook = for800();
    } elseif (window.innerHeight === 1600) {
       storybook = for1600();
    }
    

    However, I don't really recommend either of those options. It's probably going to get really problematic maintaining separate files. Instead of loading completely different files, just detect within your code. Either pass in the window.innerHeight parameter or better, just detect it in your javascript file:

    //storybook.js
    function mystorybook() {
       if (window.innerHeight === 800) {
          //do something appropriate.
       }
    };
    

    If that seems painful, add some helper functions. For example, create a function that expects an object with various keys that contain size-dependent functions to run for different sizes. It might be called something like this:

    doSomethingSizeSensitive({
       800: function() {
       },
       1024: function() {
       },
       1600: function() {
       }
    });
    

    Then you could write code in that function that does the best job of selecting the correct result based on the current screen size and the passed in object keys. Instead of doSomethingSizeSensitive actually running the functions, it could return the appropriate function or value you passed in, which you then use or store:

    var myaction = getSizeSensitiveFunction({
       800: function() {
       },
       1024: function() {
       },
       1600: function() {
       }
    });
    myaction(); // for the rest of the lifecycle of the page, it does the right thing.
    

    You could have your function return anything--not just functions, but also values as well. And what if the screen size is 1280 or 1528 or some other strange size? You'll want to pick functionality intelligently. Think about how to abstract away the part that has to be different, by encoding it in objects or in detecting-style-functions that are called from other code, so the rest of your code can all be the same.

    Maybe you should have a whole setup object:

    sizedata = {
       800: {
          something1: function() {},
          value1: 'small'
       },
       1600: {
          something2: function() {},
          value2: 'large'
       },
    };
    

    In combination with a function to correctly choose the correct sizedata sub-object, now you're in golden shape any time you want to tweak something or add a new screen size. It's all in one place! You are in heaven when it comes time to fix or maintain.

提交回复
热议问题