Why do variable in an inner function return nan when there is the same variable name at the inner function declared after log The Next CEO of Stack OverflowWhat is the naming convention in Python for variable and function names?How to execute a JavaScript function when I have its name as a stringWhat is a practical use for a closure in JavaScript?Javascript by reference vs. by valueWhy aren't ◎ܫ◎ and ☺ valid JavaScript variable names?What is the explanation for these bizarre JavaScript behaviours mentioned in the 'Wat' talk for CodeMash 2012?Is the recommendation to include CSS before JavaScript invalid?variable not writable in inner functionjavascript variable returning NaNFunction returns NaN when it shouldn't

What flight has the highest ratio of time difference to flight time?

What is "(CFMCC)" on an ILS approach chart?

Why do airplanes bank sharply to the right after air-to-air refueling?

"In the right combination" vs "with the right combination"?

Return the Closest Prime Number

Make solar eclipses exceedingly rare, but still have new moons

How do I reset passwords on multiple websites easily?

How do we know the LHC results are robust?

What can we do to stop prior company from asking us questions?

Is there a way to save my career from absolute disaster?

Why has the US not been more assertive in confronting Russia in recent years?

Is it my responsibility to learn a new technology in my own time my employer wants to implement?

Can you replace a racial trait cantrip when leveling up?

Complex fractions

If a black hole is created from light, can this black hole then move at speed of light?

Sending manuscript to multiple publishers

How to invert MapIndexed on a ragged structure? How to construct a tree from rules?

Why do variable in an inner function return nan when there is the same variable name at the inner function declared after log

What connection does MS Office have to Netscape Navigator?

Should I tutor a student who I know has cheated on their homework?

Contours of a clandestine nature

If/When UK leaves the EU, can a future goverment conduct a referendum to join the EU?

Why didn't Khan get resurrected in the Genesis Explosion?

Received an invoice from my ex-employer billing me for training; how to handle?



Why do variable in an inner function return nan when there is the same variable name at the inner function declared after log



The Next CEO of Stack OverflowWhat is the naming convention in Python for variable and function names?How to execute a JavaScript function when I have its name as a stringWhat is a practical use for a closure in JavaScript?Javascript by reference vs. by valueWhy aren't ◎ܫ◎ and ☺ valid JavaScript variable names?What is the explanation for these bizarre JavaScript behaviours mentioned in the 'Wat' talk for CodeMash 2012?Is the recommendation to include CSS before JavaScript invalid?variable not writable in inner functionjavascript variable returning NaNFunction returns NaN when it shouldn't










6















What's happening here? I get a different result if I declare a variable after console.log in the inner function



I understand that var has a functional scope and inner function can access the variable from their parent






function outer() 
var a = 2;

function inner()
a++;
console.log(a) //log NaN
var a = 8

inner()

outer()








function outer() 
var a = 2;

function inner()
a++;
console.log(a) //log 3
var b = 8

inner()

outer()





The log returns NaN in the first example and log 3 in the second example










share|improve this question




























    6















    What's happening here? I get a different result if I declare a variable after console.log in the inner function



    I understand that var has a functional scope and inner function can access the variable from their parent






    function outer() 
    var a = 2;

    function inner()
    a++;
    console.log(a) //log NaN
    var a = 8

    inner()

    outer()








    function outer() 
    var a = 2;

    function inner()
    a++;
    console.log(a) //log 3
    var b = 8

    inner()

    outer()





    The log returns NaN in the first example and log 3 in the second example










    share|improve this question


























      6












      6








      6


      1






      What's happening here? I get a different result if I declare a variable after console.log in the inner function



      I understand that var has a functional scope and inner function can access the variable from their parent






      function outer() 
      var a = 2;

      function inner()
      a++;
      console.log(a) //log NaN
      var a = 8

      inner()

      outer()








      function outer() 
      var a = 2;

      function inner()
      a++;
      console.log(a) //log 3
      var b = 8

      inner()

      outer()





      The log returns NaN in the first example and log 3 in the second example










      share|improve this question
















      What's happening here? I get a different result if I declare a variable after console.log in the inner function



      I understand that var has a functional scope and inner function can access the variable from their parent






      function outer() 
      var a = 2;

      function inner()
      a++;
      console.log(a) //log NaN
      var a = 8

      inner()

      outer()








      function outer() 
      var a = 2;

      function inner()
      a++;
      console.log(a) //log 3
      var b = 8

      inner()

      outer()





      The log returns NaN in the first example and log 3 in the second example






      function outer() 
      var a = 2;

      function inner()
      a++;
      console.log(a) //log NaN
      var a = 8

      inner()

      outer()





      function outer() 
      var a = 2;

      function inner()
      a++;
      console.log(a) //log NaN
      var a = 8

      inner()

      outer()





      function outer() 
      var a = 2;

      function inner()
      a++;
      console.log(a) //log 3
      var b = 8

      inner()

      outer()





      function outer() 
      var a = 2;

      function inner()
      a++;
      console.log(a) //log 3
      var b = 8

      inner()

      outer()






      javascript function






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited 46 mins ago









      Nick Parsons

      10.3k2926




      10.3k2926










      asked 54 mins ago









      ClaudeClaude

      426




      426






















          3 Answers
          3






          active

          oldest

          votes


















          10














          This is due to hoisting



          The declaration of a in the inner function is hoisted to the top of the function, overriding the outer function's a, so a is undefined



          undefined++ returns NaN, hence your result.



          Your code is equivalent to:



          function outer() 
          var a=2;

          function inner()
          var a;
          a++;
          console.log(a); //log NaN
          a = 8;


          inner();


          outer();


          Rewriting your code in this way makes it easy to see what's going on.






          share|improve this answer
































            1














            Because var is hoisted through the function, you're essentially running undefined++ which is NaN. If you remove var a = 8 in inner, the code works as expected:






            function outer() 
            var a = 2;

            function inner()
            a++;
            console.log(a);

            inner();

            outer();








            share|improve this answer






























              -1














              var a=0;
              function outer()
              a=2;
              function inner()
              a=a+1;
              console.log(a)
              a = 8

              inner()

              outer()





              share|improve this answer


















              • 3





                How does this piece of code explains the issue? Can you provide an explanation of the code you have posted?

                – Shidersz
                39 mins ago











              • They can’t access the inner function value so we have to defined globally. After globally you can use A value anywhere in the code

                – Darshit Shah
                37 mins ago











              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%2f55428371%2fwhy-do-variable-in-an-inner-function-return-nan-when-there-is-the-same-variable%23new-answer', 'question_page');

              );

              Post as a guest















              Required, but never shown

























              3 Answers
              3






              active

              oldest

              votes








              3 Answers
              3






              active

              oldest

              votes









              active

              oldest

              votes






              active

              oldest

              votes









              10














              This is due to hoisting



              The declaration of a in the inner function is hoisted to the top of the function, overriding the outer function's a, so a is undefined



              undefined++ returns NaN, hence your result.



              Your code is equivalent to:



              function outer() 
              var a=2;

              function inner()
              var a;
              a++;
              console.log(a); //log NaN
              a = 8;


              inner();


              outer();


              Rewriting your code in this way makes it easy to see what's going on.






              share|improve this answer





























                10














                This is due to hoisting



                The declaration of a in the inner function is hoisted to the top of the function, overriding the outer function's a, so a is undefined



                undefined++ returns NaN, hence your result.



                Your code is equivalent to:



                function outer() 
                var a=2;

                function inner()
                var a;
                a++;
                console.log(a); //log NaN
                a = 8;


                inner();


                outer();


                Rewriting your code in this way makes it easy to see what's going on.






                share|improve this answer



























                  10












                  10








                  10







                  This is due to hoisting



                  The declaration of a in the inner function is hoisted to the top of the function, overriding the outer function's a, so a is undefined



                  undefined++ returns NaN, hence your result.



                  Your code is equivalent to:



                  function outer() 
                  var a=2;

                  function inner()
                  var a;
                  a++;
                  console.log(a); //log NaN
                  a = 8;


                  inner();


                  outer();


                  Rewriting your code in this way makes it easy to see what's going on.






                  share|improve this answer















                  This is due to hoisting



                  The declaration of a in the inner function is hoisted to the top of the function, overriding the outer function's a, so a is undefined



                  undefined++ returns NaN, hence your result.



                  Your code is equivalent to:



                  function outer() 
                  var a=2;

                  function inner()
                  var a;
                  a++;
                  console.log(a); //log NaN
                  a = 8;


                  inner();


                  outer();


                  Rewriting your code in this way makes it easy to see what's going on.







                  share|improve this answer














                  share|improve this answer



                  share|improve this answer








                  edited 36 mins ago









                  Shidersz

                  9,3112933




                  9,3112933










                  answered 49 mins ago









                  jrojro

                  572115




                  572115























                      1














                      Because var is hoisted through the function, you're essentially running undefined++ which is NaN. If you remove var a = 8 in inner, the code works as expected:






                      function outer() 
                      var a = 2;

                      function inner()
                      a++;
                      console.log(a);

                      inner();

                      outer();








                      share|improve this answer



























                        1














                        Because var is hoisted through the function, you're essentially running undefined++ which is NaN. If you remove var a = 8 in inner, the code works as expected:






                        function outer() 
                        var a = 2;

                        function inner()
                        a++;
                        console.log(a);

                        inner();

                        outer();








                        share|improve this answer

























                          1












                          1








                          1







                          Because var is hoisted through the function, you're essentially running undefined++ which is NaN. If you remove var a = 8 in inner, the code works as expected:






                          function outer() 
                          var a = 2;

                          function inner()
                          a++;
                          console.log(a);

                          inner();

                          outer();








                          share|improve this answer













                          Because var is hoisted through the function, you're essentially running undefined++ which is NaN. If you remove var a = 8 in inner, the code works as expected:






                          function outer() 
                          var a = 2;

                          function inner()
                          a++;
                          console.log(a);

                          inner();

                          outer();








                          function outer() 
                          var a = 2;

                          function inner()
                          a++;
                          console.log(a);

                          inner();

                          outer();





                          function outer() 
                          var a = 2;

                          function inner()
                          a++;
                          console.log(a);

                          inner();

                          outer();






                          share|improve this answer












                          share|improve this answer



                          share|improve this answer










                          answered 46 mins ago









                          Jack BashfordJack Bashford

                          13.8k31848




                          13.8k31848





















                              -1














                              var a=0;
                              function outer()
                              a=2;
                              function inner()
                              a=a+1;
                              console.log(a)
                              a = 8

                              inner()

                              outer()





                              share|improve this answer


















                              • 3





                                How does this piece of code explains the issue? Can you provide an explanation of the code you have posted?

                                – Shidersz
                                39 mins ago











                              • They can’t access the inner function value so we have to defined globally. After globally you can use A value anywhere in the code

                                – Darshit Shah
                                37 mins ago















                              -1














                              var a=0;
                              function outer()
                              a=2;
                              function inner()
                              a=a+1;
                              console.log(a)
                              a = 8

                              inner()

                              outer()





                              share|improve this answer


















                              • 3





                                How does this piece of code explains the issue? Can you provide an explanation of the code you have posted?

                                – Shidersz
                                39 mins ago











                              • They can’t access the inner function value so we have to defined globally. After globally you can use A value anywhere in the code

                                – Darshit Shah
                                37 mins ago













                              -1












                              -1








                              -1







                              var a=0;
                              function outer()
                              a=2;
                              function inner()
                              a=a+1;
                              console.log(a)
                              a = 8

                              inner()

                              outer()





                              share|improve this answer













                              var a=0;
                              function outer()
                              a=2;
                              function inner()
                              a=a+1;
                              console.log(a)
                              a = 8

                              inner()

                              outer()






                              share|improve this answer












                              share|improve this answer



                              share|improve this answer










                              answered 46 mins ago









                              Darshit ShahDarshit Shah

                              53




                              53







                              • 3





                                How does this piece of code explains the issue? Can you provide an explanation of the code you have posted?

                                – Shidersz
                                39 mins ago











                              • They can’t access the inner function value so we have to defined globally. After globally you can use A value anywhere in the code

                                – Darshit Shah
                                37 mins ago












                              • 3





                                How does this piece of code explains the issue? Can you provide an explanation of the code you have posted?

                                – Shidersz
                                39 mins ago











                              • They can’t access the inner function value so we have to defined globally. After globally you can use A value anywhere in the code

                                – Darshit Shah
                                37 mins ago







                              3




                              3





                              How does this piece of code explains the issue? Can you provide an explanation of the code you have posted?

                              – Shidersz
                              39 mins ago





                              How does this piece of code explains the issue? Can you provide an explanation of the code you have posted?

                              – Shidersz
                              39 mins ago













                              They can’t access the inner function value so we have to defined globally. After globally you can use A value anywhere in the code

                              – Darshit Shah
                              37 mins ago





                              They can’t access the inner function value so we have to defined globally. After globally you can use A value anywhere in the code

                              – Darshit Shah
                              37 mins ago

















                              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%2f55428371%2fwhy-do-variable-in-an-inner-function-return-nan-when-there-is-the-same-variable%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

                              Францішак Багушэвіч Змест Сям'я | Біяграфія | Творчасць | Мова Багушэвіча | Ацэнкі дзейнасці | Цікавыя факты | Спадчына | Выбраная бібліяграфія | Ушанаванне памяці | У філатэліі | Зноскі | Літаратура | Спасылкі | НавігацыяЛяхоўскі У. Рупіўся дзеля Бога і людзей: Жыццёвы шлях Лявона Вітан-Дубейкаўскага // Вольскі і Памідораў з песняй пра немца Адвакат, паэт, народны заступнік Ашмянскі веснікВ Минске появится площадь Богушевича и улица Сырокомли, Белорусская деловая газета, 19 июля 2001 г.Айцец беларускай нацыянальнай ідэі паўстаў у бронзе Сяргей Аляксандравіч Адашкевіч (1918, Мінск). 80-я гады. Бюст «Францішак Багушэвіч».Яўген Мікалаевіч Ціхановіч. «Партрэт Францішка Багушэвіча»Мікола Мікалаевіч Купава. «Партрэт зачынальніка новай беларускай літаратуры Францішка Багушэвіча»Уладзімір Іванавіч Мелехаў. На помніку «Змагарам за родную мову» Барэльеф «Францішак Багушэвіч»Памяць пра Багушэвіча на Віленшчыне Страчаная сталіца. Беларускія шыльды на вуліцах Вільні«Krynica». Ideologia i przywódcy białoruskiego katolicyzmuФранцішак БагушэвічТворы на knihi.comТворы Францішка Багушэвіча на bellib.byСодаль Уладзімір. Францішак Багушэвіч на Лідчыне;Луцкевіч Антон. Жыцьцё і творчасьць Фр. Багушэвіча ў успамінах ягоных сучасьнікаў // Запісы Беларускага Навуковага таварыства. Вільня, 1938. Сшытак 1. С. 16-34.Большая российская1188761710000 0000 5537 633Xn9209310021619551927869394п

                              Partai Komunis Tiongkok Daftar isi Kepemimpinan | Pranala luar | Referensi | Menu navigasidiperiksa1 perubahan tertundacpc.people.com.cnSitus resmiSurat kabar resmi"Why the Communist Party is alive, well and flourishing in China"0307-1235"Full text of Constitution of Communist Party of China"smengembangkannyas

                              ValueError: Expected n_neighbors <= n_samples, but n_samples = 1, n_neighbors = 6 (SMOTE) The 2019 Stack Overflow Developer Survey Results Are InCan SMOTE be applied over sequence of words (sentences)?ValueError when doing validation with random forestsSMOTE and multi class oversamplingLogic behind SMOTE-NC?ValueError: Error when checking target: expected dense_1 to have shape (7,) but got array with shape (1,)SmoteBoost: Should SMOTE be ran individually for each iteration/tree in the boosting?solving multi-class imbalance classification using smote and OSSUsing SMOTE for Synthetic Data generation to improve performance on unbalanced dataproblem of entry format for a simple model in KerasSVM SMOTE fit_resample() function runs forever with no result