filter the properties of an object based on an array. And get the filtered object












0















how can i filter the properties of an object based on an array. I have sample snippet below.






var obj = {a: , b:, c: , d:}
var arr = ["a", "b"]





Following is my expected output, how can i achieve this




var outupt = {a: , b:}











share|improve this question

























  • You will have to map arr with obj and then you can get required output

    – iamrajshah
    Jan 2 at 7:33











  • got the solution

    – DILEEP THOMAS
    Jan 2 at 7:33
















0















how can i filter the properties of an object based on an array. I have sample snippet below.






var obj = {a: , b:, c: , d:}
var arr = ["a", "b"]





Following is my expected output, how can i achieve this




var outupt = {a: , b:}











share|improve this question

























  • You will have to map arr with obj and then you can get required output

    – iamrajshah
    Jan 2 at 7:33











  • got the solution

    – DILEEP THOMAS
    Jan 2 at 7:33














0












0








0








how can i filter the properties of an object based on an array. I have sample snippet below.






var obj = {a: , b:, c: , d:}
var arr = ["a", "b"]





Following is my expected output, how can i achieve this




var outupt = {a: , b:}











share|improve this question
















how can i filter the properties of an object based on an array. I have sample snippet below.






var obj = {a: , b:, c: , d:}
var arr = ["a", "b"]





Following is my expected output, how can i achieve this




var outupt = {a: , b:}







var obj = {a: , b:, c: , d:}
var arr = ["a", "b"]





var obj = {a: , b:, c: , d:}
var arr = ["a", "b"]






javascript filter






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Jan 2 at 7:32









iamrajshah

519820




519820










asked Jan 2 at 7:30









DILEEP THOMASDILEEP THOMAS

1,1172515




1,1172515













  • You will have to map arr with obj and then you can get required output

    – iamrajshah
    Jan 2 at 7:33











  • got the solution

    – DILEEP THOMAS
    Jan 2 at 7:33



















  • You will have to map arr with obj and then you can get required output

    – iamrajshah
    Jan 2 at 7:33











  • got the solution

    – DILEEP THOMAS
    Jan 2 at 7:33

















You will have to map arr with obj and then you can get required output

– iamrajshah
Jan 2 at 7:33





You will have to map arr with obj and then you can get required output

– iamrajshah
Jan 2 at 7:33













got the solution

– DILEEP THOMAS
Jan 2 at 7:33





got the solution

– DILEEP THOMAS
Jan 2 at 7:33












2 Answers
2






active

oldest

votes


















2














You could map new objects and create a single object.






var object = { a: , b: , c: , d:  },
keys = ["a", "b"],
result = Object.assign(...keys.map(k => ({ [k]: object[k] })));

console.log(result);








share|improve this answer

































    1

















    var obj = {a: , b:, c: , d:}
    var arr = ["a", "b"]

    var output = arr.reduce((result, key) => ({ ...result, [key]: obj[key] }), {});

    console.log(output)








    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%2f54002725%2ffilter-the-properties-of-an-object-based-on-an-array-and-get-the-filtered-objec%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









      2














      You could map new objects and create a single object.






      var object = { a: , b: , c: , d:  },
      keys = ["a", "b"],
      result = Object.assign(...keys.map(k => ({ [k]: object[k] })));

      console.log(result);








      share|improve this answer






























        2














        You could map new objects and create a single object.






        var object = { a: , b: , c: , d:  },
        keys = ["a", "b"],
        result = Object.assign(...keys.map(k => ({ [k]: object[k] })));

        console.log(result);








        share|improve this answer




























          2












          2








          2







          You could map new objects and create a single object.






          var object = { a: , b: , c: , d:  },
          keys = ["a", "b"],
          result = Object.assign(...keys.map(k => ({ [k]: object[k] })));

          console.log(result);








          share|improve this answer















          You could map new objects and create a single object.






          var object = { a: , b: , c: , d:  },
          keys = ["a", "b"],
          result = Object.assign(...keys.map(k => ({ [k]: object[k] })));

          console.log(result);








          var object = { a: , b: , c: , d:  },
          keys = ["a", "b"],
          result = Object.assign(...keys.map(k => ({ [k]: object[k] })));

          console.log(result);





          var object = { a: , b: , c: , d:  },
          keys = ["a", "b"],
          result = Object.assign(...keys.map(k => ({ [k]: object[k] })));

          console.log(result);






          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited Jan 2 at 7:35

























          answered Jan 2 at 7:33









          Nina ScholzNina Scholz

          192k15104177




          192k15104177

























              1

















              var obj = {a: , b:, c: , d:}
              var arr = ["a", "b"]

              var output = arr.reduce((result, key) => ({ ...result, [key]: obj[key] }), {});

              console.log(output)








              share|improve this answer




























                1

















                var obj = {a: , b:, c: , d:}
                var arr = ["a", "b"]

                var output = arr.reduce((result, key) => ({ ...result, [key]: obj[key] }), {});

                console.log(output)








                share|improve this answer


























                  1












                  1








                  1










                  var obj = {a: , b:, c: , d:}
                  var arr = ["a", "b"]

                  var output = arr.reduce((result, key) => ({ ...result, [key]: obj[key] }), {});

                  console.log(output)








                  share|improve this answer
















                  var obj = {a: , b:, c: , d:}
                  var arr = ["a", "b"]

                  var output = arr.reduce((result, key) => ({ ...result, [key]: obj[key] }), {});

                  console.log(output)








                  var obj = {a: , b:, c: , d:}
                  var arr = ["a", "b"]

                  var output = arr.reduce((result, key) => ({ ...result, [key]: obj[key] }), {});

                  console.log(output)





                  var obj = {a: , b:, c: , d:}
                  var arr = ["a", "b"]

                  var output = arr.reduce((result, key) => ({ ...result, [key]: obj[key] }), {});

                  console.log(output)






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Jan 2 at 7:34









                  DILEEP THOMASDILEEP THOMAS

                  1,1172515




                  1,1172515






























                      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%2f54002725%2ffilter-the-properties-of-an-object-based-on-an-array-and-get-the-filtered-objec%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

                      Can a sorcerer learn a 5th-level spell early by creating spell slots using the Font of Magic feature?

                      Does disintegrating a polymorphed enemy still kill it after the 2018 errata?

                      A Topological Invariant for $pi_3(U(n))$