Stop Writing Fake React Code

  Рет қаралды 47,397

Jack Herrington

Jack Herrington

Күн бұрын

Пікірлер: 185
@almazingsk8er
@almazingsk8er 2 жыл бұрын
Jack, your videos and also the COMMENTS on your videos are some of the best in the web dev community. The mantra I usually take when watching a KZbin tutorial is, “go to the comments” because often that’s where the real nuggets of wisdom are. With your videos, the comments always seem to supplement what you are saying and it’s all just one big nugget together. You’ve cultivated a great community here, and I get so much value from it. Thanks to you, and to all the commenters.
@punio4
@punio4 2 жыл бұрын
Sadly, once performance takes the priority, this is often the only way to do it. Any libraries that work with DOM animations and handling drawing and user input need to eject from react's "re-render on state change" loop as it just doesn't provide the capabilities required. Tracking mouse movements on a 120hz display in a state means that there is a setState triggered once every 8ms. Dragging nodes with this approach is a recipe for disaster. At one point, even Atom was running React, and they had to eject. Framer Motion, react-spring, virtual scrolling libraries, whiteboard / node based tools, and even many state managers use React simply as "keyframes", while the work being done between them is done outside of React.
@jherr
@jherr 2 жыл бұрын
Yeah, there is definitely a case at the high end for going back to direct DOM access. But that's not where I'm seeing this. I'm seeing this at the starting level where people are taking the skills they learned previously in school and they are applying them to React. Which seems like an obvious thing to do, but is wrong in the most basic cases.
@punio4
@punio4 2 жыл бұрын
@@jherr yep that's definitely the case which you covered. I was trying to be the devil's advocate and bring some nuance:)
@jherr
@jherr 2 жыл бұрын
@@punio4 Nuance away! I always appreciate these awesome comments!
@doc8527
@doc8527 2 жыл бұрын
Animation for frame by frame capture, dragging behaviors should not bind to state except "the end result of those actions" afaik. They belong to uncontrolled components. Fast scrolling usually requires you to implement some sort of debounce functions, this is same for vanilla JavaScript. The main problem is that nowadays many devs are being extremely lazy, they just want to learn one thing, and use the same thing or same library everywhere for the rest of 20 years, with the high salary, yet they refused to accept those new subtle differences, the limitation, and the workaround. Then they blame the tool (React for example) they are using is being lame. That's what scares me.
@DEVDerr
@DEVDerr 2 жыл бұрын
Thank you that you covered this in the right way of "Are you tired of getting all of those HTML elements via JS, directly changing the DOM and keep it in sync with data via triggering the events? And are you tired of massive code duplication and correctly managing IDs in order to not break the logic simply because of changed selectors?. This is why React was created" and not in some technology-hype way, which is popular unfortunetly. I think that in this era of development, React (or any other reactive UI framework/library) became so obvious choice and requirement to know, that beginners have almost no way of understanding all the problems React solves, simply because they didn't have a chance to see how writing reactive UIs looked like some time ago with JQuery days, where you needed to deal with this selectors hell. So giving proper context is always a key for beginners to deeply understand of what React is and what it does and why Thank you Jack again for another awesome video
@jherr
@jherr 2 жыл бұрын
Exactly!!! I totally get that having not gone through the pain that was state-sync with jQuery/etc. it's hard to really understand WHY we use React. And unless you understand WHY React exists, it's easy to misuse it.
@heroe1486
@heroe1486 2 жыл бұрын
Did you encounter people writing React that way except for dealing with vanilla libraries ? That's some madness, nice video as always !
@MrKeepItTrill
@MrKeepItTrill 2 жыл бұрын
I've seen this stuff in real production code.
@thesunabsolute
@thesunabsolute 2 жыл бұрын
I worked on a react on rails app once that had react code like this everywhere. It was like the developers lived in a cave for the last 5 years. I took over the FE department, and re-wrote the entire thing over 2 months. Didn’t even bother refactoring, nuking it into orbit was the only option.
@heroe1486
@heroe1486 2 жыл бұрын
@@thesunabsolute Some managers told them to switch to react because it was the new hot thing and they just executed without even reading the basic docs ?
@sidwebworks9871
@sidwebworks9871 2 жыл бұрын
@@MrKeepItTrill Hello Cje
@MrKeepItTrill
@MrKeepItTrill 2 жыл бұрын
@@sidwebworks9871 hi sid :)
@robwatson826
@robwatson826 2 жыл бұрын
That was totally what my first "React" apps looked like. Before I understood "the react way" I was basically just shoehorning in basic JS to get the job done. Another good intro video!
@AlazTetik
@AlazTetik 2 жыл бұрын
Thank you! Your videos are always inspiring!
@Issvor
@Issvor 2 жыл бұрын
Typically a lot of "bad" examples I see are overblown or something and outright wrong, like no one would actually do it that way. But this is definitely one of the few times where the "obviously bad" example is real, and I've actually seen this in the wild. If people actually wanted to write it this way with the convenience of reusable components, just use a template service like EJS.
@OzzyTheGiant
@OzzyTheGiant 2 жыл бұрын
I've seen bad examples of this not just here but in Vue as well, but usually that's some idiot developer who was creating a WordPress template and thought it would be ok to use direct DOM manipulation because anything goes in WordPress 😒.
@TheVioArtsofficial
@TheVioArtsofficial 2 жыл бұрын
Hey Jack! I have a question about nextjs13. I want to load Server Components inside the app folder dynamically. My prevoius approach was to import all my Components into an array and call them. Now its not possible. You maybe could make a video, how I could render Server components dynamically. Maybe like components=[„comp1“, „comp2“…] loop through this array and render it. But all inside the new nextjs13 folder :D Would be great!!!
@jherr
@jherr 2 жыл бұрын
Why would you do that? We load code dynamically on the client because we want to reduce bundle sizes going out to the client. That's not a concern on the server.
@TheVioArtsofficial
@TheVioArtsofficial 2 жыл бұрын
@@jherr Uhm maybe I have to explain my comment a bit more. We developed our own CMS System which works headless. So I started to work inside the pages directory and used the getServerSideProps function. I thought it should render my page on the server and ships the html to the client and thats it. But I still get a CLS (Column Layout shift). I get these CLS on a Component which is totally free of functions but it seems like thats its still rendered on client. And I dont get why?! Now I have to explain why I load the components into an array. First of all, on our CMS you can build a Page. You have pre built componets which you can add/remove or reorder. So I get the JSON where the app could see how the page is buitl with wich content and so on. Now I thought NextJS13 is my game change and I can deliver REAL Server Reendered pages. I need this server rendered pages cause we need a pagespeed above 95 to be competetive to the seo wars on google :D Sorry for my Bad English I hope u understand my problem and my intentions
@jherr
@jherr 2 жыл бұрын
@@TheVioArtsofficial I'm not understanding 100% but from what I'm getting you get some content from the CMS and pick out a bunch of components to render that content from what you see in that CMS content. Totally cool. What I would do is have a lookup table that has whatever key you are expecting from the CMS and the component that is used to render it. Then you just get the component for that key and use it to render. You don't have to do dynamic imports to do that.
@TheVioArtsofficial
@TheVioArtsofficial 2 жыл бұрын
@@jherr yeah right! When I do this in the pages folder everything is fine. But its still not rendered SSR. Now I thought NextJS13 will do the job with, but its not working :D It feels like you cant import React Server Comps dynamically.
@jherr
@jherr 2 жыл бұрын
@@TheVioArtsofficial Can you be more specific around what "dynamically" means. To me that means `import()` or `require()`. If so, yeah, NextJS 13 is not going to treat that as an RSC.
@lost-prototype
@lost-prototype Жыл бұрын
I want to say "who the hell does this?!" But I'm sure there are people who do.
@Chrosam
@Chrosam 2 жыл бұрын
I recently had to detect clicks outside of a component, there weren't easy options other than having a ref, then a useEffect to create an event listener to check whether the target was the ref (component) or not (outside). If you search for "React detect click outside component" it's the first stackoverflow link. Wondering if there are better solutions.
@jherr
@jherr 2 жыл бұрын
That's certainly a decent use case for using a custom event handler that is not supported by React. This video was about trying to ensure that folks aren't writing and manually wiring event handlers for events that React does cover.
@Manish-fm5iv
@Manish-fm5iv 2 жыл бұрын
Surprised someone wrote that but I guess each dev started their journey from a different place. Thanks for sharing.
@konradlesniak492
@konradlesniak492 2 жыл бұрын
I love your videos so much, cheers from Poland :)
@sergnio
@sergnio 2 жыл бұрын
Great video as always! I'm not the perfect coder by ANY stretch of the imagination though I'm surprised to see many people in the comments saying they used to do this!!
@hamzahmd_
@hamzahmd_ 2 жыл бұрын
Thanks for raising this concern. Great video.
@faizanahmed9304
@faizanahmed9304 2 жыл бұрын
Thank you for this video sir! Your videos always help me to learn React even in-depth.
@djaalabahmed2038
@djaalabahmed2038 2 жыл бұрын
Great Jack , waiting to see more content from you
@macot79
@macot79 2 жыл бұрын
Fantastic video Jack, always enjoy your content.
@barakkath
@barakkath 2 жыл бұрын
How do we extract all hyper links in page which are having external link of site? In this case do we need to have vanilla js for finding tags and manipulate when those are rendered from content apis, please suggest
@jherr
@jherr 2 жыл бұрын
Do you not control the creation of the links? Wherever you create a link just check the URL it's point to and alter it to suit. I would DEFINITELY NOT search across all the links and change them in the portion of the DOM that React controls.
@barakkath
@barakkath 2 жыл бұрын
We dont control the link, just assume entire content will be loaded from content server, At react end, we just sanitize them and feed into component. those link will be populated from content server, we dont alter it, Now i want to have speedbump whenever those links clicked on, can you suggest how we can bring in react way?
@jherr
@jherr 2 жыл бұрын
@@barakkath Before you inject the HTML into the page use regexes to add the speedbumps to the links.
@barakkath
@barakkath 2 жыл бұрын
Awesome suggestion! You are the best!
@Amar11115
@Amar11115 2 жыл бұрын
Learned valuable things here. Thanks!
@devstudies4168
@devstudies4168 2 жыл бұрын
Curiosity: sometimes it's not better write vanillaJS to solve simple task than give it to react and have to handle state Managements and stuff? One example: I found out that was way easier implement a pop-up or alert component with vanillaJs than through react. In react you gonna have to handle global states, memorization... With Vanilla you simply add and remove a block of html out of react block.
@devstudies4168
@devstudies4168 2 жыл бұрын
Just saying cuz I saw people doing all the sorts of things through react nowadays, and some of them it's easier with Vanilla.
@jherr
@jherr 2 жыл бұрын
Fair enough. Sometimes React is way overkill.
@IainSimmons
@IainSimmons 2 жыл бұрын
React is definitely better when you have a more complex application and it owns every part of it. If, on the other hand, you have a simple website with popup window, it's definitely overkill. That being said, you can use React's Portals feature to handle HTML elements outside of the React root, but still have it share the same state (so, use the component wherever you like in your tree, pass props for open/close state, etc, but still have it render and update HTML elsewhere)
@pablomotta___
@pablomotta___ 2 жыл бұрын
Great demonstration of these core concepts of React. Thanks a lot Jack!
@coder_one
@coder_one Жыл бұрын
It's hard to believe that there could be someone who would write such code in React ;D
@xenialxerous2441
@xenialxerous2441 2 жыл бұрын
Hey Jack! This was one of the best videos according to me. Helped me immensely in understanding the fundamentals just by watching it. Thanks a tonne for the great job 👍🏻🙌🏻
@jherr
@jherr 2 жыл бұрын
Thank you. Every video always has some person for whom it really works. And that's why I keep doing this.
@xenialxerous2441
@xenialxerous2441 2 жыл бұрын
@@jherr Yes, I totally agree with you and I truly appreciate your efforts in sharing your knowledge with others. Means a lot, thank you!! 😊
@dog4ik
@dog4ik 2 жыл бұрын
we should use manual event listeners only for document/window?
@jherr
@jherr 2 жыл бұрын
That's a decent rule to live by. If React created the element, React should be the one adding the event listeners. And in the case of document and window, React definitely did not create those.
@joshuaholmes5325
@joshuaholmes5325 2 жыл бұрын
I've switched to writing vanilla component classes in a react / Vue mentality.
@yassinebouchoucha
@yassinebouchoucha 2 жыл бұрын
@1:08 I thought that mixing vanilla-js and react is lvl +99 of expertise 🙃! I see this pattern a lot when trying to work on top of legacy projects/libraries, (PS: I used that while working with Threejs library !)
@jherr
@jherr 2 жыл бұрын
Well, threejs is full on GL stuff, so yeah, you will need to use a lot of DOM/direct stuff with that.
@kustomq
@kustomq 2 жыл бұрын
2 videos in a single week? it really is Christmas
@kasvith
@kasvith 2 жыл бұрын
Yah but onClick setCount seems to have a problem. It should be `setCount((prev) => prev + 1)` instead
@jherr
@jherr 2 жыл бұрын
It actually doesn't matter in this case because the () => setCount(count + 1) closure is created with the current value of count. () => setCount(p => p + 1) is valuable when the callback closure could potentially be stale.
@ThomasBroyer
@ThomasBroyer 2 жыл бұрын
@@jherr In case you have something else on the page that fills the event queue and delays your clicks, you could have such "stale" closure and your multiple clicks will all set the counter to the same value, whereas with the callback version every single click will increment the counter. So as a rule of thumb, always use the callback version if the setter when the next value depends on the previous one.
@jherr
@jherr 2 жыл бұрын
@@ThomasBroyer That's the best argument I've heard for it. Though it seems to me that it would only apply to shared state through context, or a global state manager. In which case I would very much agree with the callback version, or whatever dispatching mechanism your state manager supports.
@ThomasBroyer
@ThomasBroyer 2 жыл бұрын
@@jherr Why would it not apply for this simple counter component? (when used on a page with many more things messing around) As soon as you have some long task blocking the main thread or something firing many events, delaying the click events, there's a risk. The counter component cannot know the page context it'll run in.
@jherr
@jherr 2 жыл бұрын
@@ThomasBroyer Fair. First, I've never actually seen this in production. But I do acknowledge that it is a possibility. That being said, in the circumstance where this is a normal behavior (which would be bad in and of itself) there is a question about what the correct behavior is. If the counter is currently at two, and the user clicks the button, which says "2", and the application is blocking, so the user rage clicks, should it go to "3" when the re-render finally happens, or go to some bigger number they never saw?
@ddikodroid
@ddikodroid 2 жыл бұрын
for the setCount, it's better to write setCount(c => c+1), isn't?
@jherr
@jherr 2 жыл бұрын
Not IMHO. The value of count will be up to date because the callback closure set to onClick is regenerated during ever re-render. So no need to use the callback variant of the state setter. The callback variant is best used when you are calling the state setter within a potentially stale callback function. For example, inside of a useEffect callback that was registered onLoad and isn't re-registered and re-run on every render.
@eballeste
@eballeste 2 жыл бұрын
i was listening to this, sort of as background noise while i did other things, and had to stop what I was doing when I noticed the console log showing up in the IDE next to the line of code!!! I involuntarily started to salivate like a dog that hasn't eaten and was just shown a fat juicy steak.
@jherr
@jherr 2 жыл бұрын
That's Console Ninja. It's great.
@bphil4859
@bphil4859 2 жыл бұрын
hello jack from vietnam, can you show me extention to console.log inline vs code . please !
@jherr
@jherr 2 жыл бұрын
It's called Console Ninja.
@radvas7741
@radvas7741 2 жыл бұрын
Hi Jack. Thank you for the great content as always. Your state management and react content really makes difference for web development community. What do you think about doing video about dependency injection (using react context/provider or some third party libraries) and singletons approach to ensure only one store instance when injecting it?
@jherr
@jherr 2 жыл бұрын
It's just a personal thing, but I'm not big on DI.
@harshilparmar9076
@harshilparmar9076 2 жыл бұрын
POV: I thing it is happening only because as new react developer switching from manual DOM changing mindset to declarative mental modal of React. Sometime I think although React is library we need constraint of framework to build big complex app. So rather build that mental state how react works and go accordingly or use other framework and not to worry at all but there you have to do what framework telling you to do rather than flexible like React. Correct me If I am wrong.
@jherr
@jherr 2 жыл бұрын
If your point is to not work against the framework, and to let the framework work for you, then I completely agree.
@harshilparmar9076
@harshilparmar9076 2 жыл бұрын
@@jherr Yeah that is my point. React has so much to give but it up to us how we are taking it. And at the end no matter what the technology it is, but not following the best practices or standard it is not going to help us at all. 🙌🙌
@anasouardini
@anasouardini 2 жыл бұрын
the title is 100% accurate
@alessandros6487
@alessandros6487 2 жыл бұрын
Hi Jack, whats extension you use for console.log(count) x7 blabla? thanks
@jherr
@jherr 2 жыл бұрын
Console Ninja. You can install it today. They've said they will enable it for alpha in the coming weeks. Frustrating I know. It's super cool.
@codefinity
@codefinity 2 жыл бұрын
Very nice sum up - React is 50% state management and 50% DOM management.
@dexterstm
@dexterstm 2 жыл бұрын
Anyone knows how does Jack's autocomplete seems to know what to write? Is that Github Copilot?
@jherr
@jherr 2 жыл бұрын
It is GitHub Copilot.
@dexterstm
@dexterstm 2 жыл бұрын
Cool thanks 👍🏻
@jcsoftdev
@jcsoftdev 2 жыл бұрын
what is the extension to show the console log result?
@jherr
@jherr 2 жыл бұрын
Console Ninja
@yoda_soda
@yoda_soda 2 жыл бұрын
Hey Jack. I've heard the argument of using vanilla js in places where it's more performant then using react. Any comments/thoughts on that?
@jherr
@jherr 2 жыл бұрын
React is really performant. I think if you get to the point where you have a verifiable performance issue that isn't just a bug, like too many top-level updates that should just be fixed, then maybe you can go to hand tweaking DOM elements using refs. But I've done fast animations using straight React and the perf was fine.
@jherr
@jherr 2 жыл бұрын
You're paying 142Kb to put React onto the page. You should make the effort to get every ounce of out of that 142Kb you can. Or switch to Solid or Svelte, where you don't pay that overhead. But I think putting React on the page and then actively fighting against it regularly is silly.
@BogdanPetru-fw1ti
@BogdanPetru-fw1ti 2 жыл бұрын
I think using HTML is misleading, HTML is just a string/text that it is interpreted by the browser. The result of this is the DOM. React works with the DOM, you tell React what the UI is to be, and React-DOM manipulates the DOM accordingly. That is why the props on primitive components (div, span, h1) are different from HTML attributes. e.g. 'class' attribute, in the DOM is 'className' You can talk about turning it into HTML, but only when you are talking about server-side rendering.
@DragovicZarko
@DragovicZarko 2 жыл бұрын
Hello Jack, first of all thank you for your great videos, keep i going! :) What if we have a specific scenario where we need to create custom hook to catch onScroll event listener on some div container? What to use instead of addEventListener to the passed reference? Maybe create one video regarding that? Thanks!
@jherr
@jherr 2 жыл бұрын
That's of course fine because you are in a custom hook. Just remember to remove the event listener when the ref changes. The point of this video was to make sure that folks who are transitioning from learning DOM development to learning React development don't think they are done when they use React components like templates and do all the rest of the work with the DOM skills they just learned. If they are writing custom hooks then they are well past that level of issue.
@DragovicZarko
@DragovicZarko 2 жыл бұрын
@@jherr thanks for quick response, will use cleanup function. Once again thanks for helpful videos!
@doc8527
@doc8527 2 жыл бұрын
that's the main reason why tons of "react" website on the market are so terrible. There are so many times I saw a react website where every single action will re-render the entire page. Why bother using React if you implemented everything in a traditional MFA(multiple page application)?
@saivivekravi4844
@saivivekravi4844 2 жыл бұрын
Hi console ninja (vs code extension) is not installing it saying error it cannot install and cannot compatible with vscode version 1.58.2 version (please tell the solution how to get it)
@jherr
@jherr 2 жыл бұрын
I'm not affiliated with that company, nor do I do technical support for it. So this sounds like a good question for them. That being said I looked at my VS Code version and it's 1.78.x. So perhaps you should upgrade.
@Kermin00
@Kermin00 2 жыл бұрын
Hi, Jack. I'm currently creating a rich text editor in react for my portfolio, to get my first job. I've found that react don't have solution for handling contentEditable elements with react state init. That's why i was forced to use plain js inside react. What do you think about exceptions like that? Have a nice day :)
@jherr
@jherr 2 жыл бұрын
I think that's fine. If React can't handle it directly then sure, go for it. I'm just trying to make sure that people use React when React can do it.
@DarkShadow00972
@DarkShadow00972 2 жыл бұрын
Hi jack nice video ,one que console ninja is not working when I installed any idea my friend.
@jherr
@jherr 2 жыл бұрын
I don't know man, they still haven't released it. :( Last I heard a couple weeks back it would be going into alpha release soon. I really jumped the gun on that video. Sorry about that. It'll be worth it when it comes out though, I promise!
@DarkShadow00972
@DarkShadow00972 2 жыл бұрын
@@jherr thanx for answering jack.
@Pareshbpatel
@Pareshbpatel 2 жыл бұрын
The underlying mechanics of React, so beautifully explained. Thanks, Jack {2022-12-03}
@oyindadavid254
@oyindadavid254 2 жыл бұрын
@jherr thank you for your very helpful and insightful videos. I am in Nigeira was recently hired as a react engineer by a company in the UK. How do you advice I level up, I'm within junior - intermediate level, I want to become really good and valuable. How do I level up. my react knowledge in general. Thank you
@jherr
@jherr 2 жыл бұрын
I'd watch my Freecodecamp state management video that just came out. It's a really in-depth look into every level of state management in React.
@oyindadavid254
@oyindadavid254 2 жыл бұрын
@@jherr I'll go watch it ASAP and also give you some feedback on what I learnt, what parts also that weren't very clear to me
@knload
@knload 2 жыл бұрын
Question about using ID in jsx. Is it ok to use it in components to implement smooth scroll on a single page ( when not using react router)? Is there a better alternative?
@jherr
@jherr 2 жыл бұрын
If what you need is a reference to an HTML element to scroll it into view use useRef.
@kaushal7able
@kaushal7able Жыл бұрын
Thanks Jack, I liked your video much and your teaching is very good and I learned from you a lot. But react state actually gives a performance issue for large scale app.
@jherr
@jherr Жыл бұрын
I hear this a lot; "This won't work for large scale apps." "This doesn't scale." "How does this scale?" Unless you have specific concerns that you can express in engineering terms I don't take that as a credible reason to actively undermine a framework as shown in this video. I've never seen a performance issue in React that was caused by a fundamental issue in the framework. It has always been the application code that was poorly written. Poorly performing code can be written in any framework, including Solid-JS, Vue, Qwik, etc.
@christopheporteneuvepro
@christopheporteneuvepro 2 жыл бұрын
What are you using for call tracking etc. as in-editor annotations? I use Quokka Pro a lot on my pure-JS explainers but that seems useful on many levels!
@jherr
@jherr 2 жыл бұрын
Maybe Code Ninja?
@christopheporteneuvepro
@christopheporteneuvepro 2 жыл бұрын
@@jherr hey thx for replying! Like at 06:51 (the whole " × 3 ⌛0⌛6" thing), this is done inline in your VS Code by a "Code Ninja" ext? Can't seem to find anything by that name online except a NoCode platform.
@jherr
@jherr 2 жыл бұрын
@@christopheporteneuvepro My bad, Console Ninja marketplace.visualstudio.com/items?itemName=WallabyJs.console-ninja
@christopheporteneuvepro
@christopheporteneuvepro 2 жыл бұрын
@@jherr Got it, thanks! Another tool by Wallaby.js, sort of a slimmed-down version of Quokka. Although Quokka sure could do that too, it would be way too verbose on other lines for this. Incidentally I hadn't quite noticed this was a console.log call, my mind's eye had seen the annotations right next to the useState() call, so it felt React-specific. Thanks anyway, keep up the great work!
@jherr
@jherr 2 жыл бұрын
@@christopheporteneuvepro I kinda get the Quokka comparison. But Quokka means firing up a sheet that isn't integrated into the application and seeing the output there. This shows the output of the running application in place. Which is way better. It also shows runtime errors in place. Which is honestly even cooler. kzbin.info/www/bejne/mJ6udYdjrqxlm6c
@shortkeys73
@shortkeys73 2 жыл бұрын
If someone writes "React" code like this then they clearly haven't done even the simplest of tutorials
@jherr
@jherr 2 жыл бұрын
Yeah, exactly. And not only do they need to do the tutorial, they have to shut off their DOM brain and just stick to the React script entirely.
@golansoffer6538
@golansoffer6538 2 жыл бұрын
I'll disagree with rule #2 I do think you need to pass an id to elements in some scanrios like ur using the name attribute while building forms
@jherr
@jherr 2 жыл бұрын
Sure, when HTML requires an ID for labels or accessibility then sure, I agree as well. Use IDs for CSS or HTML reasons, but not for JavaScript reasons.
@golansoffer6538
@golansoffer6538 2 жыл бұрын
@@jherr Agree, I've used it to managed styling for selected items in collection so I've stored in some state the selected id's and used styled components to wrap each item and accept the "selected" prop and by doing so the item component it self wasn't aware of the selection state (SRP) do you think it's a legit way for using the id attr?
@jherr
@jherr 2 жыл бұрын
@@golansoffer6538 I don't quite follow but it could be cool. I'd love to see it. If you could do a simple codesandbox to demonstrate the approach that would be awesome.
@TheAnton982
@TheAnton982 2 жыл бұрын
should't you use ids on list elements?
@jherr
@jherr 2 жыл бұрын
No, use the key property. React doesn't care about IDs.
@TheAnton982
@TheAnton982 2 жыл бұрын
@@jherr oh yeah, I've mistaken :)
@alterWarOfficial
@alterWarOfficial 2 жыл бұрын
Stop writing fake react code. Use useCallback rather than inlining your callback on line 10 with onClick. You create a new callback each render. Don't do that. Also: use setCount(oldCount => oldCount + 1) as your useCallback function. Beginners....
@景玄-h6q
@景玄-h6q 2 жыл бұрын
hey Jack,What is the name of the plugin for log?😄
@jherr
@jherr 2 жыл бұрын
Console Ninja from Wallaby.
@rfossella
@rfossella 2 жыл бұрын
Thanks for that video. Do have any courses on Udemy?
@jherr
@jherr 2 жыл бұрын
I think I have a very old one on Vue. But nothing recent. Honestly, I'm not a big fan of putting stuff behind pay-walls. I'd rather just get paid by ads and put out the content for free to folks.
@zlackbiro
@zlackbiro 2 жыл бұрын
Lool.. I see this too often... Solving react problems using Vanilla.js. But i am not woried about vanilla code in React, i am woried about people doesnt know vanilla and starting to use React first. Thats one hell of a mess in their brain.
@ipojuca22
@ipojuca22 2 жыл бұрын
To this day I still don't understand why people use the term "vanilla" to refer to native JavaScript.
@jherr
@jherr 2 жыл бұрын
Me neither, but it seems to be an accepted thing.
@spencerkeene
@spencerkeene 2 жыл бұрын
It’s a term commonly used to mean “plain” or “basic” so in this case it means plain JavaScript . The term came from ice cream flavours as vanilla ice cream is so widely popular it is often considered the plain or basic flavour.
@UzairSalim-dy3uz
@UzairSalim-dy3uz 2 жыл бұрын
Your two hours course on freecode camp on hooks took me around two days to digest it amazing content alot of value thanks
@jherr
@jherr 2 жыл бұрын
Well, it took me near two months to develop and produce it, so... that kinda fits. ;)
@vigneshwarrv
@vigneshwarrv 2 жыл бұрын
Hi Jack, I got a doubt again here. How could we add event listener to the html that are not provided in return statement of the component? ( let's say , they are randomly generated ).
@jherr
@jherr 2 жыл бұрын
Can you give an actual realistic practical example?
@vigneshwarrv
@vigneshwarrv 2 жыл бұрын
@@jherr I am doing a project where server fetches the md files from the GitHub and convert them to HTML string and send it to the client and I am trying to embed them either using InnerHTML package or directly setting it as InnerHTML content of existing div tag
@jherr
@jherr 2 жыл бұрын
@@vigneshwarrv For that you should use dangerouslysetinnerhtml reactjs.org/docs/dom-elements.html#dangerouslysetinnerhtml .
@vigneshwarrv
@vigneshwarrv 2 жыл бұрын
@@jherr yeah but again , we can't add event listener to those tags that are set inside dangerously set InnerHTML right sir? So I had to manipulate DOM directly once it has been rendered. Is there any alternative way?
@jherr
@jherr 2 жыл бұрын
@@vigneshwarrv You're right, and in that circumstance it's fine. The point of this video was to make sure that folks are using React properly to manage DOM nodes and event listeners when React has the capacity to do that. That doesn't mean however that there are no circumstances under which you'll need to manage your own event listeners. They just aren't that common.
@Chris-gz4ie
@Chris-gz4ie 2 жыл бұрын
Do you think AI will replace web developers
@jherr
@jherr 2 жыл бұрын
I think it will automate some more mundane tasks, like Copilot. But you'll still need a human to make sure that it is structured and written well. Just like Copilot. Copilot can write some shockingly bad code, that still works, and it takes experience and skill to understand that.
@Chris-gz4ie
@Chris-gz4ie 2 жыл бұрын
@@jherr thanks I would really love it if you mad a video for everyone else on this iv actually spent the last six months learning an am just about to finish my portfolio website
@jherr
@jherr 2 жыл бұрын
@@Chris-gz4ie kzbin.info/www/bejne/bXqQdIxnlpJ9ps0
@dansteryoo
@dansteryoo 2 жыл бұрын
Actually using id's is useful if you need to force rerender a component. Just FYI.
@jherr
@jherr 2 жыл бұрын
Key is better for that.
@dansteryoo
@dansteryoo 2 жыл бұрын
@@jherr OOPS you are correct Jedi Master~!
@ankitpal4580
@ankitpal4580 2 жыл бұрын
Thanks for your valuable lesson
@s3xta13
@s3xta13 2 жыл бұрын
Back to basics ;) nice one.
@avi7278
@avi7278 2 жыл бұрын
You have seen someone doing this?
@jherr
@jherr 2 жыл бұрын
Yep.
@avi7278
@avi7278 2 жыл бұрын
@@jherr oh that poor tortured soul 😬
@muhammadyousufhere
@muhammadyousufhere 2 жыл бұрын
This nope seems like a I've seen somewhere, oh you won't believe, I just finished watching this amazing movie 🍿😃
@victorlongon
@victorlongon 2 жыл бұрын
I guess I have been lucky. Had never seen anything like that in over 5 years. On the other hand I have seen some crazy shit with hooks (since they came out) for sure 😂
@jherr
@jherr 2 жыл бұрын
Oh, that I see all the time. I really should just do a "hooks f-ups" video.
@MikaelBoutin
@MikaelBoutin 2 жыл бұрын
I'm disgusted to know that people use React like this. How can you pass over the state management? It's basically the first thing in every tutorial
@mumbles47455
@mumbles47455 2 жыл бұрын
Yea just use the Shadow DOM people, with a cool name like that why wouldn't you?
@buzzer79
@buzzer79 2 жыл бұрын
fake react code is jsx not tsx...
@spiceydev
@spiceydev 2 жыл бұрын
I just vomited into my own mouth
@mortezatourani7772
@mortezatourani7772 2 жыл бұрын
Oh, my eyes! my eyes! 🙈🙈🙈🙈 I remember some source code I saw that it was using jquery and read the inner state of the component by ref :))))
@jherr
@jherr 2 жыл бұрын
Ooooo, ouch, Yeah, that's not good.
@jonasboardwalker
@jonasboardwalker 2 жыл бұрын
I hardly believe someone uses react this way😅
@quelchx
@quelchx 2 жыл бұрын
Would I hire a developer that codes like this -- nope 😂. Had me dead dunno why.
@jherr
@jherr 2 жыл бұрын
Brad Pitt man. He's the best. Great movie.
@ryanleemartin7758
@ryanleemartin7758 2 жыл бұрын
Wait, you just called React a framework. I thought it was just a view library? This is what I hate about React. It's lying to me about what it is.
@jherr
@jherr 2 жыл бұрын
It's pretty hard to call 142Kb of JS anything other than a "framework". :) But I think if I had to be more objective about it, it was never a pure "view library" since it always managed state. But it really transitioned into a framework, IMHO, when hooks were added. That embedded a state management solution in the library.
@ryanleemartin7758
@ryanleemartin7758 2 жыл бұрын
@@jherr Oh yeah, ha I totally agree. It's just funny how long they played this odd semantic game of "It's not a framework, it's a library". Great content by the way!
@dominikwajchel9281
@dominikwajchel9281 Жыл бұрын
Arent you too old for programming in React?
@jherr
@jherr Жыл бұрын
No.
@tech3425
@tech3425 2 жыл бұрын
Shit. I just wrote this
@shift-happens
@shift-happens 2 жыл бұрын
nice !
@OzzyTheGiant
@OzzyTheGiant 2 жыл бұрын
All React code is fake code
@parlor3115
@parlor3115 2 жыл бұрын
Didn't I absolutely destroy your argument in your other video about how state updates ARE ASYNCHRONOUS? I'm surprised you got back into making react videos after that. You're one that can't be reasoned with. Good luck churning bad videos, I guess.
@jherr
@jherr 2 жыл бұрын
If the state setter is asynchronous then why do we see this effect? ``` const onClick = () => { console.log(`Original count: ${count}`); // Shows "Original count: 0" setCount(count + 1); // Synchronously adds one to the count value stored in the hook data associated with this instance of the component setCount((count) => { console.log(`Updated count: ${count}`); // Shows "Updated count: 1" return count; // A no-op because the value is the same }); } ```
@verysussdev
@verysussdev 2 жыл бұрын
I'm first
@LeandroSehnemHeck
@LeandroSehnemHeck 2 жыл бұрын
LOL, Stop saying what people should do.
@AngelsShareProject
@AngelsShareProject 2 жыл бұрын
Better idea: write vanilla JS and ditch the ancient and bloated React. But thanks for saying "React developer" instead of pretending that people who only know React are "front end developers". I think it's awesome that you admit that devs have to unlearn how the browser really works so that they can speak "React" to Meta's code they've interposed between their code and the browser. Sad, yes. But that's what "React developers" really do. And if you suggest to them that there is a better way, they freak out. They don't know how to program user agent code. That's long gone. They only know React. They don't work on the Web. They work on Meta.
@Zagoorland
@Zagoorland 2 жыл бұрын
I never seen anyone making this mistakes so this video seems quite unnecessary... Pretty obvious stuff.
@jherr
@jherr 2 жыл бұрын
I'm seeing it more often now, and I think it's because these turbo code schools go so fast that people just assume that the should still be using the skills they learned just a couple weeks before they started learning React.
@Zagoorland
@Zagoorland 2 жыл бұрын
@@jherr Woah. I'm surprised by that.
NextJS 13 WARNING: Easy Mistake = Infinite Loops
23:46
Jack Herrington
Рет қаралды 49 М.
The Biggest Mistake Intermediate React Developers Make
18:32
Cosden Solutions
Рет қаралды 37 М.
УЛИЧНЫЕ МУЗЫКАНТЫ В СОЧИ 🤘🏻
0:33
РОК ЗАВОД
Рет қаралды 7 МЛН
БОЙКАЛАР| bayGUYS | 27 шығарылым
28:49
bayGUYS
Рет қаралды 1,1 МЛН
JISOO - ‘꽃(FLOWER)’ M/V
3:05
BLACKPINK
Рет қаралды 137 МЛН
React 18's New State Hook You've Never Heard About
22:11
Jack Herrington
Рет қаралды 88 М.
3 React Mistakes, 1 App Killer
14:00
Jack Herrington
Рет қаралды 116 М.
How Senior Programmers ACTUALLY Write Code
13:37
Thriving Technologist
Рет қаралды 1,6 МЛН
I reimplemented REACT SERVER COMPONENTS in ASSEMBLY
20:35
Neo Goose
Рет қаралды 4,9 М.
Stop Doing this as a React Developer
12:27
CoderOne
Рет қаралды 165 М.
UseState: Asynchronous or what?
17:00
Jack Herrington
Рет қаралды 66 М.
How I Write Clean Code in React
16:36
Cosden Solutions
Рет қаралды 33 М.
Dear Game Developers, Stop Messing This Up!
22:19
Jonas Tyroller
Рет қаралды 783 М.
How to Crack Software (Reverse Engineering)
16:16
Eric Parker
Рет қаралды 838 М.
УЛИЧНЫЕ МУЗЫКАНТЫ В СОЧИ 🤘🏻
0:33
РОК ЗАВОД
Рет қаралды 7 МЛН