React JS Props and Prop Drilling | Learn ReactJS

  Рет қаралды 34,557

Dave Gray

Dave Gray

Күн бұрын

Пікірлер: 102
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
Working with props is foundational knowledge for learning React, and sharing data between components in React is often a necessity. The data, which is referred to as props, is passed down from parent components to child components. This is also called "prop drilling". If you are just learning Javascript, I recommend starting with my full 8 hour Javascript tutorial here: kzbin.info/www/bejne/e5eknWyYrN-JkM0
@nikoryu-lungma
@nikoryu-lungma Жыл бұрын
Hi, Mr.Dave. I am currently starting on learning ReactJS, and i am watching your videos. There is one thing I am curious about one thing you said in this video. In this video, you said "Avoid the div when you can", that makes me not understand. Can you explain that why do we need to avoid the div, sir?
@neatunet
@neatunet 2 жыл бұрын
Dave, you're a priceless teacher. In my opinion, it's easy to understand the topic you're explaining because you talk about the tiny details as well, while many others think that beginners should understand the obvious things, which is often not the case. Thank you!
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You're welcome!
@iamtharunraj
@iamtharunraj Жыл бұрын
Dave, I don't know how to thank you. I have been struggling with props. You just helped me get it in just a few minutes. Thank you!
@drivertoursexperience
@drivertoursexperience Жыл бұрын
I'm doing all tutorials you have Dave, very good lesons, i started with Redux when i find your video in the redux website. even already have studed React there´s always something to learn, thanks for sharing this axcelent material.
@faisalejaz3893
@faisalejaz3893 Жыл бұрын
Dave your teaching method is awsome.
@AIcompany1
@AIcompany1 Жыл бұрын
This is one of most important lessons in React, that flow was no sense till now... Thank you a lot my friend, you r epic teacher!!
@DaveGrayTeachesCode
@DaveGrayTeachesCode Жыл бұрын
Glad it helped!
@ogbonnajamessunday2139
@ogbonnajamessunday2139 5 ай бұрын
Well explained and easy to understand. Thank you very much Dave
@harag9
@harag9 Жыл бұрын
Thanks for breaking this down. 1/2 way through I was hoping you would do that. On the
@fernandosalas4885
@fernandosalas4885 2 жыл бұрын
The way you teach is outstanding. Thank you so much!
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You're welcome! And thank you for the kind words 🙏
@bhuvaneshraj5405
@bhuvaneshraj5405 10 ай бұрын
wherever whenever i can openly say that this is the best react course ever and this channel has the best content everrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr
@Brightmdapps
@Brightmdapps 2 жыл бұрын
I had not learned of defaultProps before now. Thanks Dave!
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You're welcome, Michael! 🚀
@zakariachajia1199
@zakariachajia1199 6 ай бұрын
this video is a milestone for me i learned alot from it still long way to go to finish this thing already
@shakirraza1423
@shakirraza1423 Жыл бұрын
Bro very well done , You did a excellent job. Really you can't imagine that i could never seen any tutorial same as yours in the past one and half year.
@DaveGrayTeachesCode
@DaveGrayTeachesCode Жыл бұрын
Thank you so much 😀
@ebesquin
@ebesquin 2 жыл бұрын
Dear Dave It is a wonderful course. A clear, simple and complete presentation of React I'm definitely getting a lot out of it. Thank you very very much 🤓🤓🤓
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
Glad it was helpful!
@konstantinospascal1892
@konstantinospascal1892 3 жыл бұрын
I remember feeling like React is so messy and confusing at first, but that was because my code was unorganized and written really badly. I now find it so beautiful and quick to create things with, haha. Creating and managing components is addictive!
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
I agree! Much more to come in this series, too. 🚀
@mi5956
@mi5956 2 жыл бұрын
You are a king. clean code, made everything simple. thank you
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
Thank you for the kind words! 🙏💯
@jamshidtashkent1976
@jamshidtashkent1976 Жыл бұрын
Thank you, David Gray! You are a great teacher.
@DaveGrayTeachesCode
@DaveGrayTeachesCode Жыл бұрын
You're welcome!
@toonice555
@toonice555 Жыл бұрын
Sweet. Never knew about default props!
@toonice555
@toonice555 Жыл бұрын
Great video! I'd love to know why you chose to use an icon with roles and aria labels rather than wrapping the icon in a element? Wouldn't that solve all the accessibility issues and also keep the HTML semantic? Thanks again
@pranjalruhela1103
@pranjalruhela1103 5 ай бұрын
nice qquestion . did you fnid out why?
@sheilakerber3513
@sheilakerber3513 2 жыл бұрын
Your explanations are amazing. Really grateful!
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You're welcome, Sheila! 🙏
@vivekanand5900
@vivekanand5900 2 жыл бұрын
Your explanation is great I really like the way you explain in great details.
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
Thank you very much! 🙏
@forshetrial
@forshetrial Жыл бұрын
Thank God! I came across with this treasure ❤
@CTILET
@CTILET 2 жыл бұрын
I am now pass drilling. Thanks
@ecbytes
@ecbytes 2 жыл бұрын
Incredibly helpful! Thank you, Dave! I loved the "aria-label" tip for accessibility. Do you have a video on accessibility features for webapps / webpages?
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You're welcome! 💯 I'd like to but I haven't yet. 🚀
@kaungchitko7156
@kaungchitko7156 2 жыл бұрын
Your accent is really nice and very easy to understand,Thank you sir
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You are most welcome! 🙏
@grace7671
@grace7671 2 жыл бұрын
Best explanation, that really helped, thank you
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You're welcome! 🙏
@RandomGuy-jv4vd
@RandomGuy-jv4vd 3 жыл бұрын
very beginner friendly, thank you sir :D
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
You're welcome! 🚀
@andrewclarke6916
@andrewclarke6916 3 жыл бұрын
Very well explained. Much easier too to deconstruct your props in child components rather than continually referring to the props object and its contents directly in code. I notice that if you delete the item key in the LineItem component itself the app still works ok with no errors. We pass the key (the item id) down as a prop from the ItemList component but it seems we don't need to refer to it in the LineItem child component. Was this just left in by accident?
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
You are correct! I actually quickly address this in the setup of the next tutorial. You can remove it from the li element. I missed that when pasting into the new component. Another great question Andrew! 🚀
@Retrohertz
@Retrohertz 3 жыл бұрын
Now I understand why they say it's useful to learn vanilla JS before learning libraries. If I'd not spent years learning JS, all this would make no sense at all. React is really JavaScript under the hood. The syntax is simply designed to make building apps with the same or similar components easier. Case in point -> the props drilling wasn't making sense to me. The syntax in App.js looked like HTML (e.g. ). It was only when I used 'typeof props' in the console, that I realised App.js was actually sending an object to 'Content.js'. The Object destructuring using the { } then made sense. Thanks Dave for helping me better understand all this.
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
You're welcome! I'm glad it is making sense! 💯
@salahhasan5547
@salahhasan5547 2 жыл бұрын
there some think you must to remember it when you import or export the name of function must to start with uppercase letter
@JesseTrammell
@JesseTrammell Жыл бұрын
When I first started learning react this type of injection really bothered me about react. I definitely prefer using state management tool like mobx (not everyones favorite, I know, but it works well for the projects I use.)
@masruralam6199
@masruralam6199 2 жыл бұрын
really well explanation Sir, Thanks a lot for your nice effort here.
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You are most welcome! 🙏
@vencer5709
@vencer5709 2 жыл бұрын
Thank you sir for your detailed explanation..
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You're welcome! 💯
@viniciusm.m.7822
@viniciusm.m.7822 2 жыл бұрын
Thanks a lot, Dave! God bless! Forte abraço do Brasil!
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You're welcome, Vinicius! 💯
@TruthSeeker23-m4o
@TruthSeeker23-m4o 2 жыл бұрын
Hello Dave what is tabindex 0 means? Also you are one of the True Guru when it comes to Teaching. Appriciate your efforts.
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
Thank you, Lavy! 🙏 I often put a tabindex="0" on an element that would not usually get the focus when you tab through the page, but I want it to. Most form elements like inputs and buttons already get focus when tabbing without this. More here: developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex
@roryquarrier7337
@roryquarrier7337 2 жыл бұрын
thanks, helped me a lot
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
Glad it helped!
@suovincent917
@suovincent917 3 жыл бұрын
always the best and thank you for your excellent work
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
You're welcome and thank you for the kind words. 💯🙏
@ghostpieces2362
@ghostpieces2362 2 жыл бұрын
Amazing instruction. Thank you
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
You're welcome! 🚀
@ioniangaming
@ioniangaming Жыл бұрын
Hello Sir, when i move component to parent state in main page always tell me that the list is empty
@salmantech6992
@salmantech6992 Жыл бұрын
sir this playlist is great but make complete Project in current playlist so that students who learnt from the beginners playlist will gain more knowlege after developing entire application from scratch
@DaveGrayTeachesCode
@DaveGrayTeachesCode Жыл бұрын
There is a project in this playlist. Keep going! 🚀
@modres2444
@modres2444 2 жыл бұрын
i am really like this tuturial , it,s help me
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
Glad to hear that! 🚀
@modres2444
@modres2444 2 жыл бұрын
@@DaveGrayTeachesCode 😍
@World_information5568
@World_information5568 3 жыл бұрын
Thank you 😊 Sir
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
You're welcome! 🙏
@jalaleddinebellouchi6317
@jalaleddinebellouchi6317 2 жыл бұрын
I had to do : style={(item.checked) ? {textDecoration : 'line-through'}:{textDecoration : 'inherit'}} I see you not using the ':' in your code, for me it results in an error (statement expected ":")
@MrMike44v
@MrMike44v Жыл бұрын
just want to mention , there is no need to write _rafce just rafce is fine
@DaveGrayTeachesCode
@DaveGrayTeachesCode Жыл бұрын
When I made this video, I needed to do that.. the extension was updated and I have changed a setting or two since. I do just type rafce in the file these days.
@hardwired66
@hardwired66 3 жыл бұрын
detail lesson ❤️❤️
@nica1
@nica1 2 жыл бұрын
I'm not sure if I understand the hierarchy properly. Is the reusable component, LineItem a child of ItemList? Also, is ItemList is a child of the content component? Thank you for another great tutorial, Dave!
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
I'm going by memory here, but I think LineItem is a child component of ItemList. ItemList should contain 1 or more LineItems. I don't specifically remember a "content" component, but overall there is a hierarchy. A parent component like App.js can contain many child components - and those child components can have child components of their own, too.
@nica1
@nica1 2 жыл бұрын
@@DaveGrayTeachesCode thank you, Dave. Makes sense 😊.
@surendharsmsn327
@surendharsmsn327 Жыл бұрын
Is it like passing arguments to the function?
@DaveGrayTeachesCode
@DaveGrayTeachesCode Жыл бұрын
There are similarities.
@hanszoll4943
@hanszoll4943 Жыл бұрын
Thank you
@DaveGrayTeachesCode
@DaveGrayTeachesCode Жыл бұрын
You're welcome!
@AR-iq5ji
@AR-iq5ji 3 жыл бұрын
Love your channel
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
Thank you! 🙏
@andrewclarke6916
@andrewclarke6916 3 жыл бұрын
So you can pass data down to a child component using props. So what do you do if you want to pass data in the opposite direction, from a child component to a parent component?
@ahmad-murery
@ahmad-murery 3 жыл бұрын
I think you can pass the property related setState() function to the child and then call it from there
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
Ahmad is correct about setState. We will also be learning about other state management options like useContext. Great question! 💯
@andrewclarke6916
@andrewclarke6916 3 жыл бұрын
@@DaveGrayTeachesCode Just found out how to do this by passing a pointer to a function down from the parent to the child component as a prop. I can understand why you'd want to use the Context API or even Redux though as a central store of data if you've got multiple nested components. Passing data up and down between multiple components can quickly start to get messy.
@TruthSeeker23-m4o
@TruthSeeker23-m4o 2 жыл бұрын
what is the purpose of aria-label={`Delete ${itemlist.item}`} code was already working the same.
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
Lavesh, I recommend Googling "mdn aria-label" to learn about the importance of this attribute.
@anandprakash7337
@anandprakash7337 2 жыл бұрын
Hello Dave, I have a question...I chose not to move the two handleCheck and handleDelete functions to App.js and got some cryptic error....am I correct to conclude that javascript functions can't access props' data only jsx can (items and setItems are required for javascript functions)
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
I think I understand your question. Props are passed into components. Functional components are functions. Within the function component, if you define a function, it should have access to the props that are passed in. It is not limited to JSX only.
@anandprakash7337
@anandprakash7337 2 жыл бұрын
@@DaveGrayTeachesCode Thank You Dave, I tried it again but getting error "Uncaught TypeError: Cannot read properties of undefined (reading 'length')" ........maybe I will comeback to it later ,right now I don't even know what am I doing wrong and how to explain it......Thanks again
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
@@anandprakash7337 I believe if you go to the next lesson you will find your answer for the current problem. It is trying to read the link of an array, but the array doesn't exist right now.
@anonlegion9096
@anonlegion9096 2 жыл бұрын
Line item? You mean list item?
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 жыл бұрын
Likely because HTML has a list item element. Not perfect here, just striving for progress 💯
@anonlegion9096
@anonlegion9096 2 жыл бұрын
@@DaveGrayTeachesCode just clarifying brother! I love your content! You have a way of explaining that makes learning recreational. Keep it up
@ambroseahawo
@ambroseahawo 3 жыл бұрын
Wow nice content
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 жыл бұрын
Thank you! 🙏
@dawid6026
@dawid6026 Жыл бұрын
12:44
@TravinskiyVladislav
@TravinskiyVladislav 2 жыл бұрын
Top
React JS Forms | Controlled Inputs | Learn ReactJS
37:32
Dave Gray
Рет қаралды 37 М.
React JS Lists and Keys | Learn ReactJS
32:54
Dave Gray
Рет қаралды 38 М.
МЕНЯ УКУСИЛ ПАУК #shorts
00:23
Паша Осадчий
Рет қаралды 3,5 МЛН
小路飞还不知道他把路飞给擦没有了 #路飞#海贼王
00:32
路飞与唐舞桐
Рет қаралды 79 МЛН
State Managers Are Making Your Code Worse In React
13:33
Web Dev Simplified
Рет қаралды 199 М.
Props from Child to Parent Component (Hack)
8:09
Code with Ania Kubów
Рет қаралды 122 М.
React JS Code Challenge | React Beginner Project
25:48
Dave Gray
Рет қаралды 21 М.
React Props are Easy
18:05
Sam Meech-Ward
Рет қаралды 10 М.
Compound Components in React (Design Patterns)
18:21
Cosden Solutions
Рет қаралды 45 М.
Props and Prop Drilling - React In Depth
49:29
Tech with Nader
Рет қаралды 2,1 М.
What is Prop Drilling in React? (And how to prevent it)
12:44
PedroTech
Рет қаралды 22 М.
Using Composition in React to Avoid "Prop Drilling"
15:42
React Training
Рет қаралды 87 М.
МЕНЯ УКУСИЛ ПАУК #shorts
00:23
Паша Осадчий
Рет қаралды 3,5 МЛН