admin管理员组文章数量:1340885
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
7 Answers
Reset to default 13If you really want it to be global, you have two options:
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); } } }
Assign to a
window
propertyfunction 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 withoutwindow.
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);
}
}
}
本文标签: javascriptHow to make a variable which is inside a function globalStack Overflow
版权声明:本文标题:javascript - How to make a variable which is inside a function global? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743655452a2517043.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论