kbar
react-window
Our great sponsors
kbar | react-window | |
---|---|---|
9 | 38 | |
4,587 | 15,177 | |
- | - | |
5.9 | 4.1 | |
27 days ago | 4 months ago | |
TypeScript | JavaScript | |
MIT License | MIT License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
kbar
-
kbar-svelte-mini - ctrl+k menu for your Svelte website
The nice one I found that could do this is, kbar, and It cool, but I use Svelte not React. Lucky for us Svelte devs, I took on the job to port something similar to Svelte, a package that Is designed to just be plugged and played.
- Why is "cmd/ctrl+k" the hotkey to search on many websites like tailwindcss, github, and vuejs docs?
-
Implementing a Command Palette and Task Timer (part 1)
There are many command palette implementations in JavaScript. Some are used with specific frameworks. For example, kbar is a React component and spotlight is a Laravel component. I wanted one that would work with Vanilla JavaScript. I identified two candidates:
-
Does send email to customers really work on a SaaS business? If not, what’s the best way to ask for feedbacks?
You can either build a command palette yourself from scratch by using Cmdk or Kbar, or go with the SaaS route (e.g Magny) in case you want something readily baked.
-
I made a full-stack portfolio site using Next.js and Tailwind!
I also added a Cmd+K interface to my site to make mouse-less navigation easier. It’s made using kbar and styles using Tailwind CSS. Here is what it looks like -
-
🌈 Building an Animated and Accessible Command Menu in React
With that, there are a few different approaches for adding a command menu to your website: you can use an open source library (like kmenu, cmdk, or kbar), use a proprietary tool such as CommandBar, or build your own. This tutorial focuses on building your own implementation, however you may not need to depending on whether or not you're satisfied with the other options available.
-
25 React component libraries you just might need for your next project!
kbar Fast, portable, and extensible cmd+k interface for your site.
react-window
-
Virtual Scrolling in React: Implementation from scratch and using react-window
As we have seen in the previous section we can implement virtual scrolling from scratch. In this section, we'll discuss a third-party tool called react-window that allows us to implement virtual scrolling in a much easier way.
-
React Virtualisation from scratch
If you have been using React for awhile, you may have heard of the infamous virtualisation library react-window or it's predecessor react-virtualized
-
Top 7 Libraries for Blazingly Fast ReactJS Applications
React Window is used to render long lists. Imagine you have a list of 1,000 items. Only ten are visible simultaneously, but your code tries to render all 1,000 items simultaneously.
-
Is there a perfect virtual list solution in react?
You can try react-window by Brian Vaughn
-
Memoizing table rows in a table that can be filtered
This is what you should look into. (Virtualization)
-
What's you opinion on the new Reddit design ditching React in favor of Lit for mostly performance reasons?
Take a look at react-window. But just my perspective; if you haven't needed to look into what virtualization is, it's probably because you haven't had a need for it yet. The one implication (which you'll see in another comment form me in this thread) is that it removes CTRL+F search functionality for items outside of the "window".
-
5 Tips for Optimizing ReactJS Performance and Building Lightning-Fast Applications
Virtualization can be achieved using third-party libraries like react-window or react-virtualized. These libraries provide a way to render only the visible data and load more data as needed, resulting in faster application performance.
-
Introducing Suspense: APIs to simplify data loading and caching, for use with React Suspense.
Oh, right. I totally forgot to mention that– but the idea of "less rendering" in this case seems less like a Suspense concern and more like a windowing concern. I've written a few libraries for that stuff (react-window and react-virtualized) although there are others that may fit your needs better. Their main focus is limiting what you're rendering to more or less only what's on the screen at any given point. Combine that with memoized filtering and I would imagine you're set.
-
I've built a self-hosted file storage
On the UI it is faster because of the great react-window library - it doesn't render the whole files in the folder at once, only the part you actually see on the screen. That makes scrolling through large directory efficient really fast.
-
how is infinite scroll done nowadays?
Interesting question, although I don't know the definitive way it is handled nowadays. I think looking into the source code of the popular infinite-scroll packages might help like: react-window: https://github.com/bvaughn/react-window virtual: https://github.com/tanstack/virtual
What are some alternatives?
react-virtualized - React components for efficiently rendering large lists and tabular data
react-lazyload - Lazy load your component, image or anything matters the performance.
vue-virtual-scroll-list - ⚡️A vue component support big amount data list with high render performance and efficient.
react-list - :scroll: A versatile infinite scroll React component.
react-infinite
react-select - The Select Component for React.js
react-recycled-scrolling - Simulate normal scrolling by using only fixed number of DOM elements for large lists of items with React Hooks
af-utils - Simple open-source tools that just work (usually fast)
react-input-autosize - Auto-resizing input field for React
aos - Animate on scroll library
react-infinity - A UITableView Inspired list and grid display solution with element culling and smooth animations
@egjs/react-infinitegrid