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

vue-virtual-scroll-list虚拟列表

当DOM中渲染的列表数据过多时,页面会非常卡顿,非常占用浏览器内存。可以使用虚拟列表来解决这个问题,即使有成百上千条数据,页面DOM元素始终控制在指定数量。

 

一、参考文档

https://www.npmjs.com/package/vue-virtual-scroll-list

二、引入

import VirtualList from 'vue-virtual-scroll-list'components: {'virtual-list': VirtualList
}<virtual-list:data-key="'productCode'":data-sources="productList":data-component="productItem":keeps="20"style="overflow-y: auto;"@scroll="(e) => watchScroll(e)"ref="scrollList":extra-props="{addCart}"
>

三、参数

参数描述

data-sources

数据列表[数组]

data-key

列表 key 值

data-component

列表子组件

keeps

渲染最大 DOM 数量

extra-props

额外参数,可传变量和方法

@scroll

监听滚动事件

四、注意

1、virtual-list 组件自身必须设置为滚动区域

style="overflow-y: auto;"

2、子组件引入由原 components 注册改为在 data 注册

import productItem from '@components/product/productItem';data() {return {productList: [{productCode: 1, productName...}, {...}, ...], // 数据列表productItem // 子组件}
}

3、子组件商品数据统一改为 source

props: {source: {type: Object,default() {return {};}}
}

4、子组件不再使用$emit方式与父组件交互,将父组件方法声明在extra-props中,子组件通过props接收,需要$emit 的时候使用 props 中接收的方法

props: {// 接收父组件方法addCart: {type: Function,default: () => {}}
}methods: {// 子组件点击加购按钮clickAddCart(item) {// 调用父组件加购方法this.addCart(item)}
}

5、回到顶部,虚拟列表不识别 scrollTop,使用虚拟列表特有的 scrollToIndex 或 scrollToOffset 方法回到顶部

this.$refs.scrollList.scrollToIndex(0);

http://www.lryc.cn/news/36418.html

相关文章:

  • C++学习笔记(以供复习查阅)
  • 备份时间缩短为原来 1/4,西安交大云数据中心的软件定义存储实践
  • 我国近视眼的人数已经超过了六亿,国老花眼人数超过三亿人
  • 设计模式(十八)----行为型模式之策略模式
  • VUE3入门基础:input元素的type属性值说明
  • 关于供应链,一文教你全面了解什么是供应链
  • Scope作用域简单记录分析
  • ChatGPT创作恋爱甜文
  • 贝叶斯优化及其python实现
  • Lombok使用@Builder无法build父类属性
  • Pixhawk RPi CM4 Baseboard 树莓派CM4安装Ubuntu20.04 server 配置ros mavros mavsdk
  • 后端开发过程中的安全问题
  • 基于Hyperledger Fabric的学位学历认证管理系统
  • jq条件判断验证,正则表达式
  • 23.3.9打卡 AtCoder Beginner Contest 259
  • JS - this指向
  • 低代码有哪些典型应用场景?
  • Substrate 基础教程(Tutorials) -- 监控节点指标
  • lua table 详解
  • Element表单嵌套树形表格的校验问题
  • 1.webpack的基本使用
  • 面试必看:谈谈你所了解的JVM调优,JVM性能调优总结
  • Pytorch优化器Optimizer
  • 如何在MySQL 8中实现数据迁移?这里有一个简单易用的方案
  • java多线程(二三)并发编程:Callable、Future和FutureTask
  • day4分支和循环作业
  • 轮毂要怎么选?选大还是选小?
  • RabbitMq 使用说明
  • Vue(10-20)
  • C++-对四个智能指针:shared_ptr,unique_ptr,weak_ptr,auto_ptr的理解