JavaScript Hoisting

JavaScript hoisting is basically that declarations are moved to the top of your code.

Actually your function and variable declarations are added to memory during the compile phase.
And they stay exactly where you typed them in your code.

JavaScript hoists all declarations

JavaScript hoists all declarations. Initializations are not hoisted.

Declare and initialize a variable, e.g. var x = 8;, only the var x; part (the declaration) is hoisted.
The x = 8; (the initialization) is not hoisted.

A variable that is declared but not initialized is automatically set as undefined.
Take a look at the examples to understand this.

Hoisting Variables Examples

// This is how you would expect to write the code
var x = 8; // Initialize and assign 8 to x
console.log('X has the value: '+ x);  // The printed text is: "X has the value: 8"
// Here y is assigned before it is declared
y = 8; // Assign 8 to y
console.log('Y has the value: '+ y);  // The printed text is: "Y has the value: 8"
var y; // Declare y

Learn more about JavaScript Variables

Hoisting Variables Undefined Examples

// Declare and assign the variable at the end
// Only the declaration is hoisted
console.log('Z has the value: '+ z);  // The printed text is: "Z has the value: undefined"
var z = 8; // Declare and assign 8 to z

Hoisting Functions Examples

// This is how you would expect to write the code
function printName(name) {
  console.log("My name is " + name);
printName("Donald");  // The printed text is: "My name is Donald"
// Here the function is called before it is declared
printCity("London");  // The printed text is: "My favorite city is London"
function printCity(name) {
  console.log("My favorite city is " + name);

Learn more about JavaScript Functions

Let and Const Statement

Variables and constants declared with let or const are not hoisted!

Learn more about JavaScript Let Learn more about JavaScript Const

Hoisting Best Practices

Hoisting is not well known to many developers.

It is considered a best practice to declare variables at the top of their respective scopes. Then you would limit undesirable effects.
Always initialize variables when they are declared. This will provide better code and avoid undefined variables.

JavaScript strict mode gives an error if variables is used before they are declared.

Learn more about JavaScript Scope

Check this out

JS JavaScript: Numbers Methods

Number methods can help you when working with number datatypes. The number methods are improved in ES6 (ECMAScript 6).

Keep reading to understand how the number methods and properties may help you.

JS JavaScript: Strict Mode

The strict context prevents some actions and throws more exceptions. Strict mode changes previously accepted "bad syntax" into errors. Strict mode will for example prevent using undeclared variables. The "use strict" directive was new in ECMAScript version 5.

JS JavaScript: Hoisting

JavaScript hoisting is basically that declarations are moved to the top of your code.

Actually your function and variable declarations are added to memory during the compile phase.
And they stay exactly where you typed them in your code.

JS JavaScript: Comparisons

Comparison and Logical operators are used to test for true or false.

JavaScript provides three different value-comparison operations, loose equality, strict equality and They have different usage so learn when to use them.


JavaScript is one of the 3 core language technologies of the World Wide Web that all web developers must learn:

1.      HTML to define the content of web pages.

2.      CSS to specify the layout of web pages.

3.      JavaScript to program the behavior of web pages.

JavaScript is a scripting or programming language that allows you to implement complex things on web pages. Every time a web page does more than just sit there and display static information for you to look at, displaying timely content updates, interactive maps, animated 2D/3D graphics, scrolling video jukeboxes, etc. − you can bet that JavaScript is probably involved.

The benefits of using JavaScript are:

1.      You can validate user input before sending the page off to the server. This saves server traffic, which means less load on your server.

2.      Immediate feedback to the visitors − They don't have to wait for a page reload to see if they have forgotten to enter something.

3.      Increased interactivity − You can create interfaces that react when the user hovers over them with a mouse or activates them via the keyboard.

4.      Richer interfaces − You can use JavaScript to include such items as drag-and-drop components and sliders to give a Rich Interface to your site visitors.


Need more Honney

NDC Conferences

The NDC Conferences (Norwegian Developers Conference) are one of the world`s largest independent software conferences for .NET & Agile development. The conference covers everything you need to know within software development. The conferences are held each year in many places such as Oslo, Copenhagen, London, Sydney and Minnesota.

Update Conference Prague

Update Conference Prague is the biggest developer conference in the Czech Republic. The conference is offering sessions delivered by the top experts from all around the world. Their goal is to inspire the attendees and enrich their knowledge.

Troy Hunt

Learn about Web Security from Troy Hunt. He is a really engaged speaker that frequently give talks on conferences around the world. Troy is a Microsoft MVP and you can even learn from him on some great courses on Pluralsight.

W3Schools is a great education Web Site for learning web technologies. On W3Schools you may find well organized basic to advanced tutorials and references.

Scott Hanselman

Learn about Web Technologies and new trends from Scott Hanselman. Scott Hanselman is an author of developer books and he is an engaged speaker that usually talks about the Microsoft stack. You may meet Scott on conferences around the world.

Developer Week

DeveloperWeek is one of the world’s largest developer conferences. Developer Week focus on new dev technologies, the conference have talks and workshops for newbies and experienced audience. You can attend on a Developer Week conference different places in Nothern America.


Honneybag blog

Learn JavaScript Debugging

Searching for bugs and fixing them is called code debugging. The bugs might be difficult to diagnose and therefore it is important to have a good approach to find and fix the bugs effectively. Bugs in the code might be syntax errors or logical errors. Sometimes nothing happens when the code contains bugs and there is few indications where to search. Modern web browser includes a powerful suite of developer tools. The tools do a range of things...

Explore JavaScript Arrays

Arrays are frequently used by developers. Programming languages can have slightly different implementation of arrays. An array is an object that can store a collection of items. You may say it`s a special variable that can have more than one value. The array holds many values under a single name, and you may access the values by referring to an index number. The easiest way to create....

Ultimate Guide to HTML Colors

It is essential to give the user a good user experience. There are many things you should focus on, one of them is how you use colors on your website. We don't have to struggle with black and white TVs anymore. Users expect more and more and we can apply colors to everything we want. Texts, borders, backgrounds, shadows – in HTML they all can have whatever color you decide....

Wanna be a sheep? Check out the most popular subjects
Wanna be a little different? Check out the less popular subjects