data:image/s3,"s3://crabby-images/0856d/0856d2888a6e3d21abf64526c330a02cfdeb1565" alt=""
data:image/s3,"s3://crabby-images/fa4c3/fa4c3bc5b59c1417b4b2cff4afabbd91cd5c0349" alt="π§βπDo we really need a UI Component Library?"
π§βπDo we really need a UI Component Library?
Crafting a user interface (UI) is a crucial first step in any project. But when it comes to building that UI, the debate around technology stacks can get heated. One key question stands out: Should we leverage a pre-built UI component library?
π§βπ 1. Need a UI component Library or not?
My experience collaborating with talented developers across various projects reveals interesting trends in UI library selection.
π§π§ββοΈ Smaller teams with limited UI specialists often opt for established UI component frameworks like Ant Design or Material UI, or even pre-built themes from Themeforest. These pre-built solutions offer a quicker start and a consistent design foundation.
π§π§ββοΈπ§π§ββοΈπ§ Conversely, teams with strong front-end talent often choose to build their own UI component library. This approach leverages developers' expertise and tailors the UI components specifically to project needs. Often, these custom libraries are built on top of popular CSS frameworks like Bootstrap or Tailwind CSS.
According to my experience, we really need an UI component Library because we do not have enough resources and developers to make a good UI component Library.
π§βπ 2. Completing a UI component is not simple
I'm quite a perfectionist developer when doing to UI/UX. For me, building a UI component for a developer is not easy or simple.
First, you will miss the UX problem if you create components that you think are simple. For example, Tab component, you think that simply creating a component that can generate many tabs is okay, you are wrong because it is not that simple. Because in some cases like responsive, your tab must also be collapsed instead of disappearing. You can refer how Ant Design do this: https://ant.design/components/tabs
Additionally, if you are good at UX, you will know that we should support users using hotkeys, for example [π‘²] or [π‘°] for navigation.
data:image/s3,"s3://crabby-images/b83e5/b83e51a66677bb2f93fb190b089b778bf75ef84d" alt=""
A collapsed tab of Ant Design
If you are a good frontend developer, you should definitely take care of this issue without being asked by the Design team.
A second example is about the Dropdown component, you should always render the dropdown content on the outermost side, in the body tag, not in your component. This is to avoid users using "overflow: hidden" for a wrapper component and losing the dropdown placed in that wrapper component.
And there are so many things I could mention, if you make a UI component yourself, you will definitely have many shortcomings and bugs.
π§βπ 3. You will be outdated
If you regularly follow browser updates like Chrome: https://developer.chrome.com/blog, you will see that there are many new updates over time that help you solve UI problems on your website easier. If you build a UI Library yourself, you better update every day if you don't want to fall behind.
Using an existing library is an advantage because they have a team that can do it every day.
data:image/s3,"s3://crabby-images/23a6c/23a6ca0c2b520de5a10639b02a5e32d684d3d6a1" alt=""
Chrome updates everyday with many new features
π§βπ 4. Document UI component is not easy and time consuming
You need to clearly document the UI component and help the Design team understand if you are doing a project with many participants. There are several ways to document your ui component as Storybook. However, you need to have a few developers willing to do that every time your library is updated.
data:image/s3,"s3://crabby-images/01dc3/01dc3264e20dc61a8bd16f4d546cb02e38296b70" alt=""
Storybook provides a workshop to build UIs in isolation
π§βπ Conclusions
In my experience, if you are building a large project and want to build your own UI Library, you need at least 2 people who are really experienced, have the ability to write good code and have an aesthetic eye. Always available to maintain and update UI Library throughout the project and have a long-term plan to develop / maintain / write tests. In addition, the Design team must always closely follow and support the UI Library writing team to complete it well right from the first bricks.
If you don't have enough resources like I said, use a UI Library and customize it into a high-level library based on the Designs of your project, don't try to build a separate UI Library and it will ruin the whole project. .
Of course there will be difficulties when you use an existing UI component such as: the bundle file is large, difficult to customize, depends on a third party,... However, it is the best choice you can have. when you have few resources on hand and want to create quality products.
Thanks for your reading!
Related Blogs
data:image/s3,"s3://crabby-images/0856d/0856d2888a6e3d21abf64526c330a02cfdeb1565" alt=""
data:image/s3,"s3://crabby-images/5ec40/5ec40b65249cb7588858fad175fb82524915fef1" alt=""
data:image/s3,"s3://crabby-images/5d9d3/5d9d38a499f97214b567ae87f2e3b5c5c5bf3e75" alt=""
data:image/s3,"s3://crabby-images/7b1d8/7b1d88bd685bf8b989c93584fa98d53eda4dc545" alt=""
data:image/s3,"s3://crabby-images/f27dc/f27dc6a1e670ec35d511e3ad6347ccee57061507" alt=""
data:image/s3,"s3://crabby-images/65312/653121ecacf60f7a3985111cc6455e9a0e2aca56" alt=""
data:image/s3,"s3://crabby-images/88873/888733ba145445c5ce3b6d00ec6e0fe0155f8cde" alt=""
data:image/s3,"s3://crabby-images/c0c16/c0c16f401ad66d71e0191c4720734497aefe6b06" alt=""
data:image/s3,"s3://crabby-images/d280d/d280db064f284647032f51394dcb5a376be52e9a" alt=""
data:image/s3,"s3://crabby-images/706b0/706b0cf737814ae6f94c518e7e4ae0f083d9c02e" alt=""
data:image/s3,"s3://crabby-images/defd9/defd99772b914501db4f7771363fdfde07a507b2" alt=""
data:image/s3,"s3://crabby-images/917e1/917e1755c102dc28cb3e763cd9d8dce74ed9b554" alt=""
data:image/s3,"s3://crabby-images/f76a0/f76a0add21c8d12d98b198ab674cb0001d344392" alt=""
data:image/s3,"s3://crabby-images/4f136/4f13638c58b2550d14476d53103521638ab40d09" alt=""
data:image/s3,"s3://crabby-images/dea89/dea89e5ca091c3abbba60b6cd6fe7b461f054e34" alt=""
data:image/s3,"s3://crabby-images/6215d/6215d836d45359f0f4f60c787d63873243115929" alt=""
data:image/s3,"s3://crabby-images/52d05/52d057e8d8c4176e832d565ff57f48727638c216" alt=""