Js head Append script





.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}







2















While appending a script tag programmatically after the head element,



head.appendChild(script_elm);


within this above script element, i am defining a variable. If i want to access the variable which is defining within the script tag, it does not work immediately after the head append. Why?










share|improve this question

























  • If you are loading an external JavaScript file you must wait it to be fully loaded before accessing to variables.

    – DanieleAlessandra
    Jan 3 at 12:07











  • Possible duplicate of Call javascript function after script is loaded

    – Daut
    Jan 3 at 12:23


















2















While appending a script tag programmatically after the head element,



head.appendChild(script_elm);


within this above script element, i am defining a variable. If i want to access the variable which is defining within the script tag, it does not work immediately after the head append. Why?










share|improve this question

























  • If you are loading an external JavaScript file you must wait it to be fully loaded before accessing to variables.

    – DanieleAlessandra
    Jan 3 at 12:07











  • Possible duplicate of Call javascript function after script is loaded

    – Daut
    Jan 3 at 12:23














2












2








2








While appending a script tag programmatically after the head element,



head.appendChild(script_elm);


within this above script element, i am defining a variable. If i want to access the variable which is defining within the script tag, it does not work immediately after the head append. Why?










share|improve this question
















While appending a script tag programmatically after the head element,



head.appendChild(script_elm);


within this above script element, i am defining a variable. If i want to access the variable which is defining within the script tag, it does not work immediately after the head append. Why?







javascript html






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Jan 3 at 13:11









Deepak Keynes

82221333




82221333










asked Jan 3 at 12:03









MasterOfDesasterMasterOfDesaster

1136




1136













  • If you are loading an external JavaScript file you must wait it to be fully loaded before accessing to variables.

    – DanieleAlessandra
    Jan 3 at 12:07











  • Possible duplicate of Call javascript function after script is loaded

    – Daut
    Jan 3 at 12:23



















  • If you are loading an external JavaScript file you must wait it to be fully loaded before accessing to variables.

    – DanieleAlessandra
    Jan 3 at 12:07











  • Possible duplicate of Call javascript function after script is loaded

    – Daut
    Jan 3 at 12:23

















If you are loading an external JavaScript file you must wait it to be fully loaded before accessing to variables.

– DanieleAlessandra
Jan 3 at 12:07





If you are loading an external JavaScript file you must wait it to be fully loaded before accessing to variables.

– DanieleAlessandra
Jan 3 at 12:07













Possible duplicate of Call javascript function after script is loaded

– Daut
Jan 3 at 12:23





Possible duplicate of Call javascript function after script is loaded

– Daut
Jan 3 at 12:23












2 Answers
2






active

oldest

votes


















3














You need to wait for the script to be loaded. as @DanieleAlessandra comments



 script_elem.onload = function() {
// some code
};


see this question



Call javascript function after script is loaded






share|improve this answer


























  • Wow, didnt thought it would be this simple, thanks

    – MasterOfDesaster
    Jan 3 at 12:25











  • Personally I would never "wait" for a single piece of script to load a single variable. I would suggest either using an ajax call to request the variable, or use a serversided preprocessor (like PHP) or simply include the script in the head and wait for the DOMContentLoaded event.

    – BRO_THOM
    Jan 3 at 13:18





















1














Be sure to make access to that variable available through your script.
For example, external-script.js



window.externalScript = function () {

const yourVariable = //do some magic here;
this.scriptVariable = yourVariable;
// your code
}


Then you can use this variable in your onload function like so:



script_elem.onload = () => {
if (window.externalScript &&
window.externalScript().scriptVariable) {
//do whatever you want to do with your script variable.
}
}





share|improve this answer
























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54021933%2fjs-head-append-script%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    2 Answers
    2






    active

    oldest

    votes








    2 Answers
    2






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    3














    You need to wait for the script to be loaded. as @DanieleAlessandra comments



     script_elem.onload = function() {
    // some code
    };


    see this question



    Call javascript function after script is loaded






    share|improve this answer


























    • Wow, didnt thought it would be this simple, thanks

      – MasterOfDesaster
      Jan 3 at 12:25











    • Personally I would never "wait" for a single piece of script to load a single variable. I would suggest either using an ajax call to request the variable, or use a serversided preprocessor (like PHP) or simply include the script in the head and wait for the DOMContentLoaded event.

      – BRO_THOM
      Jan 3 at 13:18


















    3














    You need to wait for the script to be loaded. as @DanieleAlessandra comments



     script_elem.onload = function() {
    // some code
    };


    see this question



    Call javascript function after script is loaded






    share|improve this answer


























    • Wow, didnt thought it would be this simple, thanks

      – MasterOfDesaster
      Jan 3 at 12:25











    • Personally I would never "wait" for a single piece of script to load a single variable. I would suggest either using an ajax call to request the variable, or use a serversided preprocessor (like PHP) or simply include the script in the head and wait for the DOMContentLoaded event.

      – BRO_THOM
      Jan 3 at 13:18
















    3












    3








    3







    You need to wait for the script to be loaded. as @DanieleAlessandra comments



     script_elem.onload = function() {
    // some code
    };


    see this question



    Call javascript function after script is loaded






    share|improve this answer















    You need to wait for the script to be loaded. as @DanieleAlessandra comments



     script_elem.onload = function() {
    // some code
    };


    see this question



    Call javascript function after script is loaded







    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited Jan 3 at 12:21

























    answered Jan 3 at 12:14









    sferretsferret

    336213




    336213













    • Wow, didnt thought it would be this simple, thanks

      – MasterOfDesaster
      Jan 3 at 12:25











    • Personally I would never "wait" for a single piece of script to load a single variable. I would suggest either using an ajax call to request the variable, or use a serversided preprocessor (like PHP) or simply include the script in the head and wait for the DOMContentLoaded event.

      – BRO_THOM
      Jan 3 at 13:18





















    • Wow, didnt thought it would be this simple, thanks

      – MasterOfDesaster
      Jan 3 at 12:25











    • Personally I would never "wait" for a single piece of script to load a single variable. I would suggest either using an ajax call to request the variable, or use a serversided preprocessor (like PHP) or simply include the script in the head and wait for the DOMContentLoaded event.

      – BRO_THOM
      Jan 3 at 13:18



















    Wow, didnt thought it would be this simple, thanks

    – MasterOfDesaster
    Jan 3 at 12:25





    Wow, didnt thought it would be this simple, thanks

    – MasterOfDesaster
    Jan 3 at 12:25













    Personally I would never "wait" for a single piece of script to load a single variable. I would suggest either using an ajax call to request the variable, or use a serversided preprocessor (like PHP) or simply include the script in the head and wait for the DOMContentLoaded event.

    – BRO_THOM
    Jan 3 at 13:18







    Personally I would never "wait" for a single piece of script to load a single variable. I would suggest either using an ajax call to request the variable, or use a serversided preprocessor (like PHP) or simply include the script in the head and wait for the DOMContentLoaded event.

    – BRO_THOM
    Jan 3 at 13:18















    1














    Be sure to make access to that variable available through your script.
    For example, external-script.js



    window.externalScript = function () {

    const yourVariable = //do some magic here;
    this.scriptVariable = yourVariable;
    // your code
    }


    Then you can use this variable in your onload function like so:



    script_elem.onload = () => {
    if (window.externalScript &&
    window.externalScript().scriptVariable) {
    //do whatever you want to do with your script variable.
    }
    }





    share|improve this answer




























      1














      Be sure to make access to that variable available through your script.
      For example, external-script.js



      window.externalScript = function () {

      const yourVariable = //do some magic here;
      this.scriptVariable = yourVariable;
      // your code
      }


      Then you can use this variable in your onload function like so:



      script_elem.onload = () => {
      if (window.externalScript &&
      window.externalScript().scriptVariable) {
      //do whatever you want to do with your script variable.
      }
      }





      share|improve this answer


























        1












        1








        1







        Be sure to make access to that variable available through your script.
        For example, external-script.js



        window.externalScript = function () {

        const yourVariable = //do some magic here;
        this.scriptVariable = yourVariable;
        // your code
        }


        Then you can use this variable in your onload function like so:



        script_elem.onload = () => {
        if (window.externalScript &&
        window.externalScript().scriptVariable) {
        //do whatever you want to do with your script variable.
        }
        }





        share|improve this answer













        Be sure to make access to that variable available through your script.
        For example, external-script.js



        window.externalScript = function () {

        const yourVariable = //do some magic here;
        this.scriptVariable = yourVariable;
        // your code
        }


        Then you can use this variable in your onload function like so:



        script_elem.onload = () => {
        if (window.externalScript &&
        window.externalScript().scriptVariable) {
        //do whatever you want to do with your script variable.
        }
        }






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Jan 3 at 13:14









        darth-coderdarth-coder

        17713




        17713






























            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54021933%2fjs-head-append-script%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            MongoDB - Not Authorized To Execute Command

            Npm cannot find a required file even through it is in the searched directory

            in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith