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

封装一个 虚拟列表渲染 组件

组件代码

<template><div ref="list" class="infinite-list-container" @scroll="scrollEvent($event)"><div class="infinite-list-phantom" :style="{ height: listHeight + 'px' }"></div><div class="infinite-list" :style="{ transform: getTransform }"><div ref="items"class="infinite-list-item" v-for="item in visibleData" :key="item.id":style="{ height: itemSize + 'px',lineHeight: itemSize + 'px' }">{{ item.value }}</div></div></div>
</template><script>
export default {name:'VirtualList',props: {//所有列表数据listData:{type:Array,default:()=>[]},//每项高度itemSize: {type: Number,default:200}},computed:{//列表总高度listHeight(){return this.listData.length * this.itemSize;},//可显示的列表项数visibleCount(){return Math.ceil(this.screenHeight / this.itemSize)},//偏移量对应的stylegetTransform(){return `translate3d(0,${this.startOffset}px,0)`;},//获取真实显示列表数据visibleData(){return this.listData.slice(this.start, Math.min(this.end,this.listData.length));}},mounted() {this.screenHeight = this.$el.clientHeight;this.start = 0;this.end = this.start + this.visibleCount;},data() {return {//可视区域高度screenHeight:0,//偏移量startOffset:0,//起始索引start:0,//结束索引end:null,};},methods: {scrollEvent() {//当前滚动位置let scrollTop = this.$refs.list.scrollTop;//此时的开始索引this.start = Math.floor(scrollTop / this.itemSize);//此时的结束索引this.end = this.start + this.visibleCount;//此时的偏移量this.startOffset = scrollTop - (scrollTop % this.itemSize);}}
};
</script><style scoped>
.infinite-list-container {height: 100%;overflow: auto;position: relative;-webkit-overflow-scrolling: touch;
}.infinite-list-phantom {position: absolute;left: 0;top: 0;right: 0;z-index: -1;
}.infinite-list {left: 0;right: 0;top: 0;position: absolute;text-align: center;
}.infinite-list-item {padding: 10px;color: #555;box-sizing: border-box;border-bottom: 1px solid #999;
}
</style>

使用:

<VirtualList :listData="data" :itemSize="100"/>
http://www.lryc.cn/news/224803.html

相关文章:

  • Spring中@Bean标注的方法是如何创建对象呢?
  • 伦敦金股票代码是什么?
  • 【环境装配】Anaconda在启动时闪现黑框,闪几次后仍能正常使用,解决黑框问题
  • 【Python】Python爬虫使用代理IP的实现
  • 盘点U-Mail邮件系统安全设计
  • Webpack--动态 import 原理及源码分析
  • 创新无处不在的便利体验——基于智能视频和语音技术的安防监控系统EasyCVR
  • 强化IP地址管理措施:确保网络安全与高效性
  • Power Automate-创建审批流
  • 商越科技:渗透测试保障平台安全,推动线上采购高效运转
  • Java10新增特性
  • Hive 知识点八股文记录 ——(一)特性
  • 如何使用PHP替换回车为br
  • Unity 场景优化策略
  • Wireshark在Windows上安装后报错怎么办?
  • 【Proteus仿真】【51单片机】水质监测报警系统设计
  • TensorFlow2.0教程3-CNN
  • flink1.18.0 sql-client报错
  • 基于ssm的校园快递物流管理系统(java+jsp+ssm+javabean+mysql+tomcat)
  • C++:this指针和构造与析构的运用
  • 通用工作站设计方案 :807-ORI-S3R500 -多路PCIe3.0的单CPU通用工作站
  • 机器学习写代码时遇到的问题(23.11.9)
  • C#学习系列之事件
  • list部分接口模拟实现(c++)
  • 数据结构(C语言) 实验-栈与字符串
  • xLua Lua访问C#注意事项(七)
  • vue3+antv2.x的画布
  • Docker部署ubuntu1804镜像详细步骤
  • mac 卸载第三方输入法
  • 可观察性在软件测试中的重要性