why is my callback function not updating my var in React












0















How can I access "string value" outside the scope of the callback function. Please forgive my primitive knowledge as i'm new to callbacks.



render() {
let test = '';
let callback = (string) => {
test = string
console.log <----returns "string value"
}
console.log(test) <-----returns empty string

console.log()
return (
<div>
{callback("string value")}
</div>
);
}
}









share|improve this question


















  • 1





    Because when you console.log(test), the callback function has not yet been called (it happens later in the return statement).

    – Bergi
    Nov 24 '18 at 22:50













  • When you call console.log the callback function hasn't been called yet so the value of test is still the empty string. I'm not sure what is the point though, what are you trying to do?

    – Stefan
    Nov 24 '18 at 22:50











  • Btw, I don't see any callback function here that would be passed around, it's just a normal local function. Is this your actual code?

    – Bergi
    Nov 24 '18 at 22:51


















0















How can I access "string value" outside the scope of the callback function. Please forgive my primitive knowledge as i'm new to callbacks.



render() {
let test = '';
let callback = (string) => {
test = string
console.log <----returns "string value"
}
console.log(test) <-----returns empty string

console.log()
return (
<div>
{callback("string value")}
</div>
);
}
}









share|improve this question


















  • 1





    Because when you console.log(test), the callback function has not yet been called (it happens later in the return statement).

    – Bergi
    Nov 24 '18 at 22:50













  • When you call console.log the callback function hasn't been called yet so the value of test is still the empty string. I'm not sure what is the point though, what are you trying to do?

    – Stefan
    Nov 24 '18 at 22:50











  • Btw, I don't see any callback function here that would be passed around, it's just a normal local function. Is this your actual code?

    – Bergi
    Nov 24 '18 at 22:51
















0












0








0








How can I access "string value" outside the scope of the callback function. Please forgive my primitive knowledge as i'm new to callbacks.



render() {
let test = '';
let callback = (string) => {
test = string
console.log <----returns "string value"
}
console.log(test) <-----returns empty string

console.log()
return (
<div>
{callback("string value")}
</div>
);
}
}









share|improve this question














How can I access "string value" outside the scope of the callback function. Please forgive my primitive knowledge as i'm new to callbacks.



render() {
let test = '';
let callback = (string) => {
test = string
console.log <----returns "string value"
}
console.log(test) <-----returns empty string

console.log()
return (
<div>
{callback("string value")}
</div>
);
}
}






javascript reactjs ecmascript-6






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 24 '18 at 22:44









RayRay

347




347








  • 1





    Because when you console.log(test), the callback function has not yet been called (it happens later in the return statement).

    – Bergi
    Nov 24 '18 at 22:50













  • When you call console.log the callback function hasn't been called yet so the value of test is still the empty string. I'm not sure what is the point though, what are you trying to do?

    – Stefan
    Nov 24 '18 at 22:50











  • Btw, I don't see any callback function here that would be passed around, it's just a normal local function. Is this your actual code?

    – Bergi
    Nov 24 '18 at 22:51
















  • 1





    Because when you console.log(test), the callback function has not yet been called (it happens later in the return statement).

    – Bergi
    Nov 24 '18 at 22:50













  • When you call console.log the callback function hasn't been called yet so the value of test is still the empty string. I'm not sure what is the point though, what are you trying to do?

    – Stefan
    Nov 24 '18 at 22:50











  • Btw, I don't see any callback function here that would be passed around, it's just a normal local function. Is this your actual code?

    – Bergi
    Nov 24 '18 at 22:51










1




1





Because when you console.log(test), the callback function has not yet been called (it happens later in the return statement).

– Bergi
Nov 24 '18 at 22:50







Because when you console.log(test), the callback function has not yet been called (it happens later in the return statement).

– Bergi
Nov 24 '18 at 22:50















When you call console.log the callback function hasn't been called yet so the value of test is still the empty string. I'm not sure what is the point though, what are you trying to do?

– Stefan
Nov 24 '18 at 22:50





When you call console.log the callback function hasn't been called yet so the value of test is still the empty string. I'm not sure what is the point though, what are you trying to do?

– Stefan
Nov 24 '18 at 22:50













Btw, I don't see any callback function here that would be passed around, it's just a normal local function. Is this your actual code?

– Bergi
Nov 24 '18 at 22:51







Btw, I don't see any callback function here that would be passed around, it's just a normal local function. Is this your actual code?

– Bergi
Nov 24 '18 at 22:51














1 Answer
1






active

oldest

votes


















0














You simply need to return test (or string) at the end of your callback function.




The return statement ends function execution and specifies a value to
be returned to the function caller.




Check the below code:



render() {
let test = '';
let callback = (string) => {
test = string;
return test;
}
return (
<div>
{callback("string value")}
</div>
);
}
}





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%2f53463002%2fwhy-is-my-callback-function-not-updating-my-var-in-react%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









    0














    You simply need to return test (or string) at the end of your callback function.




    The return statement ends function execution and specifies a value to
    be returned to the function caller.




    Check the below code:



    render() {
    let test = '';
    let callback = (string) => {
    test = string;
    return test;
    }
    return (
    <div>
    {callback("string value")}
    </div>
    );
    }
    }





    share|improve this answer






























      0














      You simply need to return test (or string) at the end of your callback function.




      The return statement ends function execution and specifies a value to
      be returned to the function caller.




      Check the below code:



      render() {
      let test = '';
      let callback = (string) => {
      test = string;
      return test;
      }
      return (
      <div>
      {callback("string value")}
      </div>
      );
      }
      }





      share|improve this answer




























        0












        0








        0







        You simply need to return test (or string) at the end of your callback function.




        The return statement ends function execution and specifies a value to
        be returned to the function caller.




        Check the below code:



        render() {
        let test = '';
        let callback = (string) => {
        test = string;
        return test;
        }
        return (
        <div>
        {callback("string value")}
        </div>
        );
        }
        }





        share|improve this answer















        You simply need to return test (or string) at the end of your callback function.




        The return statement ends function execution and specifies a value to
        be returned to the function caller.




        Check the below code:



        render() {
        let test = '';
        let callback = (string) => {
        test = string;
        return test;
        }
        return (
        <div>
        {callback("string value")}
        </div>
        );
        }
        }






        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited Nov 24 '18 at 23:06

























        answered Nov 24 '18 at 22:57









        Hassan AlMandilHassan AlMandil

        2315




        2315






























            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%2f53463002%2fwhy-is-my-callback-function-not-updating-my-var-in-react%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

            A CLEAN and SIMPLE way to add appendices to Table of Contents and bookmarks

            Calculate evaluation metrics using cross_val_predict sklearn

            Insert data from modal to MySQL (multiple modal on website)