An open API service indexing awesome lists of open source software.

https://github.com/yaxian/vue3-virtualized

Vue3 components for efficiently rendering large, scrollable lists and tabular data
https://github.com/yaxian/vue3-virtualized

virtual-list vue vue3

Last synced: about 2 months ago
JSON representation

Vue3 components for efficiently rendering large, scrollable lists and tabular data

Awesome Lists containing this project

README

          

# vue3-virtualized

It was inspired by [react-window](https://github.com/bvaughn/react-window).

![vue3-virtualized-gif](examples/vue3-virtualized.gif)

### Run example

```
cd examples
yarn install
yarn dev
```

### VariableSizeList

```vue





import { VariableSizeList } from 'vue3-virtualized'

const Row = {
name: 'Row',
props: {
index: {
type: Number
},
rows: {
type: Array,
default: () => ([])
},
},

setup(props) {
return () => {
return (
<div style="border: 1px solid">Row {props.index}</div>
)
}
}
};

const rowHeights = new Array(1000).fill(true).map(() => 25 + Math.round(Math.random() * 50));
const getItemSize = index => rowHeights[index];

export default {
name: 'VariableSizeListDemo',
components: {
VariableSizeList,
Row,
},
data() {
return {
rowHeights,
getItemSize,
}
},
methods: {
handleClickRow(rowData, index) {
console.log(`click row ${index}`)
}
}
}

```