最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to make a variable which is inside a function global? - Stack Overflow

programmeradmin0浏览0评论

Following is my javascript function, I want to use variable selected outside function, but I am getting selected not defined error in console of inspect element. window.yourGlobalVariable is not solving my problem.

function showMe(pause_btn) {
    var selected = [];
    for (var i = 0; i < chboxs.length; i++) {
        if (chboxs[i].checked) {
            selected.push(chboxs[i].value);
        }
    }
}

Following is my javascript function, I want to use variable selected outside function, but I am getting selected not defined error in console of inspect element. window.yourGlobalVariable is not solving my problem.

function showMe(pause_btn) {
    var selected = [];
    for (var i = 0; i < chboxs.length; i++) {
        if (chboxs[i].checked) {
            selected.push(chboxs[i].value);
        }
    }
}
Share Improve this question edited Apr 18, 2015 at 10:04 Ahmed Syed asked Apr 18, 2015 at 8:03 Ahmed SyedAhmed Syed 1,1892 gold badges18 silver badges47 bronze badges 4
  • "stackoverflow javascript global variables" -> stackoverflow./questions/4862193/javascript-global-variables – royhowie Commented Apr 18, 2015 at 8:36
  • possible duplicate of Define global variable in a JavaScript function – royhowie Commented Apr 18, 2015 at 8:37
  • @rowhowie I edited my question window.yourGlobalVariable is not solving my problem. – Ahmed Syed Commented Apr 18, 2015 at 9:35
  • @MujahedAKAS: It would solve the problem you've described, assuming a browser environment. If you provide more context, we may be able to help you solve it in a way that doesn't rely on one of JavaScript's biggest bugs (since fixed by strict mode). – T.J. Crowder Commented Apr 18, 2015 at 9:38
Add a ment  | 

7 Answers 7

Reset to default 13

If you really want it to be global, you have two options:

  1. Declare it globally and then leave the var off in the function:

    var selected;
    function showMe(pause_btn) {
        selected = [];
        for (var i = 0; i < chboxs.length; i++) {
            if (chboxs[i].checked) {
                selected.push(chboxs[i].value);
            }
        }
    }
    
  2. Assign to a window property

    function showMe(pause_btn) {
        window.selected = [];
        for (var i = 0; i < chboxs.length; i++) {
            if (chboxs[i].checked) {
                selected.push(chboxs[i].value); // Don't need `window.` here, could use it for clarity though
            }
        }
    }
    

    A properties of window are global variables (you can access them either with or without window. in front of them).

But, I would avoid making it global. Either have showMe return the information:

function showMe(pause_btn) {
    var selected = [];
    for (var i = 0; i < chboxs.length; i++) {
        if (chboxs[i].checked) {
            selected.push(chboxs[i].value);
        }
    }
    return selected;
}

...and then where you need it:

var selected = showMe();

...or declare it in the scope containing showMe, but not globally. Without context, that looks exactly like #1 above; here's a bit of context:

(function() {
    var selected;
    function showMe(pause_btn) {
        selected = [];
        for (var i = 0; i < chboxs.length; i++) {
            if (chboxs[i].checked) {
                selected.push(chboxs[i].value);
            }
        }
        return selected;
    }

    // ...other stuff that needs `selected` goes here...
})();

The outer anonymous function is a "scoping function" which means that selected isn't global, it's just mon to anything in that function.

Instead of assigning it to the window object or declaring it outside of the function, I would remend creating your own object outside of the function, then assigning variables from there. This avoids cluttering the window object and puts all of your global variables in one place, making them easy to keep track of. For example,

var globalObject {}
function MyFunction {
  globalObject.yourVariableName=what your variable is
}

Do this:

var selected;

function showMe(pause_btn) {
    selected = [];
    for (var i = 0; i < chboxs.length; i++) {
        if (chboxs[i].checked) {
            selected.push(chboxs[i].value);
        }
    }
}

You can actually skip the var selected; line but I prefer declaring my variables.

Dont use this;

 selected = [];

it is a bug of javascript

window.selected = []; 

inside your function.

You could define the array called selected in the scope that the function called showMe is defined.

In terms of code:

var selected = [];

function showMe(pause_btn) {
    for (var i = 0; i < chboxs.length; i++) {
        if (chboxs[i].checked) {
            selected.push(chboxs[i].value);
        }
    }
}
var selected = [];
function showMe(pause_btn) {

    for (var i = 0; i < chboxs.length; i++) {
        if (chboxs[i].checked) {
            selected.push(chboxs[i].value);
        }
    }
}

If you declare selected as a property on the window object, you will be able to access it from anywhere else.

function showMe(pause_btn) {
  window.selected = [];
  for (var i = 0; i < chboxs.length; i++) {
    if (chboxs[i].checked) {
      selected.push(chboxs[i].value);
    }
  }
}
发布评论

评论列表(0)

  1. 暂无评论