Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8595925
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 12, 20262026-06-12T00:33:20+00:00 2026-06-12T00:33:20+00:00

I have a variable id that is generate in a for loop. For some

  • 0

I have a variable id that is generate in a for loop. For some reason, the id changes from 0 to 1 when it is passed in a callback. My guess is that I am passing the id parameter incorrectly.

    refreshMenu: function(mods, callback){
    var menu = document.getElementById('menu'), 
            ul = document.createElement('ul');

    menu.innerHTML = ''; 
    menu.appendChild(ul);

    for(var id = 0; id < mods.length; id++){
        var li = document.createElement('li'), 
        that = this;


            ul.appendChild(li);

            li.setAttribute('id', id);
            li.innerHTML = mods[id].get('name');

            console.log(id); // HERE ---> 0

            li.addEventListener('click', function(){
                that.selectMenu(li, function(){

                    console.log(id); HERE ---> //1 ?

                that.selectList(id - 1);

                });
            }, false);
        }

        callback();
    }, 

    selectList: function(id)
        var activeList = this.activeList();

        console.log(id);

        if (activeList.id == id){
            return;
        } 
        else if (activeList){
            activeList.setAttribute('class', '');
        };

        var target = document.getElementById(id);
        target.setAttribute('class', 'activeList');
    },  

    selectMenu: function(li, callback){
        if(li.className == 'activeMenu') 
            return; 

        var active = document.getElementsByClassName('activeMenu')[0];
        if(active)      
            active.setAttribute('class', '');

        li.setAttribute('class', 'activeMenu');

        callback();
    },
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-12T00:33:22+00:00Added an answer on June 12, 2026 at 12:33 am

    It’s a very common gotcha when building closures within for loops. All of the functions you’re creating refer to the same id variable, and the for loop mutates the variable.

    One simple way to fix this: make a helper function that creates these functions, and have the helper take its own parameter.

    // In the body of the for loop ...
    var makeClickFunction = function (li, id) {
        return function (){
            that.selectMenu(li, function(){
                                   console.log(id);
                                   that.selectList(id - 1);
                                });
        };
    };
    li.addEventListener('click', makeClickFunction(li, id));
    

    The helper’s binding of its id argument shadows that of the for loop, and this is a good thing! We’re intentionally doing this. We also capture li, since it too needs to be held.

    Later, we call makeClickFunction, passing in the current value within the for loop. for will continue to mutate its id, but that’s ok: that mutation has no relationship to the behavior on makeClickFunction‘s closures.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a variable that im define with another variable and some text. $title
I have some code that creates a variable of some name automatically and assigns
I have code that generates a List<string[]> variable but can't quite figure out how
I'm studying javascript these days and I have question. I have variable that contain
I have a variable that may contain objects or may be undefined. I wish
I have a variable that contains the following JSON string: { 0 : Jun
I have a variable that can either contain a list of strings or a
I have a variable that contains : Sometimes array of strings and sometimes array
I have a variable that's being changed all the time in the course of
I have a variable that I'm using to build a JavaScript function call, and

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.