当前位置: 首页 > article >正文

Vue3 虚拟列表组件库 virtual-list-vue3 的使用

Vue3 虚拟列表组件库 virtual-list-vue3 的基本使用

分享个人写的一个基于 Vue3 的虚拟列表组件库,欢迎各位来进行使用与给予一些更好的建议😊

概述:该组件组件库用于提供虚拟化列表能力的组件,用于解决展示大量数据渲染时首屏渲染缓慢和滚动卡顿问题

功能:该组件库主要包含 HFixedHeightVirtualListHFlexibleHeightVirtualList 两个组件

  • HFixedHeightVirtualList: - 定高虚拟列表组件,用于列表中每一项 item 的高度都是固定时
  • HFlexibleHeightVirtualList: - 不定高虚拟列表组件,用于列表中的每一项 item 都可能是不一样时

安装: npm i virtual-list-vue3

使用:🔺通过 item 具名插槽插槽,插入对应的 HTML 结构,该插槽也接收一个 { itemData } 属性(itemData 为该项 item 的数据

使用示例

定高虚拟列表示例: - HFixedHeightVirtualList

  • 在这里插入图片描述

  • <script setup lang="ts">
    import { HFixedHeightVirtualList } from 'virtual-list-vue3';
    
    const list = Array.from({ length: 1000 }, (_, i) => i + 1) // -- 1.模拟长列表数据(生产一个长度为1000的数组)
    </script>
    
    <template>
        <!-- 2.传入对应的 list 数据,与对应 item 的定高高度 -->
        <HFxiedHeightVirtualList :list="list" :item-height="40">
            <!-- 3.通过 item 具名插槽传入对应的 item 的 HTML 结构,该插槽会返回该项的 itemData 数据  -->
            <template #item="{ itemData }">
                <div class="item">{{ itemData }}</div>
            </template>
        </HFxiedHeightVirtualList>
    </template>
    
    <style scoped>
    /* 4.基本样式,.item 的高度需要与上面传入的 item-height 配置的一样 */
    .item {
        height: 40px; /* 定高 */
        background-color: orange;
        color: white;
        line-height: 40px;
        text-align: center;
        margin-bottom: 8px;
    }
    </style>
    

不定高虚拟列表示例: - HFlexibleHeightVirtualList

  • 在这里插入图片描述

  • <script setup lang="ts">
    import { HFlexibleHeightVirtualList } from 'virtual-list-vue3';
        
    // -- 1.模拟长列表数据(生产一个长度为1000的,且值为不定数量的文字,为了模拟不定高的情况)
    const list = Array.from({ length: 1000 }, (_, i) => {
        let item = "小"
        if(i === 999) item = "END:"
        for(let i = 0; Math.floor(Math.random() * 200); i++) {
            item += "孔" // -- tip:注意这里不能使用英文来进行模拟,因为html的截断规则是根据单词来的,所以就会导致不会换行(了解)
        }
        return item
    }) 
    
    </script>
    
    <template>
        <!-- 2. 传入对应的列表数据 -->
        <HFlexibleHeightVirtualList :list="list">
            <!-- 3.通过 item 具名插槽传入对应的 item 的 HTML 结构,该插槽会返回该项的 itemData 数据  -->
            <template #item="{ itemData }">
                <div class="item" >{{ itemData }}</div>
            </template>
        </HFlexibleHeightVirtualList>
    </template>
    
    <style scoped>
    /* 4.基本样式: 不定高,根据内容适应高度 */
    .item {
        background-color: orange;
        color: white;
        margin-bottom: 8px;
    }
    </style>
    

Props

属性名说明类型默认值是否必传tip
list列表数据any[]-
width容器的宽度number` / `string“100%”当为 number 时以 px 为单位,当为 string 时,则会直接赋值到容器上
height容器的高度number / string“100vh”当为 number 时以 px 为单位,当为 string 时,则会直接赋值到容器上
bufferCount视区上、下额外展示的 DOM 节点数量(预加载)number6-
hiddenScrollbar是否隐藏滚动条booleanfalse-
reachBottomFn触底回调函数() => void / nullnull-
reachBottomFnDistance滚动到底部触发触底回调的触发距离(距离底部的距离)number50以 px 为单位
triggerBottomFnTime触发触底执行函数的节流时间number400以 ms 为单位

定高列表特有 Props

属性名说明类型默认值是否必传tip
itemHeight列表每一项 item 的高度number-以 px 为单位

不定高列表特有 Props

属性名说明类型默认值是否必传tip
initItemHeight列表 item 的预计高度number40预计高度,尽量要小点,可以多加载,但不能少,防止渲染不全(但也不能太过小,如 3、10…)

Props API

interface VitualListProps<T> {
    list: T[],
    bufferCount?: number
    height?: number | string
    width?: number | string
    hiddenScrollbar?: boolean
    reachBottomFn?: (...props: any[]) => any | null
    reachBottomDistance?: number
    triggerBottomFnTime?: number
}

interface FixedHeightProps<T> extends VitualListProps<T> {
    itemHeight: number
}

interface FlexibleHeightProps<T> extends VitualListProps<T> { 
    initItemHeight?: number
}

http://www.kler.cn/a/395848.html

相关文章:

  • RK3588 C++ 多线程运行
  • redis7.x源码分析:(2) adlist双向链表
  • postgresql.conf与postgresql.auto.conf区别
  • Flutter实现绝对定位学习
  • 基于Spring Boot的在线性格测试系统设计与实现(源码+定制+开发)智能性格测试与用户个性分析平台、在线心理测评系统的开发、性格测试与个性数据管理系统
  • 前端学习八股资料CSS(二)
  • JavaScript 单选框设置选中
  • 第5章-总体设计 5.2 需求转化为规格
  • java中设计模式的使用(持续更新中)
  • Mac解压包安装MongoDB8并设置launchd自启动
  • ‘视’不可挡:OAK相机助力无人机智控飞行!
  • pycharm分支提交操作
  • el-tree 父节点隐藏
  • 电子电气架构 --- 车载48V系统
  • JVM的组成、字节码文件的组成
  • java 随机生成验证码
  • 构建客服知识库:企业效率提升的关键步骤
  • k-近邻算法(K-Nearest Neighbors, KNN)详解:机器学习中的经典算法
  • 丹摩征文 | 图像生成,FLUX.1+ComfyUI部署教程
  • 基于 OpenCV 和 dlib 方法进行视频人脸检测的研究
  • POUF: Prompt-oriented unsupervised fine-tuning for large pre-trained models
  • 【论文阅读】医学SAM适配器:适应医学图像分割的任意分割模型
  • HTML and CSS Support HTML 和 CSS 支持
  • 安装nodejs
  • sslSocketFactory not supported on JDK 9+
  • [前端面试]HTML AND CSS