一款vue3虚拟瀑布流组件
pnpm add @lhlyu/vue-virtual-waterfall
- 局部引用
import { VirtualWaterfall } from '@lhlyu/vue-virtual-waterfall'
- 全局引用
import VueVirtualWaterfall from '@lhlyu/vue-virtual-waterfall'
app.use(VueVirtualWaterfall)
- 使用
<template>
<VirtualWaterfall :items="items" :calcItemHeight="calcItemHeight">
<template #default="{ item }: { item: ItemOption }">
<div class="card">
<img :src="item.img" />
</div>
</template>
</VirtualWaterfall>
</template>
- 在
Nuxt3
中使用
VirtualWaterfall
组件想要实现虚拟列表,包裹它的容器必须指明固定的高度,滚动事件可以绑定在这个容器上,如果这个组件挂在到body下,同样需要指明body的高度,滚动事件可以绑定在window
上
- 属性
字段 | 类型 | 默认值 | 说明 |
---|---|---|---|
virtual | boolean | true | 是否启用虚拟列表 |
rowKey | string | 'id' | v-for需要用到key |
gap | number | 15 | 每个item之间的间隔 |
padding | number or string | 15 or '15px 15px' | 容器内边距 |
preloadScreenCount | [number, number] |
[0:0] |
预加载屏数量[上面预加载屏数,下面预加载屏数] |
itemMinWidth | number | 220 | 每个item最小宽度 |
maxColumnCount | number | 10 | 允许的最大列数 |
minColumnCount | number | 2 | 允许的最小列数 |
items | any[] | [] | 数据 |
calcItemHeight | (item: any, itemWidth: number) => number |
(item: any, itemWidth: number) => 250 |
计算item高度的方法 |
- 插槽
事件 | 类型 | 说明 |
---|---|---|
default | { item: any, index: number } |
自定义默认内容 |