Access Object property using key name within map





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







0















I have below array of object



const reports = [{id:3, name:'three', description:'three d', other: 'other 3'}, {id:2, name:'two', description:'two d', other: 'other 2'}];


and I want to filter out only 2 property of each object and below is my desired output



[{id:3, name:'three'}, {id:2, name:'two'}];


so tried this way



const reportList = reports.map((report) => {id,name} );
console.log(reportList);


throw error




ReferenceError: id is not defined




even I can achieve this by using this approach



 this.reportList = reports.map((report) => ({
id: report.id,
name: report.name,
description: report.description
}));


but here I need to write extra code, I want to use object accessor using key, can I achieve anyway?










share|improve this question





























    0















    I have below array of object



    const reports = [{id:3, name:'three', description:'three d', other: 'other 3'}, {id:2, name:'two', description:'two d', other: 'other 2'}];


    and I want to filter out only 2 property of each object and below is my desired output



    [{id:3, name:'three'}, {id:2, name:'two'}];


    so tried this way



    const reportList = reports.map((report) => {id,name} );
    console.log(reportList);


    throw error




    ReferenceError: id is not defined




    even I can achieve this by using this approach



     this.reportList = reports.map((report) => ({
    id: report.id,
    name: report.name,
    description: report.description
    }));


    but here I need to write extra code, I want to use object accessor using key, can I achieve anyway?










    share|improve this question

























      0












      0








      0








      I have below array of object



      const reports = [{id:3, name:'three', description:'three d', other: 'other 3'}, {id:2, name:'two', description:'two d', other: 'other 2'}];


      and I want to filter out only 2 property of each object and below is my desired output



      [{id:3, name:'three'}, {id:2, name:'two'}];


      so tried this way



      const reportList = reports.map((report) => {id,name} );
      console.log(reportList);


      throw error




      ReferenceError: id is not defined




      even I can achieve this by using this approach



       this.reportList = reports.map((report) => ({
      id: report.id,
      name: report.name,
      description: report.description
      }));


      but here I need to write extra code, I want to use object accessor using key, can I achieve anyway?










      share|improve this question














      I have below array of object



      const reports = [{id:3, name:'three', description:'three d', other: 'other 3'}, {id:2, name:'two', description:'two d', other: 'other 2'}];


      and I want to filter out only 2 property of each object and below is my desired output



      [{id:3, name:'three'}, {id:2, name:'two'}];


      so tried this way



      const reportList = reports.map((report) => {id,name} );
      console.log(reportList);


      throw error




      ReferenceError: id is not defined




      even I can achieve this by using this approach



       this.reportList = reports.map((report) => ({
      id: report.id,
      name: report.name,
      description: report.description
      }));


      but here I need to write extra code, I want to use object accessor using key, can I achieve anyway?







      object ecmascript-6






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Jan 3 at 8:44









      diEchodiEcho

      38.2k27130202




      38.2k27130202
























          1 Answer
          1






          active

          oldest

          votes


















          1














          You just need to wrap your map arguments like this return object in ()






          const reports = [{
          id: 3,
          name: 'three',
          description: 'three d',
          other: 'other 3'
          }, {
          id: 2,
          name: 'two',
          description: 'two d',
          other: 'other 2'
          }];

          const reportList = reports.map(({id, name}) => ({
          id,
          name
          }));
          console.log(reportList);








          share|improve this answer
























          • Thanks. got it now.

            – diEcho
            Jan 3 at 9:22












          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%2f54018885%2faccess-object-property-using-key-name-within-map%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          1














          You just need to wrap your map arguments like this return object in ()






          const reports = [{
          id: 3,
          name: 'three',
          description: 'three d',
          other: 'other 3'
          }, {
          id: 2,
          name: 'two',
          description: 'two d',
          other: 'other 2'
          }];

          const reportList = reports.map(({id, name}) => ({
          id,
          name
          }));
          console.log(reportList);








          share|improve this answer
























          • Thanks. got it now.

            – diEcho
            Jan 3 at 9:22
















          1














          You just need to wrap your map arguments like this return object in ()






          const reports = [{
          id: 3,
          name: 'three',
          description: 'three d',
          other: 'other 3'
          }, {
          id: 2,
          name: 'two',
          description: 'two d',
          other: 'other 2'
          }];

          const reportList = reports.map(({id, name}) => ({
          id,
          name
          }));
          console.log(reportList);








          share|improve this answer
























          • Thanks. got it now.

            – diEcho
            Jan 3 at 9:22














          1












          1








          1







          You just need to wrap your map arguments like this return object in ()






          const reports = [{
          id: 3,
          name: 'three',
          description: 'three d',
          other: 'other 3'
          }, {
          id: 2,
          name: 'two',
          description: 'two d',
          other: 'other 2'
          }];

          const reportList = reports.map(({id, name}) => ({
          id,
          name
          }));
          console.log(reportList);








          share|improve this answer













          You just need to wrap your map arguments like this return object in ()






          const reports = [{
          id: 3,
          name: 'three',
          description: 'three d',
          other: 'other 3'
          }, {
          id: 2,
          name: 'two',
          description: 'two d',
          other: 'other 2'
          }];

          const reportList = reports.map(({id, name}) => ({
          id,
          name
          }));
          console.log(reportList);








          const reports = [{
          id: 3,
          name: 'three',
          description: 'three d',
          other: 'other 3'
          }, {
          id: 2,
          name: 'two',
          description: 'two d',
          other: 'other 2'
          }];

          const reportList = reports.map(({id, name}) => ({
          id,
          name
          }));
          console.log(reportList);





          const reports = [{
          id: 3,
          name: 'three',
          description: 'three d',
          other: 'other 3'
          }, {
          id: 2,
          name: 'two',
          description: 'two d',
          other: 'other 2'
          }];

          const reportList = reports.map(({id, name}) => ({
          id,
          name
          }));
          console.log(reportList);






          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Jan 3 at 9:17









          Bhargav PatelBhargav Patel

          262




          262













          • Thanks. got it now.

            – diEcho
            Jan 3 at 9:22



















          • Thanks. got it now.

            – diEcho
            Jan 3 at 9:22

















          Thanks. got it now.

          – diEcho
          Jan 3 at 9:22





          Thanks. got it now.

          – diEcho
          Jan 3 at 9:22




















          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%2f54018885%2faccess-object-property-using-key-name-within-map%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