Skip to content

infinite virtual scroll with react and async iterable. 使用AsyncIterable来加载数据的虚拟化长列表

Notifications You must be signed in to change notification settings

buhichan/react-infinite-virtual-scroll

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

React Infinite Virtual Scroll

demo: github page

Why

There are already many virtualize list libraries out there, but I can't find one that satisfies all these, so I decided to create one myself.

  • Simple: no dependencies other than react
  • Allow dynamic row height
    • But the viewport height must be fixed.
    • Set the viewport height by passing style prop.
  • Utilizing async iterable feature which is awesome.
  • High Performance

How

Important: You Must set a fixed height via style prop for it to work!

import InfiniteVirtualScroll from "react-infinite-virtual-scroll"

function Foo(){
    const [searchText,setSearchText] = useState("")
    const dataSource = useMemo(()=>async function *GetData(){
        let total = Infinity
        let page = 0
        let pageSize = 20
        while(page * pageSize < total){
            const {data,total:remoteTotal} = await fetch("/data",{
                method:"post",
                body:JSON.stringify({
                    page,
                    pageSize:pageSize
                })
            })
            page = page + 1
            total = remoteTotal
            yield data
        }
    },[searchText])

    return <div>
        <InfiniteVirtualScroll dataSource={dataSource} style={{height:"200vh" /** Height Must Not Be "auto" For It To Work */  }}>  
            {(rows)=>{
                return rows.map(row=><div key={row.id}>
                    <ItemDisplayComponent item={item} />
                </div>)
            }}
        </InfiniteVirtualScroll>
    </div>
}

License

Anti996

About

infinite virtual scroll with react and async iterable. 使用AsyncIterable来加载数据的虚拟化长列表

Resources

Stars

Watchers

Forks

Packages

No packages published