How does connect takes in mapStateToProps and mapDispatchToProps to create a higher order component?











up vote
0
down vote

favorite












I've been trying to figure out two things regarding redux





  1. mpaDispatchToProps is a function that takes in dispatch as an argument, where is dispatch defined? and

  2. how does connect utilize mapStateToProps and mapDispatchToProps to create HOC(Higher Order Component) ?


If I understand correctly, connect is essentially a compositional function that takes the result of mapDispatchToProps and passes it to mapStateToProps then return the result, which is a component, but how is it done?



Thank you for your time!









share


























    up vote
    0
    down vote

    favorite












    I've been trying to figure out two things regarding redux





    1. mpaDispatchToProps is a function that takes in dispatch as an argument, where is dispatch defined? and

    2. how does connect utilize mapStateToProps and mapDispatchToProps to create HOC(Higher Order Component) ?


    If I understand correctly, connect is essentially a compositional function that takes the result of mapDispatchToProps and passes it to mapStateToProps then return the result, which is a component, but how is it done?



    Thank you for your time!









    share
























      up vote
      0
      down vote

      favorite









      up vote
      0
      down vote

      favorite











      I've been trying to figure out two things regarding redux





      1. mpaDispatchToProps is a function that takes in dispatch as an argument, where is dispatch defined? and

      2. how does connect utilize mapStateToProps and mapDispatchToProps to create HOC(Higher Order Component) ?


      If I understand correctly, connect is essentially a compositional function that takes the result of mapDispatchToProps and passes it to mapStateToProps then return the result, which is a component, but how is it done?



      Thank you for your time!









      share













      I've been trying to figure out two things regarding redux





      1. mpaDispatchToProps is a function that takes in dispatch as an argument, where is dispatch defined? and

      2. how does connect utilize mapStateToProps and mapDispatchToProps to create HOC(Higher Order Component) ?


      If I understand correctly, connect is essentially a compositional function that takes the result of mapDispatchToProps and passes it to mapStateToProps then return the result, which is a component, but how is it done?



      Thank you for your time!







      redux react-redux





      share












      share










      share



      share










      asked 19 hours ago









      Michael Cheng

      32




      32
























          1 Answer
          1






          active

          oldest

          votes

















          up vote
          0
          down vote














          1. mapDispatchToProps is a function that you will define. React-Redux calls your function with dispatch passed in as the first parameter. And that dispatch, in turn, comes from the store you provided to <Provider />.



          2. connect takes the mapState and mapDispatch that you will define, and create the wrapper function that, in the most common cases:




            • run mapState with state every time your store changes

            • run mapDispatch once when the component is instantiated


            The returns of both of these functions will be merged into your wrapped component.




          Seems that you'd like to figure out how it is done. This Dan Abramov's gist explains connect in a mental modal (simplified version of what it does).



          Hope that helps!





          share





















            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%2f53370881%2fhow-does-connect-takes-in-mapstatetoprops-and-mapdispatchtoprops-to-create-a-hig%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








            up vote
            0
            down vote














            1. mapDispatchToProps is a function that you will define. React-Redux calls your function with dispatch passed in as the first parameter. And that dispatch, in turn, comes from the store you provided to <Provider />.



            2. connect takes the mapState and mapDispatch that you will define, and create the wrapper function that, in the most common cases:




              • run mapState with state every time your store changes

              • run mapDispatch once when the component is instantiated


              The returns of both of these functions will be merged into your wrapped component.




            Seems that you'd like to figure out how it is done. This Dan Abramov's gist explains connect in a mental modal (simplified version of what it does).



            Hope that helps!





            share

























              up vote
              0
              down vote














              1. mapDispatchToProps is a function that you will define. React-Redux calls your function with dispatch passed in as the first parameter. And that dispatch, in turn, comes from the store you provided to <Provider />.



              2. connect takes the mapState and mapDispatch that you will define, and create the wrapper function that, in the most common cases:




                • run mapState with state every time your store changes

                • run mapDispatch once when the component is instantiated


                The returns of both of these functions will be merged into your wrapped component.




              Seems that you'd like to figure out how it is done. This Dan Abramov's gist explains connect in a mental modal (simplified version of what it does).



              Hope that helps!





              share























                up vote
                0
                down vote










                up vote
                0
                down vote










                1. mapDispatchToProps is a function that you will define. React-Redux calls your function with dispatch passed in as the first parameter. And that dispatch, in turn, comes from the store you provided to <Provider />.



                2. connect takes the mapState and mapDispatch that you will define, and create the wrapper function that, in the most common cases:




                  • run mapState with state every time your store changes

                  • run mapDispatch once when the component is instantiated


                  The returns of both of these functions will be merged into your wrapped component.




                Seems that you'd like to figure out how it is done. This Dan Abramov's gist explains connect in a mental modal (simplified version of what it does).



                Hope that helps!





                share













                1. mapDispatchToProps is a function that you will define. React-Redux calls your function with dispatch passed in as the first parameter. And that dispatch, in turn, comes from the store you provided to <Provider />.



                2. connect takes the mapState and mapDispatch that you will define, and create the wrapper function that, in the most common cases:




                  • run mapState with state every time your store changes

                  • run mapDispatch once when the component is instantiated


                  The returns of both of these functions will be merged into your wrapped component.




                Seems that you'd like to figure out how it is done. This Dan Abramov's gist explains connect in a mental modal (simplified version of what it does).



                Hope that helps!






                share











                share


                share










                answered 8 mins ago









                wgao19

                16615




                16615






























                     

                    draft saved


                    draft discarded



















































                     


                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53370881%2fhow-does-connect-takes-in-mapstatetoprops-and-mapdispatchtoprops-to-create-a-hig%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

                    Saint-Aignan (Tarn-et-Garonne)

                    Volksrepublik China

                    How to test boost logger output in unit testing?