Uncaught TypeError: Cannot read property of undefined
JavaScript TypeError is thrown when an operand or argument passed to a function is incompatible with the type expected by that operator or function. This error occurs in Chrome Browser when you read a property or call a method on an undefined object . There are a few variations of this error depending on the property you are trying to access. Sometimes instead of undefined it will say null.
example
function myFunc(inVar) {
if (inVar === undefined) {
console.log(inVar.not)
}
return inVar;
}
var testVar;
console.log(myFunc(testVar));
When you run this code, you will get this message in browser:
Uncaught TypeError: Cannot read property 'not' of undefined
In basic terms, undefined means that a variable has been declared but has not yet been assigned a value. This particular error is probably easiest to understand from the perspective of undefined, since undefined is not considered an object type at all (but its own undefined type instead), and properties can only belong to objects within JavaScript.
In the above code, when you get undefined error , you need to make sure that whichever variables throws undefined error, is assigned a value to it.
example
function myFunc(inVar) {
if (inVar === undefined) {
console.log(inVar.not)
}
return inVar;
}
var testVar=99; //initialize here
console.log(myFunc(testVar));
In the above JacaScript you can the variable testVar is initialized the value of 99. So the script run successfully.
Handling undefined

You can handle undefined by using if statement.
if (typeof(yourvariable) == 'undefined') {
...
}
JavaScript undefined

Undefined means a variable has been declared, but the value of that variable has not yet been defined. In JavaScript there is Undefined ( type ), undefined ( value ) and undefined ( variable ).
var myVar;
console.log(myVar);
output
undefined
Also, undefined is of the type undefined:
console.log(typeof myVar);
output
undefined
Moreover, declare a variable then assign undefined to it:
var myVar = undefined;
console.log(test);
output
undefined
Related Topics
- JavaScript Interview Questions (Part2)
- JavaScript Interview Questions (Part3)
- Is JavaScript a true OOP language?
- Advantages and Disadvantages of JavaScript
- Difference Between JavaScript and ECMAScript?
- What is noscript tag?
- Escaping Special Characters in JavaScript
- What is undefined x 1 in JavaScript?
- JavaScript : Logical Operators
- Difference between '=', '==' and '===' operators?
- How to reload a page using JavaScript?
- How to write html code dynamically using JavaScript?
- How to add html elements dynamically with JavaScript?
- How to load another html page from javascript?
- What Is The Disadvantages Using InnerHTML In JavaScript?
- What is Browser Object Model
- How to detect the OS on the client machine in JavaScript?
- Difference between window, document, and screen in Javascript?
- Difference between the substr() and substring() in JavaScript?
- How to replace all occurrences of a string in JavaScript?
- How to test a string as a literal and as an object ?
- What is Associative Array? How do we use it?
- What is an anonymous function in JavaScript?
- What is the use of 'bind' method in JavaScript?
- Pure functions Vs. Impure functions in javascript
- Is Javascript a Functional Programming Language?
- What's the Difference Between Class and Prototypal Inheritance?
- Javascript, Pass by Value or Pass by Reference?
- How to prevent modification of an object in Javascript?
- What is 'this' keyword in JavaScript?
- How Does Function Hoisting Work in JavaScript?
- What do mean by NULL in Javascript?
- What does the delete operator do in JavaScript?
- What is the Infinity property used for in Javascript?
- Event bubbling and Event Capturing in JavScript?
- What is "strict mode" and how is it used in JavaScript?
- What is the difference between .call() and .apply()?
- Entire content of a JavaScript source file in a function block?
- What is an immediately-invoked function expression?
- What is escape & unescape String functions in JavaScript?
- What is the instanceof operator in JavaScript?
- What Are RESTful (REpresentational State Transfer)Web Services?
- What is Unobtrusive JavaScript & Why it's Important?
- What Does JavaScript Void(0) Mean?
- What are JavaScript Cookies?
- Difference between Client side JavaScript and Server side JavaScript
- TypeError: document.getelementbyid(...) is null
- What's the difference between Null and Undefined?