Looping a button click event in jQueryJavaScript closure inside loops – simple practical exampleIs there an “exists” function for jQuery?How do I detect a click outside an element?Add table row in jQueryHow do I check if an element is hidden in jQuery?Setting “checked” for a checkbox with jQuery?How can I know which radio button is selected via jQuery?How to check whether a checkbox is checked in jQuery?Loop through an array in JavaScriptjQuery scroll to element“Thinking in AngularJS” if I have a jQuery background?

Infinite past with a beginning?

How did the USSR manage to innovate in an environment characterized by government censorship and high bureaucracy?

New order #4: World

A Journey Through Space and Time

Why is an old chain unsafe?

What is the command to reset a PC without deleting any files

What Brexit solution does the DUP want?

Is there really no realistic way for a skeleton monster to move around without magic?

DOS, create pipe for stdin/stdout of command.com(or 4dos.com) in C or Batch?

What makes Graph invariants so useful/important?

Pronouncing Dictionary.com's W.O.D "vade mecum" in English

Copenhagen passport control - US citizen

Possibly bubble sort algorithm

How much RAM could one put in a typical 80386 setup?

What do you call a Matrix-like slowdown and camera movement effect?

Shell script can be run only with sh command

How do we improve the relationship with a client software team that performs poorly and is becoming less collaborative?

How to type dʒ symbol (IPA) on Mac?

What are these boxed doors outside store fronts in New York?

I see my dog run

What is the logic behind how bash tests for true/false?

Are tax years 2016 & 2017 back taxes deductible for tax year 2018?

Is it possible to do 50 km distance without any previous training?

How do I create uniquely male characters?



Looping a button click event in jQuery


JavaScript closure inside loops – simple practical exampleIs there an “exists” function for jQuery?How do I detect a click outside an element?Add table row in jQueryHow do I check if an element is hidden in jQuery?Setting “checked” for a checkbox with jQuery?How can I know which radio button is selected via jQuery?How to check whether a checkbox is checked in jQuery?Loop through an array in JavaScriptjQuery scroll to element“Thinking in AngularJS” if I have a jQuery background?






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








1















This loop doesn't seem to be working, I'm not sure where i'm going wrong but would appreciate any help.






var j = 0;
for (j = 0; j < 10; j++)
$('#btn-' + j).click(function()
alert(j);
);

<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<button id='btn-0'>One</button>
<button id='btn-1'>Two</button>
<button id='btn-2'>Three</button>
<button id='btn-3'>Four</button>





Basically on the click of the button it should alert out the number the loop is up to (right?) but it just alerts '10' on every one?



It's late and I know I must be doing something wrong, but I can't think what.



Here is a fiddle of my loop:
https://jsfiddle.net/p8v5sejr/










share|improve this question



















  • 3





    Possible duplicate of JavaScript closure inside loops – simple practical example

    – Ivar
    Mar 22 at 1:01

















1















This loop doesn't seem to be working, I'm not sure where i'm going wrong but would appreciate any help.






var j = 0;
for (j = 0; j < 10; j++)
$('#btn-' + j).click(function()
alert(j);
);

<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<button id='btn-0'>One</button>
<button id='btn-1'>Two</button>
<button id='btn-2'>Three</button>
<button id='btn-3'>Four</button>





Basically on the click of the button it should alert out the number the loop is up to (right?) but it just alerts '10' on every one?



It's late and I know I must be doing something wrong, but I can't think what.



Here is a fiddle of my loop:
https://jsfiddle.net/p8v5sejr/










share|improve this question



















  • 3





    Possible duplicate of JavaScript closure inside loops – simple practical example

    – Ivar
    Mar 22 at 1:01













1












1








1








This loop doesn't seem to be working, I'm not sure where i'm going wrong but would appreciate any help.






var j = 0;
for (j = 0; j < 10; j++)
$('#btn-' + j).click(function()
alert(j);
);

<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<button id='btn-0'>One</button>
<button id='btn-1'>Two</button>
<button id='btn-2'>Three</button>
<button id='btn-3'>Four</button>





Basically on the click of the button it should alert out the number the loop is up to (right?) but it just alerts '10' on every one?



It's late and I know I must be doing something wrong, but I can't think what.



Here is a fiddle of my loop:
https://jsfiddle.net/p8v5sejr/










share|improve this question
















This loop doesn't seem to be working, I'm not sure where i'm going wrong but would appreciate any help.






var j = 0;
for (j = 0; j < 10; j++)
$('#btn-' + j).click(function()
alert(j);
);

<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<button id='btn-0'>One</button>
<button id='btn-1'>Two</button>
<button id='btn-2'>Three</button>
<button id='btn-3'>Four</button>





Basically on the click of the button it should alert out the number the loop is up to (right?) but it just alerts '10' on every one?



It's late and I know I must be doing something wrong, but I can't think what.



Here is a fiddle of my loop:
https://jsfiddle.net/p8v5sejr/






var j = 0;
for (j = 0; j < 10; j++)
$('#btn-' + j).click(function()
alert(j);
);

<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<button id='btn-0'>One</button>
<button id='btn-1'>Two</button>
<button id='btn-2'>Three</button>
<button id='btn-3'>Four</button>





var j = 0;
for (j = 0; j < 10; j++)
$('#btn-' + j).click(function()
alert(j);
);

<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<button id='btn-0'>One</button>
<button id='btn-1'>Two</button>
<button id='btn-2'>Three</button>
<button id='btn-3'>Four</button>






javascript jquery html






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Mar 22 at 1:14









Jack Bashford

15.5k31848




15.5k31848










asked Mar 22 at 0:57









FoxyFishFoxyFish

4921515




4921515







  • 3





    Possible duplicate of JavaScript closure inside loops – simple practical example

    – Ivar
    Mar 22 at 1:01












  • 3





    Possible duplicate of JavaScript closure inside loops – simple practical example

    – Ivar
    Mar 22 at 1:01







3




3





Possible duplicate of JavaScript closure inside loops – simple practical example

– Ivar
Mar 22 at 1:01





Possible duplicate of JavaScript closure inside loops – simple practical example

– Ivar
Mar 22 at 1:01












5 Answers
5






active

oldest

votes


















1














It's about function scope and block scope



Just use let to declare i in for loop






// var j = 0; <-- Don't use var
for (let j = 0; j < 10; j++) // <-- use let
$('#btn-' + j).click(function()
alert(j);
);

<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<button id='btn-0'>One</button>
<button id='btn-1'>Two</button>
<button id='btn-2'>Three</button>
<button id='btn-3'>Four</button>








share|improve this answer























  • This is what i was trying to think of but couldnt think of it! Let! I need sleep 🤣

    – FoxyFish
    Mar 22 at 1:20


















1














It's because the loop runs, then when you click on your buttons, j is equal to 10. Since your values are coming from the button's IDs, you can use that to your advantage:






var j = 0;
for (j = 0; j < 10; j++)
$('#btn-' + j).click(function()
alert($(this).attr("id").split("btn-")[1]);
);

<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<button id='btn-0'>One</button>
<button id='btn-1'>Two</button>
<button id='btn-2'>Three</button>
<button id='btn-3'>Four</button>








share|improve this answer























  • Perfect solution, thanks.

    – FoxyFish
    Mar 22 at 1:05











  • No problem whatsoever @FoxyFish - if my answer fixed your problem, please mark it as accepted by clicking the grey tick mark to the left of my answer.

    – Jack Bashford
    Mar 22 at 1:11


















1














You can grab the id off of the current target element and parse out the index.






for (let index = 0; index < 4; index++) 
$('#btn-' + index).click(function(e)
var value = parseInt(e.target.id.replace(/[D+]/g, ''), 10);
alert(value);
);

<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<button id='btn-0'>One</button>
<button id='btn-1'>Two</button>
<button id='btn-2'>Three</button>
<button id='btn-3'>Four</button>








share|improve this answer






























    0














    If you do the event binding in a function you get a closure keeping the value.






    var j = 0;
    for (j = 0; j < 10; j++)
    addClick(j);


    function addClick(j)
    $('#btn-' + j).click(function()
    alert(j);
    );

    <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
    <button id='btn-0'>One</button>
    <button id='btn-1'>Two</button>
    <button id='btn-2'>Three</button>
    <button id='btn-3'>Four</button>








    share|improve this answer






























      0














      Try this,



      $( "button[id^=btn]" ).each(function(index) 
      $(this).on("click", function()
      var idvalue = $(this).attr('id');

      //alert(index);
      //or
      idvalue = idvalue.replace("btn-","");
      alert(idvalue);
      );
      );





      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%2f55291387%2flooping-a-button-click-event-in-jquery%23new-answer', 'question_page');

        );

        Post as a guest















        Required, but never shown

























        5 Answers
        5






        active

        oldest

        votes








        5 Answers
        5






        active

        oldest

        votes









        active

        oldest

        votes






        active

        oldest

        votes









        1














        It's about function scope and block scope



        Just use let to declare i in for loop






        // var j = 0; <-- Don't use var
        for (let j = 0; j < 10; j++) // <-- use let
        $('#btn-' + j).click(function()
        alert(j);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>








        share|improve this answer























        • This is what i was trying to think of but couldnt think of it! Let! I need sleep 🤣

          – FoxyFish
          Mar 22 at 1:20















        1














        It's about function scope and block scope



        Just use let to declare i in for loop






        // var j = 0; <-- Don't use var
        for (let j = 0; j < 10; j++) // <-- use let
        $('#btn-' + j).click(function()
        alert(j);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>








        share|improve this answer























        • This is what i was trying to think of but couldnt think of it! Let! I need sleep 🤣

          – FoxyFish
          Mar 22 at 1:20













        1












        1








        1







        It's about function scope and block scope



        Just use let to declare i in for loop






        // var j = 0; <-- Don't use var
        for (let j = 0; j < 10; j++) // <-- use let
        $('#btn-' + j).click(function()
        alert(j);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>








        share|improve this answer













        It's about function scope and block scope



        Just use let to declare i in for loop






        // var j = 0; <-- Don't use var
        for (let j = 0; j < 10; j++) // <-- use let
        $('#btn-' + j).click(function()
        alert(j);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>








        // var j = 0; <-- Don't use var
        for (let j = 0; j < 10; j++) // <-- use let
        $('#btn-' + j).click(function()
        alert(j);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>





        // var j = 0; <-- Don't use var
        for (let j = 0; j < 10; j++) // <-- use let
        $('#btn-' + j).click(function()
        alert(j);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Mar 22 at 1:16









        birdbird

        1,136720




        1,136720












        • This is what i was trying to think of but couldnt think of it! Let! I need sleep 🤣

          – FoxyFish
          Mar 22 at 1:20

















        • This is what i was trying to think of but couldnt think of it! Let! I need sleep 🤣

          – FoxyFish
          Mar 22 at 1:20
















        This is what i was trying to think of but couldnt think of it! Let! I need sleep 🤣

        – FoxyFish
        Mar 22 at 1:20





        This is what i was trying to think of but couldnt think of it! Let! I need sleep 🤣

        – FoxyFish
        Mar 22 at 1:20













        1














        It's because the loop runs, then when you click on your buttons, j is equal to 10. Since your values are coming from the button's IDs, you can use that to your advantage:






        var j = 0;
        for (j = 0; j < 10; j++)
        $('#btn-' + j).click(function()
        alert($(this).attr("id").split("btn-")[1]);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>








        share|improve this answer























        • Perfect solution, thanks.

          – FoxyFish
          Mar 22 at 1:05











        • No problem whatsoever @FoxyFish - if my answer fixed your problem, please mark it as accepted by clicking the grey tick mark to the left of my answer.

          – Jack Bashford
          Mar 22 at 1:11















        1














        It's because the loop runs, then when you click on your buttons, j is equal to 10. Since your values are coming from the button's IDs, you can use that to your advantage:






        var j = 0;
        for (j = 0; j < 10; j++)
        $('#btn-' + j).click(function()
        alert($(this).attr("id").split("btn-")[1]);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>








        share|improve this answer























        • Perfect solution, thanks.

          – FoxyFish
          Mar 22 at 1:05











        • No problem whatsoever @FoxyFish - if my answer fixed your problem, please mark it as accepted by clicking the grey tick mark to the left of my answer.

          – Jack Bashford
          Mar 22 at 1:11













        1












        1








        1







        It's because the loop runs, then when you click on your buttons, j is equal to 10. Since your values are coming from the button's IDs, you can use that to your advantage:






        var j = 0;
        for (j = 0; j < 10; j++)
        $('#btn-' + j).click(function()
        alert($(this).attr("id").split("btn-")[1]);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>








        share|improve this answer













        It's because the loop runs, then when you click on your buttons, j is equal to 10. Since your values are coming from the button's IDs, you can use that to your advantage:






        var j = 0;
        for (j = 0; j < 10; j++)
        $('#btn-' + j).click(function()
        alert($(this).attr("id").split("btn-")[1]);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>








        var j = 0;
        for (j = 0; j < 10; j++)
        $('#btn-' + j).click(function()
        alert($(this).attr("id").split("btn-")[1]);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>





        var j = 0;
        for (j = 0; j < 10; j++)
        $('#btn-' + j).click(function()
        alert($(this).attr("id").split("btn-")[1]);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Mar 22 at 1:01









        Jack BashfordJack Bashford

        15.5k31848




        15.5k31848












        • Perfect solution, thanks.

          – FoxyFish
          Mar 22 at 1:05











        • No problem whatsoever @FoxyFish - if my answer fixed your problem, please mark it as accepted by clicking the grey tick mark to the left of my answer.

          – Jack Bashford
          Mar 22 at 1:11

















        • Perfect solution, thanks.

          – FoxyFish
          Mar 22 at 1:05











        • No problem whatsoever @FoxyFish - if my answer fixed your problem, please mark it as accepted by clicking the grey tick mark to the left of my answer.

          – Jack Bashford
          Mar 22 at 1:11
















        Perfect solution, thanks.

        – FoxyFish
        Mar 22 at 1:05





        Perfect solution, thanks.

        – FoxyFish
        Mar 22 at 1:05













        No problem whatsoever @FoxyFish - if my answer fixed your problem, please mark it as accepted by clicking the grey tick mark to the left of my answer.

        – Jack Bashford
        Mar 22 at 1:11





        No problem whatsoever @FoxyFish - if my answer fixed your problem, please mark it as accepted by clicking the grey tick mark to the left of my answer.

        – Jack Bashford
        Mar 22 at 1:11











        1














        You can grab the id off of the current target element and parse out the index.






        for (let index = 0; index < 4; index++) 
        $('#btn-' + index).click(function(e)
        var value = parseInt(e.target.id.replace(/[D+]/g, ''), 10);
        alert(value);
        );

        <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
        <button id='btn-0'>One</button>
        <button id='btn-1'>Two</button>
        <button id='btn-2'>Three</button>
        <button id='btn-3'>Four</button>








        share|improve this answer



























          1














          You can grab the id off of the current target element and parse out the index.






          for (let index = 0; index < 4; index++) 
          $('#btn-' + index).click(function(e)
          var value = parseInt(e.target.id.replace(/[D+]/g, ''), 10);
          alert(value);
          );

          <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
          <button id='btn-0'>One</button>
          <button id='btn-1'>Two</button>
          <button id='btn-2'>Three</button>
          <button id='btn-3'>Four</button>








          share|improve this answer

























            1












            1








            1







            You can grab the id off of the current target element and parse out the index.






            for (let index = 0; index < 4; index++) 
            $('#btn-' + index).click(function(e)
            var value = parseInt(e.target.id.replace(/[D+]/g, ''), 10);
            alert(value);
            );

            <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
            <button id='btn-0'>One</button>
            <button id='btn-1'>Two</button>
            <button id='btn-2'>Three</button>
            <button id='btn-3'>Four</button>








            share|improve this answer













            You can grab the id off of the current target element and parse out the index.






            for (let index = 0; index < 4; index++) 
            $('#btn-' + index).click(function(e)
            var value = parseInt(e.target.id.replace(/[D+]/g, ''), 10);
            alert(value);
            );

            <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
            <button id='btn-0'>One</button>
            <button id='btn-1'>Two</button>
            <button id='btn-2'>Three</button>
            <button id='btn-3'>Four</button>








            for (let index = 0; index < 4; index++) 
            $('#btn-' + index).click(function(e)
            var value = parseInt(e.target.id.replace(/[D+]/g, ''), 10);
            alert(value);
            );

            <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
            <button id='btn-0'>One</button>
            <button id='btn-1'>Two</button>
            <button id='btn-2'>Three</button>
            <button id='btn-3'>Four</button>





            for (let index = 0; index < 4; index++) 
            $('#btn-' + index).click(function(e)
            var value = parseInt(e.target.id.replace(/[D+]/g, ''), 10);
            alert(value);
            );

            <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
            <button id='btn-0'>One</button>
            <button id='btn-1'>Two</button>
            <button id='btn-2'>Three</button>
            <button id='btn-3'>Four</button>






            share|improve this answer












            share|improve this answer



            share|improve this answer










            answered Mar 22 at 1:03









            Mr. PolywhirlMr. Polywhirl

            17.6k85092




            17.6k85092





















                0














                If you do the event binding in a function you get a closure keeping the value.






                var j = 0;
                for (j = 0; j < 10; j++)
                addClick(j);


                function addClick(j)
                $('#btn-' + j).click(function()
                alert(j);
                );

                <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
                <button id='btn-0'>One</button>
                <button id='btn-1'>Two</button>
                <button id='btn-2'>Three</button>
                <button id='btn-3'>Four</button>








                share|improve this answer



























                  0














                  If you do the event binding in a function you get a closure keeping the value.






                  var j = 0;
                  for (j = 0; j < 10; j++)
                  addClick(j);


                  function addClick(j)
                  $('#btn-' + j).click(function()
                  alert(j);
                  );

                  <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
                  <button id='btn-0'>One</button>
                  <button id='btn-1'>Two</button>
                  <button id='btn-2'>Three</button>
                  <button id='btn-3'>Four</button>








                  share|improve this answer

























                    0












                    0








                    0







                    If you do the event binding in a function you get a closure keeping the value.






                    var j = 0;
                    for (j = 0; j < 10; j++)
                    addClick(j);


                    function addClick(j)
                    $('#btn-' + j).click(function()
                    alert(j);
                    );

                    <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
                    <button id='btn-0'>One</button>
                    <button id='btn-1'>Two</button>
                    <button id='btn-2'>Three</button>
                    <button id='btn-3'>Four</button>








                    share|improve this answer













                    If you do the event binding in a function you get a closure keeping the value.






                    var j = 0;
                    for (j = 0; j < 10; j++)
                    addClick(j);


                    function addClick(j)
                    $('#btn-' + j).click(function()
                    alert(j);
                    );

                    <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
                    <button id='btn-0'>One</button>
                    <button id='btn-1'>Two</button>
                    <button id='btn-2'>Three</button>
                    <button id='btn-3'>Four</button>








                    var j = 0;
                    for (j = 0; j < 10; j++)
                    addClick(j);


                    function addClick(j)
                    $('#btn-' + j).click(function()
                    alert(j);
                    );

                    <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
                    <button id='btn-0'>One</button>
                    <button id='btn-1'>Two</button>
                    <button id='btn-2'>Three</button>
                    <button id='btn-3'>Four</button>





                    var j = 0;
                    for (j = 0; j < 10; j++)
                    addClick(j);


                    function addClick(j)
                    $('#btn-' + j).click(function()
                    alert(j);
                    );

                    <script src="https://code.jquery.com/jquery-3.3.1.js"></script>
                    <button id='btn-0'>One</button>
                    <button id='btn-1'>Two</button>
                    <button id='btn-2'>Three</button>
                    <button id='btn-3'>Four</button>






                    share|improve this answer












                    share|improve this answer



                    share|improve this answer










                    answered Mar 22 at 1:05









                    Adrian BrandAdrian Brand

                    4,85121124




                    4,85121124





















                        0














                        Try this,



                        $( "button[id^=btn]" ).each(function(index) 
                        $(this).on("click", function()
                        var idvalue = $(this).attr('id');

                        //alert(index);
                        //or
                        idvalue = idvalue.replace("btn-","");
                        alert(idvalue);
                        );
                        );





                        share|improve this answer



























                          0














                          Try this,



                          $( "button[id^=btn]" ).each(function(index) 
                          $(this).on("click", function()
                          var idvalue = $(this).attr('id');

                          //alert(index);
                          //or
                          idvalue = idvalue.replace("btn-","");
                          alert(idvalue);
                          );
                          );





                          share|improve this answer

























                            0












                            0








                            0







                            Try this,



                            $( "button[id^=btn]" ).each(function(index) 
                            $(this).on("click", function()
                            var idvalue = $(this).attr('id');

                            //alert(index);
                            //or
                            idvalue = idvalue.replace("btn-","");
                            alert(idvalue);
                            );
                            );





                            share|improve this answer













                            Try this,



                            $( "button[id^=btn]" ).each(function(index) 
                            $(this).on("click", function()
                            var idvalue = $(this).attr('id');

                            //alert(index);
                            //or
                            idvalue = idvalue.replace("btn-","");
                            alert(idvalue);
                            );
                            );






                            share|improve this answer












                            share|improve this answer



                            share|improve this answer










                            answered Mar 22 at 1:13









                            MyHealingLifeMyHealingLife

                            54




                            54



























                                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%2f55291387%2flooping-a-button-click-event-in-jquery%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

                                Kamusi Yaliyomo Aina za kamusi | Muundo wa kamusi | Faida za kamusi | Dhima ya picha katika kamusi | Marejeo | Tazama pia | Viungo vya nje | UrambazajiKuhusu kamusiGo-SwahiliWiki-KamusiKamusi ya Kiswahili na Kiingerezakuihariri na kuongeza habari

                                Swift 4 - func physicsWorld not invoked on collision? The Next CEO of Stack OverflowHow to call Objective-C code from Swift#ifdef replacement in the Swift language@selector() in Swift?#pragma mark in Swift?Swift for loop: for index, element in array?dispatch_after - GCD in Swift?Swift Beta performance: sorting arraysSplit a String into an array in Swift?The use of Swift 3 @objc inference in Swift 4 mode is deprecated?How to optimize UITableViewCell, because my UITableView lags

                                Access current req object everywhere in Node.js ExpressWhy are global variables considered bad practice? (node.js)Using req & res across functionsHow do I get the path to the current script with Node.js?What is Node.js' Connect, Express and “middleware”?Node.js w/ express error handling in callbackHow to access the GET parameters after “?” in Express?Modify Node.js req object parametersAccess “app” variable inside of ExpressJS/ConnectJS middleware?Node.js Express app - request objectAngular Http Module considered middleware?Session variables in ExpressJSAdd properties to the req object in expressjs with Typescript