Software Development Exam  >  Software Development Questions  >  What will be the output of the following code... Start Learning for Free
What will be the output of the following code snippet?
var x = 10;
function foo() {
  console.log(x);
  var x = 20;
}
foo();
  • a)
    10
  • b)
    20
  • c)
    undefined
  • d)
    ReferenceError
Correct answer is option 'C'. Can you explain this answer?
Most Upvoted Answer
What will be the output of the following code snippet?var x = 10;funct...
Variable hoisting causes the declaration of 'var x' inside the function to be hoisted to the top. However, it is initialized with the value 'undefined' before the assignment. Therefore, the output is 'undefined'.
Free Test
Community Answer
What will be the output of the following code snippet?var x = 10;funct...
Explanation:

The output of the code snippet will be undefined.

Code Analysis:
- The code snippet declares a variable x and assigns it the value 10.
- It then defines a function called foo.
- Inside the foo function, a new variable x is declared using the var keyword.
- The console.log statement inside the function tries to log the value of x.
- Finally, the foo function is called.

Variable Hoisting:
- JavaScript has a concept called hoisting where variable and function declarations are moved to the top of their containing scope during the compilation phase.
- However, only the declarations are hoisted, not the initializations.
- In the code snippet, the variable x inside the foo function is hoisted to the top of the function scope.
- Therefore, the declaration of var x; is moved to the top of the foo function.
- As a result, the original x variable inside the function is shadowed by the hoisted variable declaration.
- Since the hoisted variable declaration does not have an initialization, it is assigned the value undefined by default.

Output Explanation:
- When the foo function is called, it tries to log the value of x.
- However, since the hoisted variable declaration is assigned the value undefined, that is what gets logged to the console.
- The original x variable outside the function remains unaffected and retains its value 10.

Therefore, the output of the code snippet is undefined.
Attention Software Development Students!
To make sure you are not studying endlessly, EduRev has designed Software Development study material, with Structured Courses, Videos, & Test Series. Plus get personalized analysis, doubt solving and improvement plans to achieve a great score in Software Development.
Explore Courses for Software Development exam

Top Courses for Software Development

What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer?
Question Description
What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer? for Software Development 2024 is part of Software Development preparation. The Question and answers have been prepared according to the Software Development exam syllabus. Information about What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer? covers all topics & solutions for Software Development 2024 Exam. Find important definitions, questions, meanings, examples, exercises and tests below for What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer?.
Solutions for What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer? in English & in Hindi are available as part of our courses for Software Development. Download more important topics, notes, lectures and mock test series for Software Development Exam by signing up for free.
Here you can find the meaning of What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer? defined & explained in the simplest way possible. Besides giving the explanation of What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer?, a detailed solution for What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer? has been provided alongside types of What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer? theory, EduRev gives you an ample number of questions to practice What will be the output of the following code snippet?var x = 10;function foo() { console.log(x); var x = 20;}foo();a)10b)20c)undefinedd)ReferenceErrorCorrect answer is option 'C'. Can you explain this answer? tests, examples and also practice Software Development tests.
Explore Courses for Software Development exam

Top Courses for Software Development

Explore Courses
Signup for Free!
Signup to see your scores go up within 7 days! Learn & Practice with 1000+ FREE Notes, Videos & Tests.
10M+ students study on EduRev