vue3实现虚拟滚动Vue-Virtual-Scroller

前端优化不可不避的一谈之虚拟滚动:众所周知,滚动是直挺挺的往dom树加东西,如果滚太多滚到万级,渲染过多就会卡顿,而vue-virtual-scroll的灵活懒渲染就能解决这个问题

1,下载与配置

复制代码
npm install --save vue-virtual-scroller@next

2,main.ts中配置导入

复制代码
import VueVirtualScroller from 'vue-virtual-scroller'
import 'vue-virtual-scroller/dist/vue-virtual-scroller.css'

app.use(VueVirtualScroller)

3,使用如下:

Arr是自定义的比如一个对象数组,至少含有id,min-item-size是最小的高度默认px单位,key-field会读取posts中的id,列表的长度由posts长度决定,行内style的两个样式是必须有的,高度代表视窗高度,然后设置overscroll-scroll才能滚动,其他属性就没必要管了,不用去看官方又臭又长的文档

复制代码
<template>
    <DynamicScroller
         :style="'overflow':'scroll', 'height':'400px'"
        :items="Arr"
        :min-item-size="100"
        key-field="id"
    >
        <template #default="{ item, index, active }">
            <DynamicScrollerItem
                :item="item"
                :active="active"
                :data-index="index"
            >
                // 这里放置需要循环的代码
            </DynamicScrollerItem>
        </template>
    </DynamicScroller>
</template>
相关推荐
shenyan~3 分钟前
关于 WASM: WASM + JS 混合逆向流程
开发语言·javascript·wasm
Mintopia5 分钟前
Three.js 高级纹理(Advanced Textures):超越基础,打造沉浸式 3D 世界
前端·javascript·three.js
玄玄子6 分钟前
JS Promise
前端·javascript·程序员
Raink老师11 分钟前
7. TypeScript接口
javascript·typescript
Thanks_ks14 分钟前
探索现代 Web 开发:从 HTML5 到 Vue.js 的全栈之旅
javascript·vue.js·css3·html5·前端开发·web 开发·全栈实战
BillKu16 分钟前
Vue3本地存储实现方案
vue.js
GIS之路17 分钟前
OpenLayers 获取地图状态
前端·javascript·html
remember_me34 分钟前
前端打印实现-全网最简单实现方法
前端·javascript·react.js
前端小巷子37 分钟前
IndexedDB:浏览器端的强大数据库
前端·javascript·面试
Whbbit199937 分钟前
如何使用 Vue Router 的类型化路由
前端·vue.js