React JS Props and Prop Drilling | Learn ReactJS

Поділитися
Вставка
  • Опубліковано 20 жов 2024

КОМЕНТАРІ • 102

  • @DaveGrayTeachesCode
    @DaveGrayTeachesCode  3 роки тому +8

    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: ua-cam.com/video/EfAl9bwzVZk/v-deo.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 2 роки тому +5

    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!

  • @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.

  • @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!!

  • @fernandosalas4885
    @fernandosalas4885 2 роки тому +1

    The way you teach is outstanding. Thank you so much!

  • @bhuvaneshraj5405
    @bhuvaneshraj5405 9 місяців тому

    wherever whenever i can openly say that this is the best react course ever and this channel has the best content everrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr

  • @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.

  • @ogbonnajamessunday2139
    @ogbonnajamessunday2139 5 місяців тому

    Well explained and easy to understand. Thank you very much Dave

  • @zakariachajia1199
    @zakariachajia1199 5 місяців тому

    this video is a milestone for me i learned alot from it still long way to go to finish this thing already

  • @Brightmdapps
    @Brightmdapps 2 роки тому

    I had not learned of defaultProps before now. Thanks Dave!

  • @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.

  • @sheilakerber3513
    @sheilakerber3513 2 роки тому +2

    Your explanations are amazing. Really grateful!

  • @jamshidtashkent1976
    @jamshidtashkent1976 Рік тому

    Thank you, David Gray! You are a great teacher.

  • @mi5956
    @mi5956 2 роки тому

    You are a king. clean code, made everything simple. thank you

  • @ebesquin
    @ebesquin 2 роки тому +1

    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
    🤓🤓🤓

  • @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!

  • @toonice555
    @toonice555 Рік тому

    Sweet. Never knew about default props!

  • @harag9
    @harag9 Рік тому

    Thanks for breaking this down. 1/2 way through I was hoping you would do that. On the

  • @forshetrial
    @forshetrial 11 місяців тому

    Thank God! I came across with this treasure ❤

  • @grace7671
    @grace7671 2 роки тому

    Best explanation, that really helped, thank you

  • @vivekanand5900
    @vivekanand5900 2 роки тому

    Your explanation is great I really like the way you explain in great details.

  • @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

  • @CTILET
    @CTILET 2 роки тому

    I am now pass drilling. Thanks

  • @kaungchitko7156
    @kaungchitko7156 2 роки тому

    Your accent is really nice and very easy to understand,Thank you sir

  • @RandomGuy-jv4vd
    @RandomGuy-jv4vd 3 роки тому

    very beginner friendly, thank you sir :D

  • @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?

  • @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.

  • @vencer5709
    @vencer5709 2 роки тому

    Thank you sir for your detailed explanation..

  • @masruralam6199
    @masruralam6199 2 роки тому

    really well explanation Sir, Thanks a lot for your nice effort here.

  • @viniciusm.m.7822
    @viniciusm.m.7822 2 роки тому

    Thanks a lot, Dave!
    God bless!
    Forte abraço do Brasil!

  • @salahhasan5547
    @salahhasan5547 2 роки тому +1

    there some think you must to remember it when you import or export the name of function must to start with uppercase letter

  • @ghostpieces2362
    @ghostpieces2362 2 роки тому

    Amazing instruction. Thank you

  • @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

  • @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.)

  • @andrewclarke6916
    @andrewclarke6916 3 роки тому +1

    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 роки тому +1

      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! 🚀

  • @suovincent917
    @suovincent917 3 роки тому

    always the best and thank you for your excellent work

  • @roryquarrier7337
    @roryquarrier7337 2 роки тому

    thanks, helped me a lot

  • @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

  • @ioniangaming
    @ioniangaming Рік тому

    Hello Sir, when i move component to parent state in main page always tell me that the list is empty

  • @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 ":")

  • @MrMike44v
    @MrMike44v Рік тому

    just want to mention , there is no need to write _rafce just rafce is fine

    • @DaveGrayTeachesCode
      @DaveGrayTeachesCode  Рік тому +1

      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.

  • @World_information5568
    @World_information5568 3 роки тому +1

    Thank you 😊 Sir

  • @hardwired66
    @hardwired66 3 роки тому

    detail lesson ❤️❤️

  • @modres2444
    @modres2444 2 роки тому

    i am really like this tuturial , it,s help me

  • @AR-iq5ji
    @AR-iq5ji 3 роки тому

    Love your channel

  • @surendharsmsn327
    @surendharsmsn327 Рік тому

    Is it like passing arguments to the function?

  • @hanszoll4943
    @hanszoll4943 Рік тому

    Thank you

  • @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 😊.

  • @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 роки тому +1

      I think you can pass the property related setState() function to the child and then call it from there

    • @DaveGrayTeachesCode
      @DaveGrayTeachesCode  3 роки тому +2

      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.

  • @ambroseahawo
    @ambroseahawo 3 роки тому

    Wow nice content

  • @anonlegion9096
    @anonlegion9096 2 роки тому +1

    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

  • @TravinskiyVladislav
    @TravinskiyVladislav 2 роки тому

    Top

  • @dawid6026
    @dawid6026 Рік тому

    12:44