90

Possible Duplicate:
Detecting an undefined object property in JavaScript

From the below JavaScript sample,

try {
    if(jsVar) {
        proceed();
    }
}
catch(e) {
    alert(e);
}

this jsVar is declared and initialized in another file.

The problem is that code throws undefined error when this code is executed before the other file (where its declared and initialized) is executed. That is why it is surrounded by try and catch.

What's the best way to handle this undefined error than try catch?

1
  • 1
    I don't get it, How come even after marked as duplicate this question still got 48 up votes. Isn't it's lack of judgement and decreases quality of these up votes. And then voting might be broke if duplicate questions get up votes. Commented Oct 19, 2018 at 22:34

3 Answers 3

120

You can check the fact with

if (typeof jsVar == 'undefined') {
  ...
}
Sign up to request clarification or add additional context in comments.

5 Comments

Does this have any advantage over "my" way?
It may throw an error: jsVar is not defined. You should test it this way : if (window.jsVar !== undefined) {}. It seems like typeof() "catches" this error.
@Fabien: Or perhaps use if("jsVar" in window){}... but I would avoid code that would require coding for this error case.
@logic-unit that is in theory better, but == is enough for a typeof comparission, since there are only a few possible values that can be returned.
You can use the typeof to determine the type of the unevaluated operand. It will return the type of operand in a string. You can use "===", if you know they are equal value and equal type.
16

As is often the case with JavaScript, there are multiple ways to do this:

typeof foo !== 'undefined'
window.foo !== undefined
'foo' in window

The first two should be equivalent (as long as foo isn't shadowed by a local variable), whereas the last one will return true if the global varible is defined, but not initialized (or explicitly set to undefined).

1 Comment

hmm 'foo' in windows seems to return false even if foo is defined for me, in fact only typeof seems to work in my case
1

In JavaScript, the following values will cause the if condition to fail and not execute its statement: null, undefined, false, NaN, the number 0, and the empty string ''.

Assuming that the variable jsVar is a boolean and that we want to call the proceed() method when jsVar is true, we can do the following check.

if (jsVar && jsVar == true)
    proceed();

The above code snippet first check that jsVar has been defined and then checks that its value is true. The if condition will be satisfied only if both the conditions are met.

If jsVar is not a boolean then we can substitute the appropriate check in place of jsVar == true in the code above.

3 Comments

keep in mind that this does not check for boolean true as you're not using strict comparison (in JS, eg '1' == true is true!); this will still throw the reference error as well if the variable has not been defined, ie your code doesn't solve Madhu's problem
@Christoph you're right!
if (jsVar && jsVar !== undefined) should work

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.