How to handle over variables in nested functions in JavaScript












0














When calling an function like in my case "setState(...)" which has a form where the first argument is a function, I wonder how to pass a local variable over to this function.



Here is my example:



let myDate = new Date();

this.setState((myDate) => {
return {
date: myDate
}
})


As you can see I'm using the arrow-notation here.










share|improve this question





























    0














    When calling an function like in my case "setState(...)" which has a form where the first argument is a function, I wonder how to pass a local variable over to this function.



    Here is my example:



    let myDate = new Date();

    this.setState((myDate) => {
    return {
    date: myDate
    }
    })


    As you can see I'm using the arrow-notation here.










    share|improve this question



























      0












      0








      0







      When calling an function like in my case "setState(...)" which has a form where the first argument is a function, I wonder how to pass a local variable over to this function.



      Here is my example:



      let myDate = new Date();

      this.setState((myDate) => {
      return {
      date: myDate
      }
      })


      As you can see I'm using the arrow-notation here.










      share|improve this question















      When calling an function like in my case "setState(...)" which has a form where the first argument is a function, I wonder how to pass a local variable over to this function.



      Here is my example:



      let myDate = new Date();

      this.setState((myDate) => {
      return {
      date: myDate
      }
      })


      As you can see I'm using the arrow-notation here.







      javascript ecmascript-6






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 12 at 14:59









      Marcus Höglund

      9,60852545




      9,60852545










      asked Nov 12 at 14:56









      Marc M

      5231623




      5231623
























          2 Answers
          2






          active

          oldest

          votes


















          1














          You have two variables called myDate.




          • The one in the wider scope defined on line one

          • The one local to the arrow function defined in its arguments on line three


          The second one masks the first one.



          Just don't do that so the function has access to the one in the wider scope.



          this.setState(() => {





          share|improve this answer





























            1














            Adding the parameter in your setState is unnecessary, simply call the variable in your setState and that will work.



            let myDate = new Date();

            this.setState(() => {
            return {
            date: myDate
            }
            })





            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%2f53264751%2fhow-to-handle-over-variables-in-nested-functions-in-javascript%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









              1














              You have two variables called myDate.




              • The one in the wider scope defined on line one

              • The one local to the arrow function defined in its arguments on line three


              The second one masks the first one.



              Just don't do that so the function has access to the one in the wider scope.



              this.setState(() => {





              share|improve this answer


























                1














                You have two variables called myDate.




                • The one in the wider scope defined on line one

                • The one local to the arrow function defined in its arguments on line three


                The second one masks the first one.



                Just don't do that so the function has access to the one in the wider scope.



                this.setState(() => {





                share|improve this answer
























                  1












                  1








                  1






                  You have two variables called myDate.




                  • The one in the wider scope defined on line one

                  • The one local to the arrow function defined in its arguments on line three


                  The second one masks the first one.



                  Just don't do that so the function has access to the one in the wider scope.



                  this.setState(() => {





                  share|improve this answer












                  You have two variables called myDate.




                  • The one in the wider scope defined on line one

                  • The one local to the arrow function defined in its arguments on line three


                  The second one masks the first one.



                  Just don't do that so the function has access to the one in the wider scope.



                  this.setState(() => {






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 12 at 14:59









                  Quentin

                  638k718611031




                  638k718611031

























                      1














                      Adding the parameter in your setState is unnecessary, simply call the variable in your setState and that will work.



                      let myDate = new Date();

                      this.setState(() => {
                      return {
                      date: myDate
                      }
                      })





                      share|improve this answer


























                        1














                        Adding the parameter in your setState is unnecessary, simply call the variable in your setState and that will work.



                        let myDate = new Date();

                        this.setState(() => {
                        return {
                        date: myDate
                        }
                        })





                        share|improve this answer
























                          1












                          1








                          1






                          Adding the parameter in your setState is unnecessary, simply call the variable in your setState and that will work.



                          let myDate = new Date();

                          this.setState(() => {
                          return {
                          date: myDate
                          }
                          })





                          share|improve this answer












                          Adding the parameter in your setState is unnecessary, simply call the variable in your setState and that will work.



                          let myDate = new Date();

                          this.setState(() => {
                          return {
                          date: myDate
                          }
                          })






                          share|improve this answer












                          share|improve this answer



                          share|improve this answer










                          answered Nov 12 at 15:02









                          Dmitriy

                          477112




                          477112






























                              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.





                              Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                              Please pay close attention to the following guidance:


                              • 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%2f53264751%2fhow-to-handle-over-variables-in-nested-functions-in-javascript%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

                              Xamarin.iOS Cant Deploy on Iphone

                              Glorious Revolution

                              Dulmage-Mendelsohn matrix decomposition in Python