Тёмный

React JS Props and Prop Drilling | Learn ReactJS 

Dave Gray
Подписаться 337 тыс.
Просмотров 33 тыс.
50% 1

Опубликовано:

 

11 сен 2024

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 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: ru-vid.com/video/%D0%B2%D0%B8%D0%B4%D0%B5%D0%BE-EfAl9bwzVZk.html
@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 Год назад
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 Год назад
You're welcome!
@ogbonnajamessunday2139
@ogbonnajamessunday2139 3 месяца назад
Well explained and easy to understand. Thank you very much Dave
@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!
@faisalejaz3893
@faisalejaz3893 Год назад
Dave your teaching method is awsome.
@zakariachajia1199
@zakariachajia1199 4 месяца назад
this video is a milestone for me i learned alot from it still long way to go to finish this thing already
@jhbndrivedexperience
@jhbndrivedexperience 11 месяцев назад
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.
@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 🙏
@sheilakerber3513
@sheilakerber3513 2 года назад
Your explanations are amazing. Really grateful!
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
You're welcome, Sheila! 🙏
@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!
@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 😀
@bhuvaneshraj5405
@bhuvaneshraj5405 7 месяцев назад
wherever whenever i can openly say that this is the best react course ever and this channel has the best content everrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr
@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!
@Brightmdapps
@Brightmdapps 2 года назад
I had not learned of defaultProps before now. Thanks Dave!
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
You're welcome, Michael! 🚀
@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! 🙏💯
@toonice555
@toonice555 Год назад
Sweet. Never knew about default props!
@forshetrial
@forshetrial 10 месяцев назад
Thank God! I came across with this treasure ❤
@jamshidtashkent1976
@jamshidtashkent1976 Год назад
Thank you, David Gray! You are a great teacher.
@DaveGrayTeachesCode
@DaveGrayTeachesCode Год назад
You're welcome!
@grace7671
@grace7671 2 года назад
Best explanation, that really helped, thank you
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
You're welcome! 🙏
@harag9
@harag9 Год назад
Thanks for breaking this down. 1/2 way through I was hoping you would do that. On the
@vivekanand5900
@vivekanand5900 2 года назад
Your explanation is great I really like the way you explain in great details.
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
Thank you very much! 🙏
@erickcohen1876
@erickcohen1876 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. 🚀
@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 3 месяца назад
nice qquestion . did you fnid out why?
@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
@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! 🚀
@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.)
@roryquarrier7337
@roryquarrier7337 2 года назад
thanks, helped me a lot
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
Glad it helped!
@kaungchitko7156
@kaungchitko7156 2 года назад
Your accent is really nice and very easy to understand,Thank you sir
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
You are most welcome! 🙏
@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. 💯🙏
@CTILET
@CTILET 2 года назад
I am now pass drilling. Thanks
@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! 💯
@RandomGuy-jv4vd
@RandomGuy-jv4vd 3 года назад
very beginner friendly, thank you sir :D
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 года назад
You're welcome! 🚀
@ioniangaming
@ioniangaming 11 месяцев назад
Hello Sir, when i move component to parent state in main page always tell me that the list is empty
@masruralam6199
@masruralam6199 2 года назад
really well explanation Sir, Thanks a lot for your nice effort here.
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
You are most welcome! 🙏
@ghostpieces2362
@ghostpieces2362 2 года назад
Amazing instruction. Thank you
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
You're welcome! 🚀
@vencer5709
@vencer5709 2 года назад
Thank you sir for your detailed explanation..
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
You're welcome! 💯
@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
@jalaleddinebellouchi6317
@jalaleddinebellouchi6317 Год назад
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 ":")
@hardwired89
@hardwired89 3 года назад
detail lesson ❤️❤️
@World_information5568
@World_information5568 3 года назад
Thank you 😊 Sir
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 года назад
You're welcome! 🙏
@AR-iq5ji
@AR-iq5ji 3 года назад
Love your channel
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 года назад
Thank you! 🙏
@modres2444
@modres2444 2 года назад
i am really like this tuturial , it,s help me
@DaveGrayTeachesCode
@DaveGrayTeachesCode 2 года назад
Glad to hear that! 🚀
@modres2444
@modres2444 2 года назад
@@DaveGrayTeachesCode 😍
@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.
@hanszoll4943
@hanszoll4943 Год назад
Thank you
@DaveGrayTeachesCode
@DaveGrayTeachesCode Год назад
You're welcome!
@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 😊.
@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! 🚀
@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.
@surendharsmsn327
@surendharsmsn327 Год назад
Is it like passing arguments to the function?
@DaveGrayTeachesCode
@DaveGrayTeachesCode Год назад
There are similarities.
@TravinskiyVladislav
@TravinskiyVladislav 2 года назад
Top
@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.
@ambroseahawo
@ambroseahawo 3 года назад
Wow nice content
@DaveGrayTeachesCode
@DaveGrayTeachesCode 3 года назад
Thank you! 🙏
@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
@dawid6026
@dawid6026 Год назад
12:44
Далее
React JS Forms | Controlled Inputs | Learn ReactJS
37:32
React useState Hook | Learn ReactJS
12:07
Просмотров 29 тыс.
Мой телеграмм: v1ann
00:14
Просмотров 85 тыс.
А ВЫ ЛЮБИТЕ ШКОЛУ?? #shorts
00:20
Просмотров 1,6 млн
Introducing iPhone 16 | Apple
02:00
Просмотров 4,9 млн
Cursor Is Beating VS Code (...by forking it)
18:00
Просмотров 53 тыс.
React JS Lists and Keys | Learn ReactJS
32:54
Просмотров 36 тыс.
React App Component and JSX | Learning ReactJS
11:49
Просмотров 35 тыс.
Мой телеграмм: v1ann
00:14
Просмотров 85 тыс.