You're great at explaining concepts in the simplest, most-organized manner.
@luisgeronimo43875 жыл бұрын
Damn... Your teaching skills are over 9000! I really like how you talk about what people used to do and how it is now, it gives more context around it. Also small details like "this is a function expression, EVEN IF I GAVE IT A NAME it is still a function expression BECAUSE..." Thank you.
@rupertsmith94603 жыл бұрын
Again and again and again and again you end up being the one who explains these concepts the best. Thank you Steve
@rotrose75314 жыл бұрын
Thank you another great explanation, finally let and const seem to be a lot more easier to approach. As all others, I respect the way you treat every details seriously and take all the effort to deliver them in the easiest way to us.
@heavydirtysoul14914 жыл бұрын
As for me that's the best tutorial about hoisting so far. Your channel is definetely worth subscribing!
@halofreak6443 жыл бұрын
i started coding in C++ and java. I did some other languages like php and ended up at javascript. I was surprised at the power and simplicity of it like not needing to declare what type of variable you're trying to create. its great
@sujoy92bhowmick5 жыл бұрын
Sir, Your react native tutorials are awesome. Please continue
@paieu Жыл бұрын
great expaination professor steve.
@nataliewenberg56973 жыл бұрын
Thank you, thank you so much! I am going to check other videos of yours! Short and informative
@saimi034 жыл бұрын
So far the best video I have watched!
@chesterxp5083 жыл бұрын
Another very cool tutorial!
@collinsushi11552 жыл бұрын
With let or const, the JS Interpreter still split the declared variable and its assigned value(if any), then hoists the declared variable to the top but unlike var, it does not assign the default value to 'undefined'
@edetmmekut809 Жыл бұрын
precise straight to point without any bullshite jargon
@edetmmekut809 Жыл бұрын
can you do something on react useref hook?
@laffed20455 жыл бұрын
So just to clarify, let/const still get hoisted but the interpreter does not set a default value of undefined to these?
@SteveGriffith-Prof3ssorSt3v35 жыл бұрын
Yes. If you have a line like this: let x; Then when you reach that line x will have a value of undefined, but not before.
@laffed20455 жыл бұрын
@@SteveGriffith-Prof3ssorSt3v3 Awesome thanks so much Steve. please keep posting!
@laurenthrl44335 жыл бұрын
Great explanation. Thanks for sharing!
@abhinandshetty90634 жыл бұрын
That explanation! 👌
@johnywhy46794 жыл бұрын
4:36 Won't `function f () {...}` get hoisted above `let log = ...`, thereby making `log` unavailable to function f?
@SteveGriffith-Prof3ssorSt3v34 жыл бұрын
function f(){ } and let log; Will be hoisted, but not run. When the script runs, the first thing that happens is console.log is assigned to log. Then f( ) runs. When it runs, log will be available.
@johnywhy46794 жыл бұрын
@@SteveGriffith-Prof3ssorSt3v3 So they're both getting hoisted. How can we be sure the let will get hoisted higher than f(){}?
@genylegend2 жыл бұрын
Now my concept got clear.
@manavjethani4118 Жыл бұрын
Hello, can anyone explain why this below output gives error, we have declare the same statement x = 5 inside a function, javascript attached it to global scope, then in this case why javascript didn't assign to global scope console.log(x) x = 5
@DmitriyMalayevProfile8 ай бұрын
Thanks Professor. Another question. Why does this becomes undefined, and "New" but if it's by itself it will no longer be undefined var currentCity = "New York" var changeCurrentCity = function(){ // let city = "city" // console.log(city) console.log(currentCity) var currentCity = "New" console.log(currentCity) }; changeCurrentCity() var currentCity = "New York" var changeCurrentCity = function(){ console.log(currentCity) //prints New York }; changeCurrentCity()
@SteveGriffith-Prof3ssorSt3v38 ай бұрын
when you use "new" in front of a function call, it changes what the function returns. Basic functions return undefined unless you add a return keyword and tell them what to return. If you call a function with "new" then the function will build a new object and return that when you omit the return keyword. Inside the function called with new, the keyword "this" refers to the object that will be returned. kzbin.info/www/bejne/f2OmlaWBobWXd7s
@gregcraig61633 жыл бұрын
My God your voice🤩🤩😍👌
@sparshgupta80784 жыл бұрын
Sir plz make a video on these terms Lexical environment Lexical binding They confuse us a lot♥️you are amazing
@SteveGriffith-Prof3ssorSt3v34 жыл бұрын
Thanks. Please add that to the comments on my tutorial request video
@oleksastep Жыл бұрын
Hoisting for 'let' is not explained. Is there sny example how we can take advantage of hoisting for 'let'? How can we use this 'let' hoisting?
@SteveGriffith-Prof3ssorSt3v3 Жыл бұрын
Let and const work the same way. All variables are hoisted. The difference with let and const is the temporal deadzone, which makes it feel like there is no hoisting because you still have to reach the line where you declare it before you can reference the variable.
@sam-hf8yc3 жыл бұрын
Thanks, man!
@RalphGoddard-tt1xq Жыл бұрын
Perhaps you cover this in a different video. With the introduction of 'let' and 'const' a different Global name space is also defined - at least as I understand it. Dev Tools splits it into 'window' and 'script'. This was a great source of confusion on my part as both spaces are referred to as Global on most online literature. Clarity around this naming convention, how they interact, would really be helpful. I have noticed that 'function declarations' end up in the window Global space. If one wants to avoid polluting the window name space then, by reason, function declarations should be avoided - at least as I understand it.
@SteveGriffith-Prof3ssorSt3v3 Жыл бұрын
When you declare a variable with `var` a property of the same name will be added to the window object. This doesn't happen with let and const. `var` variables are scoped globally or locally (inside a function). let and const variables are block scoped - globally or inside a set of { }. Every script that is loaded has it's own execution context. The window object is available globally across the execution contexts. Each function has a new execution context where variables can be declared and values stored. The window object is the container for all the Web APIs. Eg: window.document, window.navigator, etc. Core JavaScript is the part of JavaScript that exists both in the browser and in NodeJS. Variables can be scoped to the script. Depending on whether the scripts are loaded globally by the web page or as modules they may share or have separate scopes.
@RalphGoddard-tt1xq Жыл бұрын
@@SteveGriffith-Prof3ssorSt3v3 Thanks. I believe I have it straight now. Script 'global' variables defined with let and const do not become properties of the window object. It would seem there is a naming conflict going on here with 'global' ;-)
@sarfarazsheikh73782 жыл бұрын
great video
@samuelmatheson96555 жыл бұрын
i see, Do you have an advanced/paid tutorial out there?
@SteveGriffith-Prof3ssorSt3v35 жыл бұрын
Not yet. Hard to find the time to build one while still working full time and doing all these tutorials on KZbin. Hopefully next Summer.
@LGmediaGlobal3 жыл бұрын
Thank you
@halofreak6443 жыл бұрын
legend
@winmonaye4 жыл бұрын
why am I seeing the different results?? is spect changed recently? jsbin.com/zucehag/1/edit?js,console
@SteveGriffith-Prof3ssorSt3v34 жыл бұрын
JSBin is a different environment. Do an inspect element on the page, open the console and copy & paste your code into the console. Run it there and you will see the same output.
@sergeymigel46804 жыл бұрын
thanks!
@johnywhy46794 жыл бұрын
7:56 This seems like a bug in JS. If JS doesn't find a declaration in the fx or in global, it should give the variable it's contextual scope-- function-scope, in the case of x. "done to protect you, but leads to bad coding" -- sounds contradictory. Seems it DOESN'T protect you.
@zakaruPL4 жыл бұрын
It's not a bug, it's a feature :D well to be honest it's pretty basic JS behaviour. When you don't declare you variable BUT you assign value AND when you're in non-strict mode (which is default in JS) then compiler during the LHS phase will assign this variable into your global context (because it won't find it in function scope) - which is "window". When you set `strict mode` it will behave differently - you'll get Reference Error too. Paste this code into console and check it out ;) then remove "use strict" and check it again "use strict"; someFn(); console.log(window.globalVariable); function someFn() { globalVariable = 'some global value' }
@marcoonlinetv77695 жыл бұрын
Why you do not make a small app in Vanila JS like calculator or TodoList, something like that ?
@SteveGriffith-Prof3ssorSt3v35 жыл бұрын
Because there are hundreds of those online already. When I have the time I will create a course that has some real world value.
@husniddinqurbonboyev26344 жыл бұрын
You have 9 browsers installed on your mac ))
@SteveGriffith-Prof3ssorSt3v34 жыл бұрын
At least 9. I need to be able to test what I build on any platform. I also have Windows installed through Bootcamp and Linux on a VM.
@alvaroksin3 жыл бұрын
Broadcaster voice haha
@yarik83men515 жыл бұрын
+++
@TimeLapse200OK Жыл бұрын
function userDetails(username) { if (username) { console.log(age); let age = 30; } } userDetails("John"); why in this case the output is - Uncaught ReferenceError: Cannot access 'age' before initialization where as in case of the below code: //global scope console.log(num); let num=10; the output is - Uncaught ReferenceError: num is not defined?