When should you refactor larger React components into smaller ones

  Рет қаралды 15,703

Web Dev Cody

Web Dev Cody

Күн бұрын

Пікірлер: 42
@thydevdom
@thydevdom 2 жыл бұрын
This has become my favorite channel as someone building their first larger project.
@kaloianangelkov4919
@kaloianangelkov4919 2 жыл бұрын
Same here
@NathanBudd
@NathanBudd 2 жыл бұрын
This is very apt, as I was working on a component that felt too big today, so I decided to re-factor in a similar vein to what you've done here. Nice video and some good food for thought.
@Evikeuklavier
@Evikeuklavier 2 жыл бұрын
In these scenarios I like to make a sub components directory in the directory of the component that needs these components that aren’t really reusable somewhere else. Header directory would have another components folder where you put these logged in, logged out links components, etc. works for us :)
@WebDevCody
@WebDevCody 2 жыл бұрын
Yeah I could see having a sub components directory if it helps label what is a private component vs public component
@s8x.
@s8x. 9 ай бұрын
man i wish there were more types of these videos instead of full on website clones. this is way more helpful for escaping tutorial hell and doing things on my own
@alexjones420
@alexjones420 2 жыл бұрын
I have been a developer for just over a year and mainly focusing on FE & react and this has been one of my biggest question. I’ve been going by a ~150 lines of code max for a component as a rule of thumb. Definitely not set in stone but once I have a file that size I know to start looking for ways to break up the jsx into separate components or any business logic that can be extracted as a util or custom hook etc.
@WebDevCody
@WebDevCody 2 жыл бұрын
Yeah if the component is too hard to understand or find specific areas of concern, it’s time to split it up
@alexjones420
@alexjones420 2 жыл бұрын
@@WebDevCody yeah exactly. Either for reusability or maintainability
@amankaushik5833
@amankaushik5833 2 жыл бұрын
damn! You continue to impress me with your refactoring! I really admire your thought patterns.... would love to know how you got there as a programmer.
@Alexjemapplesyrup
@Alexjemapplesyrup 2 жыл бұрын
You can probably use headlessUI for your menu thingy, works with tailwind pretty nicely
@WebDevCody
@WebDevCody 2 жыл бұрын
I’ve been checking it out, it have a couple of nice pre made components
@butwhothehellknows
@butwhothehellknows 2 жыл бұрын
Good job babe!
@sprioleau
@sprioleau 2 жыл бұрын
I love seeing this support from your wife on so many of your videos. I’m a recent subscriber and have noticed it several time already. It’s great to see. Thanks for your content. It’s nice to see that it is focused more on experienced engineers. I look forward to it each week. Keep going. I’m rooting for you.
@ccanyanwu
@ccanyanwu 2 жыл бұрын
I love your videos a lot. They are real and explanatory. Which vscode theme do you use?
@WebDevCody
@WebDevCody 2 жыл бұрын
Material community high contrast
@ccanyanwu
@ccanyanwu 2 жыл бұрын
@@WebDevCody thank you
@subhasishnath3078
@subhasishnath3078 2 жыл бұрын
What extension are you using to get those next errors on the page? it's so cool.
@WebDevCody
@WebDevCody 2 жыл бұрын
Error lens with tyoescript
@subhasishnath3078
@subhasishnath3078 2 жыл бұрын
@@WebDevCodyThank you. 🙂
@tmraaex9617
@tmraaex9617 2 жыл бұрын
If I want to make a component render on all pages like a navbar and i put it in app.js (next.js) how do i make its state reliably update when i log in and out? I have had this problem for a long time
@WebDevCody
@WebDevCody 2 жыл бұрын
Are you using next auth? If there is no session.data you can hide it
@mazmerox
@mazmerox 2 жыл бұрын
What is the name of the extension that shows warning and errors directly in vscode?
@mahalaxmigandham9542
@mahalaxmigandham9542 2 жыл бұрын
eslint
@IStMl
@IStMl Жыл бұрын
no its error lense eslint is the linter that finds the errors@@mahalaxmigandham9542
@ThanHtutZaw3
@ThanHtutZaw3 2 жыл бұрын
Question For Typescript: When I open other people ts code in vs code and it has a lot of red underlines. Then I restart vs code and that error lines gone away. What is happening to me? I am zero typescript
@alexjones420
@alexjones420 2 жыл бұрын
Just your linter bugging out while it runs the initial parse
@nemanjavucic6653
@nemanjavucic6653 2 жыл бұрын
crtl+shift+p => TS restart server
@Izzat-bj1le
@Izzat-bj1le Жыл бұрын
why not hide components from css instead of conditional rendering?
@Abhi-ow6xe
@Abhi-ow6xe 2 жыл бұрын
What theme are you using ??
@WebDevCody
@WebDevCody 2 жыл бұрын
Material community high contrast
@Abhi-ow6xe
@Abhi-ow6xe 2 жыл бұрын
@@WebDevCody thank you!!
@stanimirdimitrov4913
@stanimirdimitrov4913 2 жыл бұрын
A refactor idea: 1. Make an array of all LoggedInLinks. 2. Construct a type for all of them 3. Map them into an element.
@WebDevCody
@WebDevCody 2 жыл бұрын
That’ll work at well
@CottidaeSEA
@CottidaeSEA 2 жыл бұрын
Regarding the click event stuff you had, wouldn't it be possible to add an invisible div around the entire screen (has to be sticky) which has onClick to close? Not sure how well it'd work due to it possibly intercepting other events, pointer information and such, but it's the most React-like way I can think of to solve that. Maybe some other person has a better solution to it without using event listener on the document. I know of other solutions that also use event listener on the document which are neatly wrapped into a hook, but from what I've understood there are some issues regarding iOS (of course) with that method. I have a burning hatred for iOS, as a side note.
@WebDevCody
@WebDevCody 2 жыл бұрын
That would be a fun thing to checkout. It always seems hacky adding event listeners directly to dom elements
@Sammysapphira
@Sammysapphira Жыл бұрын
This is very hacky and not good. The div would be blocking interaction below it. It's amazing for modals that demand the full user attention, but not a drop-down menu where users often click on other parts of the page without closing the drawer.
@NullViewer
@NullViewer 3 ай бұрын
300 lines.... lol. I just got a legacy project of 18000 line JS files. Having fun. None of linters formatters etc can handle that. 😂
@liquidcode1704
@liquidcode1704 2 жыл бұрын
I love tailwind... hate the pos libraries/packages (whatever u call them) that implement tailwind. You know what they say about wanting something done right
You Are Using useEffect Wrong
14:40
Cosden Solutions
Рет қаралды 37 М.
Why Signals Are Better Than React Hooks
16:30
Web Dev Simplified
Рет қаралды 497 М.
СИНИЙ ИНЕЙ УЖЕ ВЫШЕЛ!❄️
01:01
DO$HIK
Рет қаралды 3,3 МЛН
Леон киллер и Оля Полякова 😹
00:42
Канал Смеха
Рет қаралды 4,7 МЛН
The important things to know about React state and renders
18:33
Web Dev Cody
Рет қаралды 28 М.
A Better Way To Organize Components In Vue
10:10
Program With Erik
Рет қаралды 27 М.
Live refactoring a subscriber's React code
32:32
Web Dev Cody
Рет қаралды 117 М.
Un-Suck Your React Components - Composable & Compound Components
15:47
Refactoring a React Component (Design Patterns)
28:20
Cosden Solutions
Рет қаралды 18 М.
This is the Only Right Way to Write React clean-code - SOLID
18:23
Create Highly Reusable React Components in Minutes with TypeScript
10:35
Josh tried coding
Рет қаралды 40 М.
The Absolute Best Intro to Monads For Software Engineers
15:12
Studying With Alex
Рет қаралды 680 М.
Goodbye, useEffect - David Khourshid
29:59
BeJS
Рет қаралды 505 М.
React is Holding Me Hostage!!! | Prime Reacts
28:44
ThePrimeTime
Рет қаралды 106 М.