Generics: The most intimidating TypeScript feature

  Рет қаралды 190,021

Matt Pocock

Matt Pocock

Күн бұрын

Пікірлер: 247
@DjokovicAirlines
@DjokovicAirlines 2 жыл бұрын
Matt, you are the Wizard. I can't describe how helpful this video was for me. It's purely golden. Thank you for your work!
@phamtienthinh1795
@phamtienthinh1795 4 ай бұрын
Man, being able to find this channel while learning TypeScript is a true blessing. I'll will alway looking for this channel when having problems with Typescript. Thank you Matt
@Deliverant
@Deliverant 2 жыл бұрын
Please never stop doing these videos, you're my inspiration
@nikostsakas7742
@nikostsakas7742 2 жыл бұрын
The stuff about apis is golden, I recently did a similar thing to stop typing JSON responses as 'any' and it really helped with leveraging Typescript to handle edge cases etc. I haven't used schema validation yet, but seeing how clean the code is, it's really enticing.
@shivamjhaa
@shivamjhaa Жыл бұрын
This is actually really awesome. The light bulb moment for me was "Take generic from inward to outward": as in, generics can be inferred from the arguments passed to a function. This is very poweful
@stonecoldcold2941
@stonecoldcold2941 Жыл бұрын
One of the best videos out there on Typescript Generics!
@emiletremblay1377
@emiletremblay1377 2 жыл бұрын
that's it im sold. Subbing to this gold channel
@concisedeveloper
@concisedeveloper Жыл бұрын
10:07 To get the proper return type of your function, instead of type assertion, you can add it as return type to the function: const typeObjectKeys = (obj:TObj):Array =>{ return Object.keys(obj) } This would result in the perfectly valid error of "Type 'string' is not assignable to type 'never'", since empty arrays can be passed to it. Since keyof keeps the original type but Object.keys returns strings, this can cause runtime errors. The proper implementation would assure that only objects with valid keys can be accepted by the function: const typeObjectKeys = (obj:TObj):Array =>{ return Object.keys(obj) }
@01110100011101110110
@01110100011101110110 3 ай бұрын
Came here to say this ^ "as" is almost never the answer
@eulucascampelo
@eulucascampelo 2 жыл бұрын
14:03 is the better part of this video 😁
@brangtoggez6363
@brangtoggez6363 Жыл бұрын
I love you Matt, free contents that you produced are chef kisses. I am always craving for more.
@ivankudinov4153
@ivankudinov4153 4 ай бұрын
That number 8 tip was, in fact, really good, I didn't understand it before
@TeaBroski
@TeaBroski Жыл бұрын
Thanks for sharing, great tips and I didn't know much about generic types. I just fear huge overheads, especially in the code readability department. When these types of codebases are written in real world scenarios, things turn pretty ugly pretty quickly. And usually, when the wizard who wrote this dark spells on a magic mushroom microdose induced flow state goes for the better paying company, the rest of people is left scrambling in chaos. Sometimes, especially for large companies with mixed teams, it's ok to be a bit verbose and repetitive if it leads to faster handovers and a better overall team experience. That said, we (as the JS community) need to mature towards more advanced design patterns. Was great learning about generic types today, thanks for sharing!
@RmonikMusic
@RmonikMusic Жыл бұрын
In general, you'll mostly see generics, conditional types, the "infer" keyword, etc used in packages to make them as strictly typed but broadly usable as possible. In real-world production code, I would indeed avoid complex types and be more verbose about your typing.
@BlurryBit
@BlurryBit 2 жыл бұрын
The most helpful video I have seen for a while. :) Adding to bookmark for using as a documentation.
@lukadimnik1554
@lukadimnik1554 Жыл бұрын
At 14:00 I laughed so hard. Really good explanation of generics. Good job.
@richards16
@richards16 Жыл бұрын
Yeah right, the guy really likes Generics LOL!
@ori_geva
@ori_geva Жыл бұрын
Hey Matt, your videos are very helpful, you're covering features in TypeScript I needed and didn't know exist. It'd be so great if you could give and example of a scenario before explaining a TS solution, for the more complicated ones. Leaving out inline object types (like { firstName: string, lastName: string } would be nice too just so there's less to process heh.
@nikhilgeorgemathew791
@nikhilgeorgemathew791 Жыл бұрын
best video i have seen in a while on yt. thankyou!
@F4LLEND4RK
@F4LLEND4RK Жыл бұрын
Brilliant video, learnt a lot - I've never really looked into generics before, so, now my Typescript knowledge really has gone up a level.
@artless-soul
@artless-soul 2 жыл бұрын
Thank you Matt for all this great content! May be consider slowing down a bit so we get time to grasp the content and avoid head spinning injury by having to rerun videos/ play at lower speed with robot voice 😀
@bryanngen5572
@bryanngen5572 2 жыл бұрын
I usually don't make comments, but this was a great video. Thank you !
@Ageofzetta
@Ageofzetta Жыл бұрын
Straight to bookmarks. You're an amazing teacher!!
@LucaStasio
@LucaStasio Жыл бұрын
Man, you are the sunshine!
@sandeepreddy6247
@sandeepreddy6247 Жыл бұрын
this is absolute masterclass...
@robwatson826
@robwatson826 Жыл бұрын
I pressed the like button, I got a surge of dopamine 👍. Really interesting video, generics are fun!
@onlywei
@onlywei Жыл бұрын
This video is exactly what I needed! P.S. it’s still really hard for me to get over the fact that non-Chinese people don’t know how to count to 10 on one hand.
@alimoghadam6464
@alimoghadam6464 2 жыл бұрын
I'm in love with that makeZodSafeFetch function! Thank you for this great video!
@i4o
@i4o 2 жыл бұрын
Coincidentally, I just watched your generics video on LWJ and was doing those exercises. This is a great video. Lot of things clicked for me with generics! Thanks Matt!
@andyl.5998
@andyl.5998 2 жыл бұрын
What's LWJ, if I may ask?
@kidussolomon9708
@kidussolomon9708 2 жыл бұрын
@@andyl.5998 Learn With Jason www.youtube.com/@learnwithjason
@aaronmiller1835
@aaronmiller1835 2 жыл бұрын
@@andyl.5998 Learn With Jason, if you haven't found it already
@Praetorsss
@Praetorsss Жыл бұрын
I have the task to write a blog post about generics and you, my lord, have completely saved me in the most important thing to do it, understanding them!
@vaidassiburskis
@vaidassiburskis 2 жыл бұрын
Nice work Matt
@juansereina_
@juansereina_ Жыл бұрын
The more I watch your videos I love TS more! 🧡
@VinitNeogi
@VinitNeogi 2 жыл бұрын
Which extension is it which is giving type hints using "^?"
@dentalfloss1
@dentalfloss1 2 жыл бұрын
Yup I would love to know this also
@hyperprotagonist
@hyperprotagonist 2 жыл бұрын
twoslash-queries vscode extension.
@_timestamp
@_timestamp 2 жыл бұрын
@@nextmaker Thank you for this link :D
@efkastner
@efkastner 2 жыл бұрын
Hah nice, Matt just posted a video about this extension!
@ChillAutos
@ChillAutos 2 жыл бұрын
Chdck his most recdnt video
@luczztem
@luczztem Жыл бұрын
bro this is wonderful you explained it VERY well
@kevduc314
@kevduc314 2 жыл бұрын
Amazing video! Thank you! One question tho, for tip 7 (10:07) wouldn't casting as Array potentially give wrong types (and thus potentially wrong linting) if some of the keys of the object are not defined as strings? Since Object.keys returns strings and even if the key is not a string (e.g. number) it's converted to a string, but `keyof TObj` doesn't convert to string and keeps the original type. In the example, that problem doesn't come up since both the "name" and "age" keys are strings, but for e.g. { name: "John", 42: "whatever value" }, if you later try to do some string-specific operation on `result`, like `result[1].charAt(0)`, the IDE will flag it as something like `Property 'charAt' doesn't exist on type '"name" | 42'`, when that's a perfectly valid thing to do since Object.keys will return the string "42" for the number key 42
@anush8
@anush8 Жыл бұрын
You're right.
@johnsoto7112
@johnsoto7112 Жыл бұрын
Why is it difficult for me to wrap my head around generics..
@chrisjames278
@chrisjames278 2 жыл бұрын
Thanks, Great video! Look forward to going through it in total typescript
@KhalilCodes
@KhalilCodes 9 ай бұрын
Hey Matt, I've been following you on X for sometimes and learned a lot from about TS. And here as well.... Subscribed 😍
@jonatanferenczfi189
@jonatanferenczfi189 2 жыл бұрын
Great video. Not many new things for me. But it's really good to see someone making truly advanced topic videos on TS. Keep it up 🚀
@stiwart83
@stiwart83 Жыл бұрын
Amazing video Matt, thank you so much!
@ChillAutos
@ChillAutos 2 жыл бұрын
This was a brilliant video. You are clearly incredibly knowledgeable in all things typescript so instead of just giving praise I'd offer a tiny bit of criticism, maybe it's worth something too you, maybe not. Ive watched all your videos, some multiple times, and the one thing I notice is that some examples are a little too contrived, or at least it's not clear where I'd ever use a certain tip. Ive been a professional ts dev for about a year, and I'm no where near as good as you are but I really struggle to see the use cases in some of the tips, I'm not saying they don't exist, it's just I can't see them. Your zod example is a perfect example of the type of tips I find most useful, it's clear the real world use case and the example you use is a something we might actually see in our own code bases. Basically I'm saying is love some more real world examples for some of the more complex tips you give. I think part of it is your older videos were quite short which are great for a quick look and you do a great job of explaining how it works clearly, but then the video just ends and I'm left wondering how to apply it somewhere. Overall 9/10, just thought this might be more useful just another clap emoji. Thanks for your videos, looking forward to the next one as always.
@mattpocockuk
@mattpocockuk 2 жыл бұрын
That's interesting! I've heard this criticism before but I consider this video to be a good example of me using real-world examples. Type safe object keys, typing Set, making type-safe fetches, integrating with Zod are all things I've been asked how to do. Which example in particular felt too abstract for you?
@mshamba8066
@mshamba8066 Жыл бұрын
good feedback ≠ criticism
@AlexKozack
@AlexKozack 2 жыл бұрын
How to make type argument required? That createSet() should throw a type error about missed type argument?
@petarkolev6928
@petarkolev6928 Жыл бұрын
Default params in TS o.O Whaaaaaaaaaaaaaat ? Matt, tip after tip and I think you can't amaze me more and there you go :D Matt, you're our hero 🍻
@brandonz404
@brandonz404 Жыл бұрын
This video singlehandedly dissolved my fear of "complicated" typescript. I'm pretty new to it, but now I want to use generics everywhere
@thohangst
@thohangst 2 ай бұрын
I don't know what it is about generics, but they just make my brain shut off. Looking forward to remedying this with this video.
@erikslorenz
@erikslorenz 2 жыл бұрын
Tip 10 is the best one! Just did something similar the other day.
@justingolden21
@justingolden21 Жыл бұрын
This man is on another level! Subbed!
@RevolutionaryUsername
@RevolutionaryUsername Жыл бұрын
7:43 Any difference between doing that and doing extends Function?
@MartynK981
@MartynK981 2 жыл бұрын
@Matt, do you know why in example N8 (getValue function) we need explicitly provide the second generic for the keys - 'TKey extends keyof TObj'? Why the setting of the arg 'key: keyof TObj' is not enough?
@jasonstewart7983
@jasonstewart7983 2 жыл бұрын
I'll attempt to answer in the absence of Matt. The issue is how to get TS to connect the return type with the input type. Since the input type is an object with multiple attributes, each with a different type, we don't want the return type to be a union of all those possible types, we want it to be keyed to the 'key' input arg. Hence we use the 2nd generic and infer the return type. On a deeper level, I'm uncertain "why" this is necessary, why TS didn't have enough information to start with. Which is something for Matt to explain.
@MartynK981
@MartynK981 2 жыл бұрын
@@jasonstewart7983 Thank you
@piano42
@piano42 Жыл бұрын
13:42 From a C# background `TKey extends keyof TObj` makes no sense for me. Why does this describe the `typeof TValue`? I hope I can internalize the solution because I stumble over this problem from time to time and asking myself again and again how the syntax was supposed to be. ^^
@FranciscoLopez-jc6vq
@FranciscoLopez-jc6vq Жыл бұрын
Great video, Matt. Hats off ;)
@learner8084
@learner8084 Жыл бұрын
Thanks very much for the video. This is a real eye opener.
@theaungmyatmoe
@theaungmyatmoe 2 жыл бұрын
I just love final part imo
@christopheanfry
@christopheanfry 2 жыл бұрын
So nice video!! I’m starting with typescript so not sure if I get it well but what I understand is that generics help typescript to infer on the arguments we pass in a function and give the proper return type. So a well defined generic in a function will give a much easier function handling when using it. Sorry if it’s not clear for me just try to understand. Thanks anyway for this video will work on it.
@JulianHarris
@JulianHarris Жыл бұрын
Outstanding. Last time I used generics was C++ and Java in the late 90s probably before most of the other commenters were born😂 and it’s really great to see the inference capabilities to avoid “type stuttering” you otherwise get.
@alexodan
@alexodan 2 жыл бұрын
amazing stuff Matt thanks for those tips🙌 they were really 🔥🔥🔥
@Mitsunee_
@Mitsunee_ 2 жыл бұрын
everytime I try to use keyof in generics I end up with it staying at the union type. Yesterday I was trying to merge all my getBundledFooBar functions into a single util and it just never wanted to work for me. Really confused as to what specifically makes typescript understand when a keyof-based parameter is not the union of all keys.
@bagaskara1567
@bagaskara1567 Жыл бұрын
very clear explanation, amazing
@lamtran6520
@lamtran6520 11 ай бұрын
Question: What is the // ^2 in your code, and why it log the variable all the time ? Is it a plugin or typescript external ?
@joker_j1268
@joker_j1268 11 ай бұрын
Its a VSCode extension. He covered it in this video before: kzbin.info/www/bejne/q2HElX56qpJgmaM
@msich
@msich 2 жыл бұрын
This is awesome Matt 🙌🏻
@4sent4
@4sent4 Жыл бұрын
Default type parameter is actually genious feature
@m_hussain_mustafa
@m_hussain_mustafa 9 ай бұрын
Great video!
@jcubic
@jcubic Жыл бұрын
That was great but you did one mistake in tip 7 you don't need to use "as" in that example if you restrict the type of the object to have keys of type string. Object.keys doesn't return symbols in JavaScript but the keyof does. const typeObjectKeys = ( obj: TObj ): Array => { return Object.keys(obj); };
@eliasmangoro413
@eliasmangoro413 2 жыл бұрын
Nice video! Another tip is you can do generic type inference from a function return type, in the same way you can do it for function parameters
@celica96
@celica96 Жыл бұрын
Many cool pieces of advice. Thank you!
@eldbudd
@eldbudd Жыл бұрын
i wish i'd seen this video like four months ago, when i refactored an entire routing architecture, for which i found myself using what here you will see as tips 1 through 9. Had to learn it the harder way. this video would have really made the learning curve less steep. I
@alpakarosa3678
@alpakarosa3678 2 жыл бұрын
This video makes me love more typescript!
@Noway1252
@Noway1252 2 жыл бұрын
What a wonderful video! I wish I can like it more than once. Thanks a lot Matt
@dan_isaza_dev
@dan_isaza_dev Жыл бұрын
This video was fantastic -- thank you. But I have to say, I think the best part was when I clicked the like button and a bunch of TypeScript knowledge injected itself into my brain
@WaterJay
@WaterJay Жыл бұрын
this video is just immensely helpful
@maxtsh
@maxtsh Жыл бұрын
Love this Matt, thank you so much
@eliasvasques80
@eliasvasques80 Жыл бұрын
Thanks man, very good content.
@skittlznt2611
@skittlznt2611 Жыл бұрын
Thanks for the videos Matt. I can imagine they take a lot to put together. Just something I've noticed, you speak really fast and take almost no breaths between words 😅 then you go from one topic to the next with almost no breaks in-between. For me personally It's really tough to follow because these are kind of complicated topics you are covering. Again, I really appreciate the time and effort you put into your videos. Just a bit of constructive feedback from one viewer. 👌🏾
@mohdsahil226
@mohdsahil226 Жыл бұрын
Really great content! Please provide a Nextjs 14 course. I follow stephen grider, but your way of teaching impressed me. I would like to work for free for you! I want to improve my coding!
@maker_aleks
@maker_aleks Жыл бұрын
Really good explanation! 👍
@jotasenator
@jotasenator Жыл бұрын
let me grab a beer to make my fears go away and jump fully into this, is ok to have fear, but I need to face it
@lasfito
@lasfito 2 жыл бұрын
In example number 6, why do TObj extends Record when a mere Record would've sufficed?
@mattpocockuk
@mattpocockuk 2 жыл бұрын
Because you wouldn't get autocomplete on the key that comes back in the return type
@jainebri
@jainebri 10 ай бұрын
Amazing Matt ... Just Amazing !!! Thanks
@PickleRiiiiiiick
@PickleRiiiiiiick Жыл бұрын
Did you invent Typescript? Lol. Just kidding. I watch your videos all the time. Very enjoyable.
@mervinmarias9283
@mervinmarias9283 Жыл бұрын
This seems like a more powerful form of destructuring, where instead of presetting the initial values, you enforce the types that should be returned.
@eldbudd
@eldbudd Жыл бұрын
what is this addon with ?^ that shows the typing of the consts as they change according to the different types that are fed to the generic type? for example that ^? const result: ...." with the changing types. anybody?
@patricknelson
@patricknelson Жыл бұрын
Like and subscribed. Awesome tips, they proved to be particularly useful for me just to learn.
@joelmturner
@joelmturner 2 жыл бұрын
Excellent tips, thank you!
@muhammadmejanulhaque3305
@muhammadmejanulhaque3305 2 жыл бұрын
I am really glad that I started my javascript journey with Typescript. Thank you so much for the video.
@jeffreysegovia7656
@jeffreysegovia7656 2 жыл бұрын
Thank you Matt!
@oussamabenchkroune3151
@oussamabenchkroune3151 2 жыл бұрын
Thank you for the effort to make this awesome and useful video, Much love
@paulmel4411
@paulmel4411 Жыл бұрын
Clicking "like" because I really need those generics in my brain
@firasnizam
@firasnizam Жыл бұрын
great, direct into the point
@torontodev525
@torontodev525 11 ай бұрын
Legend! thanks mate, the best of the best of the best :) 🙏🏼
@webdev5180
@webdev5180 Жыл бұрын
I love this video so much !
@qodesmith520
@qodesmith520 2 жыл бұрын
Always A+ content. Thanks for this!
@DanielAbernathy
@DanielAbernathy Жыл бұрын
One thing I don't understand - why does TS use inference here: `(obj: TObj, key: TKey)` But not here: `(obj: TObj, key: keyof TObj)` Aren't we essentially providing TS with the same information?
@oduylinh5773
@oduylinh5773 Жыл бұрын
I have the same question. I can't understand why it has this difference
@mpotane
@mpotane Жыл бұрын
probably the return type becomes a union because it split the inner keys in the object itself.
@multigladiator384
@multigladiator384 Жыл бұрын
13:34 nice! this is useful stuff
@EngineerNick
@EngineerNick Жыл бұрын
Thankyou this was super useful :)
@todorvachev891
@todorvachev891 Жыл бұрын
Example 4 I think is not a really good idea, especially if you are working on a team or a big project, might work well for small stuff. The reason is simple, you wouldn't really write addIdToObject( ... ). You would normally have that out in a type or an interface, so it would be more like addIdToObject({ ... }), and now if you are using IdType anywhere else in the code, if you change it, you will get all of the errors that you need. However if you have left the type as inferred, you could simply say pass in an extra argument to the function, or remove an argument, and you would never know that you just broke 50 different things until it gets to production and you get angry clients :)
@criticalthinker88gis13
@criticalthinker88gis13 Жыл бұрын
Superb video
@Abdulrahman-zj8cv
@Abdulrahman-zj8cv Жыл бұрын
Thank you so much man you are great, bless you.
@AlfonsoBlanco-co5ql
@AlfonsoBlanco-co5ql 9 ай бұрын
You are so cool while explaining!!!
@househall
@househall Жыл бұрын
Sometimes `as` is unavoidable indeed, but your example is dangerous. You can easily use it in typed function like `type TA = { a: number }; function getAProps(a: TA) { return typedObjectKeys(a); }` and its result will be typed as `"a"[]` but you could put a value of some type that extends TA as an argument, like `const b = { a: 2, b: 3 }; getAProps(b);` and get `["a", "b"]` result wrongly typed as `"a"[]`.
@rkingham3181
@rkingham3181 Жыл бұрын
hmm... Sorry for my ignorance but re. tip 6 what is the point of and then "let highestKey: keyof TObj" when we can do "function(obj: Record) and then (obviously) "let highestKey: string" - that also takes advantage of Tip 4? Why should we do it the painful way?
@mattpocockuk
@mattpocockuk Жыл бұрын
Because then the highest key would be too loose as a type, and you wouldn't be able to index into the original object with it. Having keyof there means a nicer API for those consuming the function.
@rkingham3181
@rkingham3181 Жыл бұрын
@@mattpocockuk I think I can understand the philosophy, but am I wrong to think that with the Record the "keyof" will have no way to be anything but string anyway? In other words should we sacrifice our knowledge that a particular type 'has to' be - say - string, for the sake of writing a more sophisticated looking code? Thank you for taking the time to reply mate!
@mattpocockuk
@mattpocockuk Жыл бұрын
@@rkingham3181 The point here is that keyof T is _more_ specific than string. I.e. it's a specific set of literals.
@rkingham3181
@rkingham3181 Жыл бұрын
@@mattpocockuk ah... I think I got it now!
@edgeeffect
@edgeeffect Жыл бұрын
I've been thinking there's something "a bit odd" about `Record` and it's finally dawned on me.... I haven't seen a `Record` keyword since I was programming in PASCAL - and TypeScript was designed by ANDERS HEJLSBERG... oh, I see clearly now! And it's just dawned on me that TypeScript is almost an intersection of 2 of my favourite languages ever... ... ... and that also explains why TypeScript loves PascalCase so much. (Sorry for irrelevant drivel but irrelevant drivel is what I do)
@amans6504
@amans6504 2 жыл бұрын
Can you do one with axios? I literally get confused using axios with typescript and make my responses and errors typesafe
@RemotHuman
@RemotHuman 17 күн бұрын
what is that //^ extension?
My favourite VSCode extension has 3k downloads
2:11
Matt Pocock
Рет қаралды 133 М.
TypeScript Generics are EASY once you know this
22:21
ByteGrad
Рет қаралды 148 М.
How Strong Is Tape?
00:24
Stokes Twins
Рет қаралды 96 МЛН
Infer is easier than you think
13:38
Matt Pocock
Рет қаралды 96 М.
as const: the most underrated TypeScript feature
5:38
Matt Pocock
Рет қаралды 129 М.
Writing Code That Runs FAST on a GPU
15:32
Low Level
Рет қаралды 578 М.
Learn TypeScript Generics In 13 Minutes
12:52
Web Dev Simplified
Рет қаралды 301 М.
TypeScript generics или универсальный типы, обобщения
23:51
Михаил Непомнящий
Рет қаралды 35 М.
Enums considered harmful
9:23
Matt Pocock
Рет қаралды 218 М.
The Biggest Mistake Intermediate React Developers Make
18:32
Cosden Solutions
Рет қаралды 50 М.
TypeScript Speedrun: Crash Course for Beginners
23:39
Matt Pocock
Рет қаралды 40 М.