Javascript Parameter format









up vote
-2
down vote

favorite












I don't understand the difference between these two functions:



function animal( cat )
return cat


function animal(cat)
return cat



why use one over the other? Is there an advantage?










share|improve this question























  • Did you try running the code? They don't do the same thing...
    – Jared Smith
    Nov 10 at 3:13






  • 4




    The first is using Destructuring assignment and the other is returning the full cat object.
    – Nick Parsons
    Nov 10 at 3:14















up vote
-2
down vote

favorite












I don't understand the difference between these two functions:



function animal( cat )
return cat


function animal(cat)
return cat



why use one over the other? Is there an advantage?










share|improve this question























  • Did you try running the code? They don't do the same thing...
    – Jared Smith
    Nov 10 at 3:13






  • 4




    The first is using Destructuring assignment and the other is returning the full cat object.
    – Nick Parsons
    Nov 10 at 3:14













up vote
-2
down vote

favorite









up vote
-2
down vote

favorite











I don't understand the difference between these two functions:



function animal( cat )
return cat


function animal(cat)
return cat



why use one over the other? Is there an advantage?










share|improve this question















I don't understand the difference between these two functions:



function animal( cat )
return cat


function animal(cat)
return cat



why use one over the other? Is there an advantage?







javascript ecmascript-6 destructuring






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 10 at 3:15









Sushanth --

49.3k64783




49.3k64783










asked Nov 10 at 3:11









olafsadventures

476




476











  • Did you try running the code? They don't do the same thing...
    – Jared Smith
    Nov 10 at 3:13






  • 4




    The first is using Destructuring assignment and the other is returning the full cat object.
    – Nick Parsons
    Nov 10 at 3:14

















  • Did you try running the code? They don't do the same thing...
    – Jared Smith
    Nov 10 at 3:13






  • 4




    The first is using Destructuring assignment and the other is returning the full cat object.
    – Nick Parsons
    Nov 10 at 3:14
















Did you try running the code? They don't do the same thing...
– Jared Smith
Nov 10 at 3:13




Did you try running the code? They don't do the same thing...
– Jared Smith
Nov 10 at 3:13




4




4




The first is using Destructuring assignment and the other is returning the full cat object.
– Nick Parsons
Nov 10 at 3:14





The first is using Destructuring assignment and the other is returning the full cat object.
– Nick Parsons
Nov 10 at 3:14













2 Answers
2






active

oldest

votes

















up vote
0
down vote













The first function will return the property cat from the object which is passed in as it is using destructuring assignment. The second will return the full object cat which is the objected that was passed in.



For example, the first function is equivalent to:



function animal(catObj)
return catObj.cat;



Meaning that when you call animal() you pass through an object which has the property cat within it.



eg:



const myCatObj = 
cat: true,
dog: false,
name: "Meow"


animal(myCatObj); // retruns true


So, if we're looking at the first function, this will extract the cat property and return true.



Your second function will simply just return the entire object passed into the function. So if we passed through myCatObj we would get the same contents within myCatObj as an output.



So, to answer your question, both are used to perform different sorts of functions, so they each have their own advantages in certain scenarios.






share|improve this answer



























    up vote
    -1
    down vote













    calling those two functions



    animal(cat:9); returns 9



    animal(9); returns undefined since the number 9 does not have a cat property (everything is an object in js)



    we use the 1st function when we want to know about the cat property of an object



    we use the second one when we want to call an object directly






    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',
      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%2f53235704%2fjavascript-parameter-format%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








      up vote
      0
      down vote













      The first function will return the property cat from the object which is passed in as it is using destructuring assignment. The second will return the full object cat which is the objected that was passed in.



      For example, the first function is equivalent to:



      function animal(catObj)
      return catObj.cat;



      Meaning that when you call animal() you pass through an object which has the property cat within it.



      eg:



      const myCatObj = 
      cat: true,
      dog: false,
      name: "Meow"


      animal(myCatObj); // retruns true


      So, if we're looking at the first function, this will extract the cat property and return true.



      Your second function will simply just return the entire object passed into the function. So if we passed through myCatObj we would get the same contents within myCatObj as an output.



      So, to answer your question, both are used to perform different sorts of functions, so they each have their own advantages in certain scenarios.






      share|improve this answer
























        up vote
        0
        down vote













        The first function will return the property cat from the object which is passed in as it is using destructuring assignment. The second will return the full object cat which is the objected that was passed in.



        For example, the first function is equivalent to:



        function animal(catObj)
        return catObj.cat;



        Meaning that when you call animal() you pass through an object which has the property cat within it.



        eg:



        const myCatObj = 
        cat: true,
        dog: false,
        name: "Meow"


        animal(myCatObj); // retruns true


        So, if we're looking at the first function, this will extract the cat property and return true.



        Your second function will simply just return the entire object passed into the function. So if we passed through myCatObj we would get the same contents within myCatObj as an output.



        So, to answer your question, both are used to perform different sorts of functions, so they each have their own advantages in certain scenarios.






        share|improve this answer






















          up vote
          0
          down vote










          up vote
          0
          down vote









          The first function will return the property cat from the object which is passed in as it is using destructuring assignment. The second will return the full object cat which is the objected that was passed in.



          For example, the first function is equivalent to:



          function animal(catObj)
          return catObj.cat;



          Meaning that when you call animal() you pass through an object which has the property cat within it.



          eg:



          const myCatObj = 
          cat: true,
          dog: false,
          name: "Meow"


          animal(myCatObj); // retruns true


          So, if we're looking at the first function, this will extract the cat property and return true.



          Your second function will simply just return the entire object passed into the function. So if we passed through myCatObj we would get the same contents within myCatObj as an output.



          So, to answer your question, both are used to perform different sorts of functions, so they each have their own advantages in certain scenarios.






          share|improve this answer












          The first function will return the property cat from the object which is passed in as it is using destructuring assignment. The second will return the full object cat which is the objected that was passed in.



          For example, the first function is equivalent to:



          function animal(catObj)
          return catObj.cat;



          Meaning that when you call animal() you pass through an object which has the property cat within it.



          eg:



          const myCatObj = 
          cat: true,
          dog: false,
          name: "Meow"


          animal(myCatObj); // retruns true


          So, if we're looking at the first function, this will extract the cat property and return true.



          Your second function will simply just return the entire object passed into the function. So if we passed through myCatObj we would get the same contents within myCatObj as an output.



          So, to answer your question, both are used to perform different sorts of functions, so they each have their own advantages in certain scenarios.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 10 at 3:24









          Nick Parsons

          2,9332619




          2,9332619






















              up vote
              -1
              down vote













              calling those two functions



              animal(cat:9); returns 9



              animal(9); returns undefined since the number 9 does not have a cat property (everything is an object in js)



              we use the 1st function when we want to know about the cat property of an object



              we use the second one when we want to call an object directly






              share|improve this answer
























                up vote
                -1
                down vote













                calling those two functions



                animal(cat:9); returns 9



                animal(9); returns undefined since the number 9 does not have a cat property (everything is an object in js)



                we use the 1st function when we want to know about the cat property of an object



                we use the second one when we want to call an object directly






                share|improve this answer






















                  up vote
                  -1
                  down vote










                  up vote
                  -1
                  down vote









                  calling those two functions



                  animal(cat:9); returns 9



                  animal(9); returns undefined since the number 9 does not have a cat property (everything is an object in js)



                  we use the 1st function when we want to know about the cat property of an object



                  we use the second one when we want to call an object directly






                  share|improve this answer












                  calling those two functions



                  animal(cat:9); returns 9



                  animal(9); returns undefined since the number 9 does not have a cat property (everything is an object in js)



                  we use the 1st function when we want to know about the cat property of an object



                  we use the second one when we want to call an object directly







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 10 at 3:27









                  Aditya Shankar

                  1284




                  1284



























                      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%2f53235704%2fjavascript-parameter-format%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

                      Use pre created SQLite database for Android project in kotlin

                      Darth Vader #20

                      Ondo