Hasgeek launched in 2010. It’s been a decade! Join us for a recap of the year. If Hasgeek made an impact on your personal/professional journey, share your testimonial on: hasgeek.com/hasgeek/10/
Got your point : programming is about abstractions but to understand those abstractions one must know the internals. Or as he says it you become chess master once you know the internals 👍 great talk
Hey guys I though this information would help you. During the memory allocation phase,if you have a variable assignment (var b =3) it will allocate the memory for variable b and set the value of be to be UNDEFINED,a special value in JS.And later during execution phase the assignment actually happens.
There is a misnomer for that, it's called hoisting and it happens only for var, let and const declarations and function declarations, not for expressions. Go through ECMAScript spec, HTML spec, CSS spec and finally open documentations of V8 or Chakra engine, you will find all information there.
In ECMAScript 2015, let bindings are not subject to Variable Hoisting, which means that let declarations do not move to the top of the current execution context.
As far as I know , of "var", "let" and "const" only the variable declaration "var" ( not "let" and "const") is hoisted. This means variable initialization is not hoisted.
@@sebastiankumlin9542 Absolutely correct. Hosiiting is for var and function declaration, not even for let, const, and function expressions. Also, Hoisting takes place at the time of compilation.
I had a really hard time understanding the difference between function scope and closure. I can even understand the formal definition of closure. :D Thanks a lot for this video.
I can understand before coming this video some other mentor are explained clear to me But this is also. Awesome bro ❤️❤️❤️❤️❤️❤️❤️❤️❤️❤️ I love more on JavaScript
Awesome talk. Actually, Javascript when behaving like that everyone was thinking in the past it is stupid language, but with time we discovered this is the power, flexibility & versatility behind js. The guy who invented js is super genius!
But it was really stupid language when it was invented. It became pretty efficient and productive later. You can thank V8 developers for efficiency for example. And you can find the early language specifications. It had no all these cool things you use now. In fact even ES5 and ES6 has pretty different approach in a development.
Great talk. On second thoughts I realise speaker was talking abut execution of call stack and during that myG at one point holds reference to g() as it moves up. Btw funny reference to make adder function be on adder is a poisonous snake found in uk/ ( started the king Arthur's war on misunderstanding)
What you mean to say is that Declarations take precedence over Statements and are parsed through first in the 'compilation phase' and then things are put together in the 'execution phase' where statements are brought into play to generate the output? Add to that, variable hiding and forgiving nature of JS, the concept sounds and looks messy. I say that despite the fact that I like JavaScript. Very helpful and highly informative. Thanks a ton.
+Common Yunus - take a look at this which explains it briefly through guided examples: goo.gl/OOuqej Variable declarations are parsed first during the first run through of your program (hoisting also occurs), then during run time assignments and function calls are made.
Rishabh Mishra yeah but he uses loupe also the code gave as an example with the scope chain was exactly the same as in another talk very likely in the related videos
Please look into time duration 29:06 to 29:11 (ruclips.net/video/QyUFheng6J0/видео.htmlm6s). He did have taken the name of Philips Roberts and also have mentioned clearly that the visualization is done by him. To me, that looked like clear reference :)
That's not a declaration, it's an assignment. The declaration should start with var, let, const or function keyword. e=1 is an assignment which will fail in strict mode with Reference error. In non-strict mode, it will look for the variable e in the local scope and if found assign the value 1 to b, or else it will follow the scope chain till Global object. If it reaches Global object and it couldn't find the variable e declared anywhere then it will create a property e of Global object and assign the value 1, like Global.e =1, window.e=1 etc.
Then i guess he made a mistake by putting variable 'e' in the context of function f() instead of the global scope like he did with variable 'c'. Yes? (I am referring to his slides by minute 19:00)
hey guys, I have a problem about 28:32. Could anyone tell me why adder2's function has a different closure ?? Does it not refer to the same function?? Or I miss something??
It does hold the same code block. But an entirely new closure will be created for adder2 and the memory allocation references will be in adder2's closure. Which is why we dont see a mixup happening with adder3.
I think this may be irrelevant for u know after years but will be helpful for someone who is reading comments with same doubt, As Arindam mentioned, ruclips.net/video/QyUFheng6J0/видео.html local execution scope block is created when the method is executed so adder 2 is the holding method which is returned when executing makeAdder(2) whereas adder3 is holding method which is returned when executing makeAdder(3), this means when executing, local scope created for both the adder is different which basically means when u do console.dir(adder2), the scope chain it is pointing will be local execution block of makeAdder(2) and same with adder3, but global scope will be same for both of them, so this becomes like globalScope / \ makeAdder(3) scope makeAdder(2) scope / \ adder(3) scope adder(2) scope something like this
I think in the process of explaining compilation, when he says `var x does nothing` , he missed a point called hoisting. JS compiler pulls variables at the top and initializes them with undefined value.
At runtime execution phase ,it cannot find reference for c at the current scope, so it looks up at outer scope and does not find it so it creates the definition for the same (runtime execution phase) i.e var c =4 ; since it reached finally at global scope so value for the same is global..
Why is variable 'e' not placed in global scope during its first declaration while its similar case 'c' is in global scope? I will get a dinner party to whoever answers. 🐱
Mr. KS what you said is BS :) If the concept is same it doesn't matter who says it, it is going to be the same. Of course provided you know the concept and are saying it correct :P Mr. Arindam Paul was just Amazing !! Please stop BSing and passing your negativity to others :) Have a great day. Bye :)
Had you attended any university or wrote a dissertation or thesis, you would have unquestionably understood what I was alluding to. You need to cite references. First of all, I never said you are incorrect, I just said it was lifted from another person who had put his precious time and effort to create the content for consumption, the least one could do is to pay due credit to that person, needn't be monetarily but just a few words before passing on the content as your own. There is something called conscience. :) Instead of acknowledging the creator of the content, which btw reeks of negativity and feigned superiority, you are trying to ridicule me for pointing that out. You call yourself "geek"! Rightly so, just read about the etymology of the word, you're a perfect example. :))
Please look into time duration 29:06 to 29:11 (ruclips.net/video/QyUFheng6J0/видео.htmlm6s). He did have taken the name of Philips Roberts and also have mentioned clearly that the visualization is done by him. To me, that looked like clear reference :) By the way, it is not me giving the lecture :) I am just an audience who really liked Arindam's lecture and felt bad that you were too busy finding a fault which actually is not correct rather than to appreciate the splendid job he has done :) I guess to complete a PhD you do need to write a thesis and I am no exception. So, Yes, I very well know "You need to cite references" :)
another interesting source for variable hoisting :stackoverflow.com/questions/336859/javascript-function-declaration-syntax-var-fn-function-vs-function-fn?rq=1#answer-34995357
Hasgeek launched in 2010. It’s been a decade! Join us for a recap of the year.
If Hasgeek made an impact on your personal/professional journey, share your testimonial on: hasgeek.com/hasgeek/10/
If you are a front end developer. This is a must watch for your carrier.
I always come back to this video, concreting my understanding on how JS works behind the scene.
This is awesome. Lot of things in jS now makes sense.
It starts slowly, but the run through at the tenth minute is very good, thhanks a lot
Really awesome explanation. The way i look at javascript is completely changed. Thank you so much.
Got your point : programming is about abstractions but to understand those abstractions one must know the internals. Or as he says it you become chess master once you know the internals 👍 great talk
This is more than just a presentation.. thanks!
This was super !! got the actual idea of closure
Awesome tutorial, very easy to understand the way you describe it
Excellent talk, really explains event Q and why setTimeout should be used with caution.
GDI, this is so useful. No reason to hate javascript once this makes sense!
I just started with Javascript. Great presentation!
Best explanation of JS ever!
This is awesome. Thank you for this great talk.
Hey guys I though this information would help you.
During the memory allocation phase,if you have a variable assignment (var b =3) it will allocate the memory for variable b and set the value of be to be UNDEFINED,a special value in JS.And later during execution phase the assignment actually happens.
There is a misnomer for that, it's called hoisting and it happens only for var, let and const declarations and function declarations, not for expressions. Go through ECMAScript spec, HTML spec, CSS spec and finally open documentations of V8 or Chakra engine, you will find all information there.
In ECMAScript 2015, let bindings are not subject to Variable Hoisting, which means that let declarations do not move to the top of the current execution context.
As far as I know , of "var", "let" and "const" only the variable declaration "var" ( not "let" and "const") is hoisted. This means variable initialization is not hoisted.
@@sebastiankumlin9542 Absolutely correct. Hosiiting is for var and function declaration, not even for let, const, and function expressions. Also, Hoisting takes place at the time of compilation.
At 18:19 he gives an explanation that will help anyone trying to comprehend closures.
I had a really hard time understanding the difference between function scope and closure. I can even understand the formal definition of closure. :D Thanks a lot for this video.
I can understand before coming this video some other mentor are explained clear to me
But this is also. Awesome bro ❤️❤️❤️❤️❤️❤️❤️❤️❤️❤️
I love more on JavaScript
what a great presentation!
Simply nailed it. Awesome.
8:54 why it will skipped? When it is not declared with var keyword it will be taken on global platform example window
This is awesome.
this is a classic, so good!
Excellent talk! Very well explained!
awesome just inspired me to dig in more...
This video is so good!!! I learn a lot of things.
Great. Absolute clarity.
The explanation is very good 👍
Great information and presentation! Thank you!
Amazing talk. Any more like this? Fantastic.
Awesome talk. Actually, Javascript when behaving like that everyone was thinking in the past it is stupid language, but with time we discovered this is the power, flexibility & versatility behind js. The guy who invented js is super genius!
But it was really stupid language when it was invented. It became pretty efficient and productive later. You can thank V8 developers for efficiency for example. And you can find the early language specifications. It had no all these cool things you use now. In fact even ES5 and ES6 has pretty different approach in a development.
Awesome one bud. Thanks for sharing this one!
"programming is about abstractions" ..two minutes later.. "it's very important that you understand the internals"
Because to implement an abstraction one has to understand the internals)
Well explained. Things in JavaScript are bit more clear now.
Very useful information, Thank you.
Simply brilliant
Amazing video. Thanks
Great talk. On second thoughts I realise speaker was talking abut execution of call stack and during that myG at one point holds reference to g() as it moves up.
Btw funny reference to make adder function be on adder is a poisonous snake found in uk/ ( started the king Arthur's war on misunderstanding)
Awesome Presentation
What you mean to say is that Declarations take precedence over Statements and are parsed through first in the 'compilation phase' and then things are put together in the 'execution phase' where statements are brought into play to generate the output? Add to that, variable hiding and forgiving nature of JS, the concept sounds and looks messy. I say that despite the fact that I like JavaScript. Very helpful and highly informative. Thanks a ton.
+Common Yunus - take a look at this which explains it briefly through guided examples: goo.gl/OOuqej
Variable declarations are parsed first during the first run through of your program (hoisting also occurs), then during run time assignments and function calls are made.
+Clifford Fajardo I will and thanks.
Good one Arindam.
Excellent talk, thanks!
I said several times Indians are best in teaching.This is extraordinary staff.thanks a lot dada .
fabulous job... expecting more videos...
Very nice understood a lot today
Awesome❤❤❤
Great talk. Is there a possible" oral typo" myG can't be set equal to g() outside f(z) scope did you mean as is written myG= f(1)??
Wow, what a talk!
when he is talking about function execution, memory gets allocated in the stack for primitive type?
i learnt a lot of things. Before write some code we should know internal things.
what a coincidence! watching this on 23rd September 2021.
which talk was first, this one or the one with "what is the event loop anyway"
Both are different.
"what is the event loop anyway" is from JsConf EU
and this is from JSFOO India
Rishabh Mishra yeah but he uses loupe also the code gave as an example with the scope chain was exactly the same as in another talk very likely in the related videos
Yes you're correct, he lifted Roberts' speech as well, not only the app.
Please look into time duration 29:06 to 29:11 (ruclips.net/video/QyUFheng6J0/видео.htmlm6s). He did have taken the name of Philips Roberts and also have mentioned clearly that the visualization is done by him. To me, that looked like clear reference :)
which IDE was used for this ? can anybody suggest?
Thank for the video :)
Amazing information
amazing talk
Hi @arindam
I have a query declartion "e=1" in f() is unlike b or c, in global scope. Is it the special case?
That's not a declaration, it's an assignment. The declaration should start with var, let, const or function keyword. e=1 is an assignment which will fail in strict mode with Reference error. In non-strict mode, it will look for the variable e in the local scope and if found assign the value 1 to b, or else it will follow the scope chain till Global object. If it reaches Global object and it couldn't find the variable e declared anywhere then it will create a property e of Global object and assign the value 1, like Global.e =1, window.e=1 etc.
Then i guess he made a mistake by putting variable 'e' in the context of function f() instead of the global scope like he did with variable 'c'. Yes? (I am referring to his slides by minute 19:00)
Great talk.
hey guys, I have a problem about 28:32. Could anyone tell me why adder2's function has a different closure ?? Does it not refer to the same function?? Or I miss something??
It does hold the same code block. But an entirely new closure will be created for adder2 and the memory allocation references will be in adder2's closure. Which is why we dont see a mixup happening with adder3.
I think this may be irrelevant for u know after years but will be helpful for someone who is reading comments with same doubt, As Arindam mentioned, ruclips.net/video/QyUFheng6J0/видео.html local execution scope block is created when the method is executed so adder 2 is the holding method which is returned when executing makeAdder(2) whereas adder3 is holding method which is returned when executing makeAdder(3), this means when executing, local scope created for both the adder is different which basically means when u do console.dir(adder2), the scope chain it is pointing will be local execution block of makeAdder(2) and same with adder3, but global scope will be same for both of them, so this becomes like
globalScope
/ \
makeAdder(3) scope makeAdder(2) scope
/ \
adder(3) scope adder(2) scope
something like this
@@sasuke_2145 I'm back. Thank you bro.
Great talk
Omg from today i am going to believe in js
What's his name ?
Thanks :)
You Rock Bro :) Awesome Lecture !!
Quite informative!
Helpful video
Master piece
nice! Thanks.
what he is doing right now?
awesome! Thanks for sharing
awesome,good job
Superb .
I think in the process of explaining compilation, when he says `var x does nothing` , he missed a point called hoisting. JS compiler pulls variables at the top and initializes them with undefined value.
superb
Hmm ... So did Kyle Simpson learn this from Arindam Paul or did Arindam learn from Kyle?
Of course I learnt it from him :)
awesome...awesome
very helpfull
It becomes difficult to follow around 20 mins. But great presentation.
Great video !! but variable naming could've been better
U nailed it
nice video
Awesome content, funny accent. Especially when he pronounces "g" as "z" 😂
awesome can you make this in hindi / urdu?
#JavaScript #scope #closures
ocw.mit.edu/courses/electrical-engineering-and-computer-science/6-001-structure-and-interpretation-of-computer-programs-spring-2005/syllabus/
Isnt 'c' in the local scope of function 'f' and not in global scope...?
Good video otherwise... thank you
At runtime execution phase ,it cannot find reference for c at the current scope, so it looks up at outer scope and does not find it so it creates the definition for the same (runtime execution phase) i.e var c =4 ; since it reached finally at global scope so value for the same is global..
now i get it men
am I the only one who couldn't follow along?
lambda not lamda
wow
Why is variable 'e' not placed in global scope during its first declaration while its similar case 'c' is in global scope?
I will get a dinner party to whoever answers. 🐱
good, sort off
Almost exactly same with this: ruclips.net/video/zRZNb4GDOPI/видео.htmlm29s
From 30:00 onwards, it's blatant plagiarism of Philip Roberts's JSConf EU 2014 seminar, exact wordings. :)
Mr. KS what you said is BS :)
If the concept is same it doesn't matter who says it, it is going to be the same. Of course provided you know the concept and are saying it correct :P
Mr. Arindam Paul was just Amazing !! Please stop BSing and passing your negativity to others :) Have a great day. Bye :)
Had you attended any university or wrote a dissertation or thesis, you would have unquestionably understood what I was alluding to. You need to cite references. First of all, I never said you are incorrect, I just said it was lifted from another person who had put his precious time and effort to create the content for consumption, the least one could do is to pay due credit to that person, needn't be monetarily but just a few words before passing on the content as your own. There is something called conscience. :)
Instead of acknowledging the creator of the content, which btw reeks of negativity and feigned superiority, you are trying to ridicule me for pointing that out. You call yourself "geek"! Rightly so, just read about the etymology of the word, you're a perfect example. :))
Please look into time duration 29:06 to 29:11 (ruclips.net/video/QyUFheng6J0/видео.htmlm6s). He did have taken the name of Philips Roberts and also have mentioned clearly that the visualization is done by him. To me, that looked like clear reference :)
By the way, it is not me giving the lecture :) I am just an audience who really liked Arindam's lecture and felt bad that you were too busy finding a fault which actually is not correct rather than to appreciate the splendid job he has done :)
I guess to complete a PhD you do need to write a thesis and I am no exception. So, Yes, I very well know "You need to cite references" :)
Even he used the same examples in loupe which was used by Philip Roberts. :D :D
totally agree
another interesting source for variable hoisting :stackoverflow.com/questions/336859/javascript-function-declaration-syntax-var-fn-function-vs-function-fn?rq=1#answer-34995357
:) :) :)
an american with Indian accent. hmm weird
very thick indian accent. hard to follow.
Works well for a billion+ people.
Now you know how it feels like to listen to Britain or American or Australian English.
irksome accent :(
Great talk.
which IDE was used for this ? can anybody suggest?
you mean at 26:30? It is just chrome console.