@@Fireship hands down Atom had the most beautiful UI, tho VS Code is light years ahead when it comes to performance and features... to be honest, I still miss the smooth look and feel of Atom (One Dark theme don't fully recreate that), but in nowadays rush you have to go with what's best for productivity...
This course is PERFECT for people with some programming background who need to learn JS quickly. Thank you so much for creating it. Thanks to you I've slowly started to fall in love with JS and I'm using it for more and more of my projects.
Really? I know JS pretty well but this stuff moves too fast and doesn't give anyone time to digest. It's REALLY well done and covers everything right but I'm not sure I'd recommend it
09:40 defining the eatBrain property on the new zombie object itself means that a brand new function is going to be created every time a new zombie is created. Better to set it on the function's prototype property so it is only declared once. Also, that is what happens behind the scenes when you use the class syntactic sugar. Great video!
sorry if i don't get it, but could you give an example of how to achieve that? From my understanding, by "function's prototype" you are referring to the constructor function (Zombie), and i'm having a hard time understanding how to access the prototype from there.
First of all I know the editing for this video probably took forever, especially finding old clips that fit the theme so thank you for that, but also your tutorials (albeit very short and fast) have been very helpful for someone like me who just graduated from a bootcamp( I know...) so thank you for the hard work!
If someone did not understand 8:03 here is a quick explanation, it just means that in case of nested objects, example: let obj = { name: "John", anotherObject: { age: 52, } } -> if we Object.assign({}, ) this object to let say b, although it wont copy the properties of 'obj' through reference, lets call it hard copying, it will copy the properties inside the nested object (anotherObject here) through reference. means, changing the properties of nested objects will change the copied properties of b.
This course is really good. You're explaining topics that are really complicated to understand because it's necessary to see the javascript history and it's hard to do. Thank you!
I think I need to watch this at least 10 times to fully absorb the density of the content. Other videos it is common to speed playback to 1.5X , this is one video where slowing it down can actually be helpful.. refreshingly concise, great job.
I only ever used Javascript to make a small project for school and I mostly disliked the language. This tutorial made me appreciate the language a bit and I am just astounded at how you can make a programming tutorial so fun and interesting. I just have to say thank you and keep doing what you're doing man!
I spent 4 hours parsing/escaping a JSON file, because a particular library kept rejecting it. Then when it finally worked, I used another library. And people say frontend dev is easy :)
Classic one cover almost everything, Thanks 😊. I just wanted to request you for something like if it is possible then please make a video on Symbol in es6 and their use case in real time application like where it's suitable for use and in enterprise application how we can maintain this. Thank you much . Big fan of yours.
How do you make your videos they are so elegent. Your channel content quality is awesome. It looks like vscode editor and probably some emoji extension. What is the font size?
One thing that bothers me is - why can't we have higher order functions, like in arrays, but for objects, since they are basically associative arrays? Having programmed PHP for a while, I'm quite bummed out that we can't use .map(), .filter() and .reduce() on them.
I've always felt the same way - would be super convenient. I assume they are missing because the Object is so fundamental to the language. You can use the `Map` class as an alternative.
For the sake of simplicity, I usually stick with for...in loops - not very happy about it, but also not very disappointed. We can get by, but it doesn't feel right to just go switching paradigms (although I know PHP isn't really a good example of paradigm consistency).
I thought functions inherited from the object prototype and everything you put between its curly braces is a property that gets fed to the JS interpreter when you call that function, or use the parentheses short hand.
Fireship, could you please link me to the sound effect/music that plays from 0:15 to 0:25? That spacey, wide sounding music with some harp plucks? Thanks! (Also this video helped me a lot as a Javascript student)
@@Thatguy-rh5ls What I don't understand is how can you set up functionsgetters/setters inside an object, to me that's the specific definition for a class not a map.
Like: function operation(func, a, b) { console.log(func(a,b)); } function sum(a,b) { return a + b; } operation(sum, 1, 2); This prints 3 and would work for a lot of operations like subtraction or concatenation. It works because we can pass that function as an argument.
So considering this I think having a function as a property would still make it a map even though it's really weird 😅 Also, the classes in JavaScript are apparently not entirely the same as classes in other languages.
Okay, I have a doubt. let web = ''outer'; function foo() { let web = 'inner'; let in = () => console.log(this.web); } } What will the code print? 'outer' or 'inner'?
How about null/undefine checking in objects? You don't want a code that something like this const data = response.data.item ? response.data.item: response.data
Dang you have a lot of knowlage about javascript where did you learn all this I expect that you've probably been working with it for more then 10 years?
Let's just pretend the audio issues in this video were meant to add extra suspense 👻 ¯\_(ツ)_/¯
One question - what is the editor and theme that you use in your videos? Looks like Visual Studio Code with Material theme?
@@vasiovasio VS Code + Atom One Dark + vscode-icons
@@Fireship hands down Atom had the most beautiful UI, tho VS Code is light years ahead when it comes to performance and features... to be honest, I still miss the smooth look and feel of Atom (One Dark theme don't fully recreate that), but in nowadays rush you have to go with what's best for productivity...
another qutestion, how to quick type the emoji string, i had to use the short ctrl+shift+b (Windows) and select one from the list
What plugins do you use to get the squares on the left side and the console.log showing its output on the right?
Let's be honest. There is no better programming content than FireShip. A big thank you! I hope you never stop making videos.
Yeah I just love the format of the videos!
Truer words have never been spoken!
Kkkkkokkokkkokokkokk
@@WTFAnyNameWorks kkokkkkokokokokkok
kkokkkkkkk
This course is PERFECT for people with some programming background who need to learn JS quickly. Thank you so much for creating it. Thanks to you I've slowly started to fall in love with JS and I'm using it for more and more of my projects.
Or for dumb people like me who need to review this over and over
@@FordExplorer-rm6ew 🙃
Really? I know JS pretty well but this stuff moves too fast and doesn't give anyone time to digest. It's REALLY well done and covers everything right but I'm not sure I'd recommend it
09:40 defining the eatBrain property on the new zombie object itself means that a brand new function is going to be created every time a new zombie is created. Better to set it on the function's prototype property so it is only declared once. Also, that is what happens behind the scenes when you use the class syntactic sugar.
Great video!
That is a great point. I've been spoiled by TypeScript for a long time.
duh, it's amazing
sorry if i don't get it, but could you give an example of how to achieve that? From my understanding, by "function's prototype" you are referring to the constructor function (Zombie), and i'm having a hard time understanding how to access the prototype from there.
@@TheCecchino98After having declared and assigned the constructor
👇
Zombie.prototype.eatBrain = function() {};
So, *outside* the constructor.
@@mabdullahsari thank you very much!
I love the blend of high level concepts and basics. It’s not overwhelming, and it’s not too basic. Amazing content
This was very well produced. You Hit a lot of deep CS topics in a digestible high level way. Sharing this with my team!
First of all I know the editing for this video probably took forever, especially finding old clips that fit the theme so thank you for that, but also your tutorials (albeit very short and fast) have been very helpful for someone like me who just graduated from a bootcamp( I know...) so thank you for the hard work!
If someone did not understand 8:03 here is a quick explanation,
it just means that in case of nested objects, example:
let obj = {
name: "John",
anotherObject: { age: 52, }
}
-> if we Object.assign({}, ) this object to let say b, although it wont copy the properties of 'obj' through reference, lets call it hard copying, it will copy the properties inside the nested object (anotherObject here) through reference.
means, changing the properties of nested objects will change the copied properties of b.
This course is really good. You're explaining topics that are really complicated to understand because it's necessary to see the javascript history and it's hard to do. Thank you!
I learned A LOT in this one. This channel is so clutch.
Love how in depth these videos go, I had personally never heard of the object.entries destructuring trick before!
I think I need to watch this at least 10 times to fully absorb the density of the content. Other videos it is common to speed playback to 1.5X , this is one video where slowing it down can actually be helpful.. refreshingly concise, great job.
When I get notification from this channel, I know that I'm getting quality!
I can't believe that it's it's it's juuuuuuuust 10 min I'm like WOW, Thank you so much 💖
this it great. popping sound made me jump though ha
Sorry bout that, YT did not like the audio for some reason
10 min video and hours worth of content. Thank you so much.
You just blew my mind. I've never heard of Bigint before 🤯
Bigint was the highlight of the video!
You and theo are my fav tech content creators
With programming there are a million ways to do something, love it. Great video, learned some new tricks!
As a beginner, I'm so glad I found this channel :D
9:53
const obj = new Zombie("👨💻 Jeff");
🤣🤣🤣
I came from a Python background and finally understand the mysterious rationale of copy and deepcopy of dictionaries. Thank you!
Love it!
Love it!
Love it!
Fast pace for the win mate!
I really love the quality man! Good Work 👌
I like your teaching style . please make more JavaScript video like this one.
OMG Object.entries will make my life easier to deep check an object. Amazing! Thanks man!
But you need to use a polyfill to make it work in IE. It's a new browser thing.
Jeff kudos to you man! You always make learning fun with all these creative jokes. Thanks a lot
I only ever used Javascript to make a small project for school and I mostly disliked the language. This tutorial made me appreciate the language a bit and I am just astounded at how you can make a programming tutorial so fun and interesting. I just have to say thank you and keep doing what you're doing man!
Another amazing technical video about JavaScript
The video I needed to watch .. thanks
This is a really awesome channel period.
thought I was in control of this topic...🤓 thanks for this refresher and sharpening
concise, elegant, and tremendously informative ❤️
The key to getting this video is to pause it, try the shit out in vscode, and go "ohhhh"
And that was perfect scene/phrase to end this!
Still one of the best! 🔥🔥🔥
Covered overall all the concepts 😍
Please do more of these videos! Thanks @Fireship
Thank you for the good content you're making!
I spent 4 hours parsing/escaping a JSON file, because a particular library kept rejecting it. Then when it finally worked, I used another library. And people say frontend dev is easy :)
Classic one cover almost everything, Thanks 😊. I just wanted to request you for something like if it is possible then please make a video on Symbol in es6 and their use case in real time application like where it's suitable for use and in enterprise application how we can maintain this. Thank you much
. Big fan of yours.
Amazing content..
Precious job my dude UwU ♥️
I don't think I've ever laughed while understanding Javascript more intimately at the same time...
Twilight Zone is legit a great show btw...
good one. objects are the origin on JS
You unlock this door with the key of imagination - yep, thanks for providing the door
dude, you are saving my ass rn. Thank you!
Perfect tutorial 👌🏼
Thank you so much!
What's the extension he's using here to print those console.log() ?
Which plugin you are using for getting console log outputs in ide ?
Good video
I second that
I too want to know that....
First time I've actually slowed a video down just go catch all the content haha
That was a great video thanks
4:01 This gives an error that says "Cannot redeclare block-scoped variable 'spider'." and "Cannot redeclare block-scoped variable 'legs'."
Someone seems to be excited for Halloween
Are we an object ?
#Existential101
Or are we a primitive?
@@Fireship we are a wrapper around a primitive
@@moonythm Deep, i like that!
How do you make your videos they are so elegent. Your channel content quality is awesome. It looks like vscode editor and probably some emoji extension. What is the font size?
nice video, as vintage clips try some from the invaders tv serie !
One thing that bothers me is - why can't we have higher order functions, like in arrays, but for objects, since they are basically associative arrays?
Having programmed PHP for a while, I'm quite bummed out that we can't use .map(), .filter() and .reduce() on them.
I've always felt the same way - would be super convenient. I assume they are missing because the Object is so fundamental to the language. You can use the `Map` class as an alternative.
For the sake of simplicity, I usually stick with for...in loops - not very happy about it, but also not very disappointed.
We can get by, but it doesn't feel right to just go switching paradigms (although I know PHP isn't really a good example of paradigm consistency).
tks for the awesome content
Ultra use of object
That was a great video
{ neo: 'I know OOP.' }
Well that escalated quickly...
After watching this especially the last part, I am confused, so can I use function instead of a class? (Currently i dont know class)
So you stopped using Monokai pro ?
Gleasons map, noice!
Hi, whats the extension that you use in VS code that outputs the value from console.log next to it?
Sadly I've been combing multiple videos and comments for the answer to this question.
Quokka.js
The tempo is so fast, I can't even hit pause on time to get some rest and rethink it.
thank you
What text editor are you using? Or what extension you used for those icons between the ' ' ?
nicee. very helpful and very nice intro and music...
btw what's your ide?
Are you just using the "CTRL+Z" throughout the video or its video editing ?
How do you have those cool icons in your code, like the trex and comet?
When I watch fireship tutorials, I feel like there's virus on my phone that puts random short videos in the middle of tutorials.
what vscode plugin is that one that update the result live inside the editor?
Its called Quokka (kwok-ah) - very nifty
Actually all fuctions are methods derived from the primary document object.
I thought functions inherited from the object prototype and everything you put between its curly braces is a property that gets fed to the JS interpreter when you call that function, or use the parentheses short hand.
@@nicholasmaniccia1005 Yes, it´s like that
Fireship, could you please link me to the sound effect/music that plays from 0:15 to 0:25? That spacey, wide sounding music with some harp plucks? Thanks!
(Also this video helped me a lot as a Javascript student)
Are js objects like classes in other languages?
He said it was like maps in other languages. You can create classes with the class keyword.
@@Thatguy-rh5ls What I don't understand is how can you set up functionsgetters/setters inside an object, to me that's the specific definition for a class not a map.
@@TimeoutMegagameplays I think it's because they treat everything like it's an object. Like you can pass functions as an argument in JavaScript.
Like:
function operation(func, a, b)
{
console.log(func(a,b));
}
function sum(a,b)
{
return a + b;
}
operation(sum, 1, 2);
This prints 3 and would work for a lot of operations like subtraction or concatenation. It works because we can pass that function as an argument.
So considering this I think having a function as a property would still make it a map even though it's really weird 😅 Also, the classes in JavaScript are apparently not entirely the same as classes in other languages.
what is the extension that displays the return as a comment on the right side called
Right side wins, sneaky pun ;)
No pun intended ;)
what theme do you use for vs code?
May I know the ending music?
Thanks 🙏
Jeff what are these Emojis you use in your code? doesn't look typical
This is da bomb
In 9:40 shouldn't the method be defined on the prototype?
Okay, I have a doubt.
let web = ''outer';
function foo() {
let web = 'inner';
let in = () =>
console.log(this.web);
}
}
What will the code print? 'outer' or 'inner'?
Inner, but if you do it with arrow function it will print outter
@@lot.bajrami Sorry, I meant to use arrow function over there.
@@lot.bajrami But isn't inner outside of the function and hence global for that function? Why would arrow function print outer?
@@jayanths1221 Because arrow functions have no context, they take their parent's
What is the plugin you are using that logs the console.log() inside of the IDE?
Quokka.js
u know that fireship 10min video is actually 30 min video. It just runs for 10 min.
OMG. I FUCKING LOVE YOUR VIDEOS M8. SO UNDERRATED.
what extension you use to show the result of console.log ??
What theme you are using.?
Fireship is King
Outro Music 🔥, please give me the name.
Seeing destructuring in the for...of loop, was my twilight zone moment.
Whats the outro track dawg?
How about null/undefine checking in objects?
You don't want a code that something like this
const data = response.data.item ? response.data.item: response.data
We should see this null aware operator in future JS, similar to Dart github.com/tc39/proposal-nullish-coalescing
How do you get the emojis in you editor?
what font you are using?
Dang you have a lot of knowlage about javascript where did you learn all this I expect that you've probably been working with it for more then 10 years?