9月7日-8日,相约 2023 腾讯全球数字生态大会!聚焦产业未来发展新趋势! 了解详情
写点什么

Web 长列表的救星?谷歌推出 Virtual Scroller

  • 2018-11-16
  • 本文字数:2522 字

    阅读完需:约 8 分钟

Web长列表的救星?谷歌推出Virtual Scroller

在刚刚结束的 Chrome dev summit 2018 上,谷歌工程经理 Gray Norton 向我们介绍 virtual-scroller,一个 Web 滚动组件,未来它可能会成为 Web 高层级 API(Layered API)的一部分。它的目标是解决长列表的性能问题,消除离屏渲染。该项目处于研发中,你可以在 GitHub 查看它的开发者预览版本。


众所周知,渲染性能主要取决于渲染量, 过多的 DOM 会使你的网站速度变得很慢,即使在本地,也会出现相同的问题,但若通过虚拟滚动的方式,也就是在用户滚动时用足够的内容填充屏幕并不断更新,就能让网站保持高速运行,这也是 virtual-scroller 的基本原理。

virtual-scroller 详解

<virtual-scroller>是未来 Web 平台的一个潜在特性,是 layered API 项目的一部分,用于将 JavaScript 对象集映射到 DOM 节点上,并且只渲染当前可见的 DOM 节点,其余部分为“虚拟”的。

示例

<script type="module"        src="std:virtual-scroller|https://some.cdn.com/virtual-scroller.js"></script>
<virtual-scroller></virtual-scroller>
<script type="module"> const scroller = document.querySelector('virtual-scroller'); const myItems = new Array(200).fill('item');
scroller.updateElement = (child, item, index) => { child.textContent = index + ' - ' + item; child.onclick = () => console.log(`clicked item #${index}`); };
// This will automatically cause a render of the visible children // (i.e., those that fit on the screen). scroller.itemSource = myItems;</script>
复制代码


默认情况下,这个示例中创建的虚拟滚动条内的元素为<div>,并将会被回收。更多示例请参阅:


https://github.com/valdrinkoshi/virtual-scroller/blob/master/demo/index.html

virtual-scroller demo

00:00 / 00:00
    1.0x
    • 2.0x
    • 1.5x
    • 1.25x
    • 1.0x
    • 0.75x
    • 0.5x
    网页全屏
    全屏
    00:00

    API 介绍

    createElement 属性

    类型:function(item: any, itemIndex: number) => Element


    在设置这个属性时,使用工厂函数来配置虚拟滚动条,这个工厂函数会在指定索引位置的项目首次准备好在 DOM 中显示时创建一个元素。


    在首次调用时,createElement 将搜索第一个<template>元素,该元素本身在其模板内容中至少也包含了一个子元素。如果存在,它将通过克隆该子元素来创建新元素。否则,它将创建一个<div>元素。对于这两种情况,如果 recycleElement 为默认值,它将回收 DOM 节点。


    如果 recycleElement 为默认值,那么更改这个属性的默认值将自动将 recycleElement 重置为 null。

    updateElement 属性

    类型:function(child: Element, item: any, itemIndex: number)


    在设置这个属性时,使用一个函数来配置虚拟滚动条,这个函数将使用指定索引处的项目的数据来更新元素。


    这个属性将在以下场景中被调用:


    • 用户滚动滚动条,更改项目元素的可见性。在这种情况下,将为所有新的可见元素调用 updateElement。

    • 开发人员修改了 itemSource 属性。

    • 开发人员调用了 itemsChanged(),它将为所有当前可见的元素调用 updateElement。


    默认的 updateElement 将子元素的 textContent 设置为给定项。几乎所有使用的地方都需要改变这个行为。

    recycleElement 属性

    类型:function(child: Element, item: any, itemIndex: number)


    如果项目的元素不再可见,recycleElement 默认会将它回收,并将其与 DOM 连接,默认的 createElement 就可以重用它。


    当项目元素不再可见时,将这个属性设置为 null 可以将它从 DOM 中删除,并防止被默认的 createElement 回收。


    通常,这个属性会被自定义,以便引入自定义的节点回收逻辑。

    itemSource 属性

    类型:Array 或 ItemSource


    设置这个属性可以控制滚动条如何将可见索引映射到对应项。然后,这些项被提供给各种自定义渲染函数:createElement、updateElement、recycleElement。


    如果提供的是数组,它将被转换为 ItemSource 实例,这个实例将返回数组中的元素,就像在调用 ItemSource.fromArray(array)一样(没有 key 参数)。

    layout 属性

    类型:string


    值可以为:


    • “vertical”(默认);

    • “horizontal”;

    • “vertical-grid”;

    • “horizontal-grid”。


    也可以设置为元素的属性,例如<virtual-scroller layout=“horizontal-grid"></virtual-scroller>

    itemsChanged()方法

    这将重新渲染所有当前显示的元素,使用 updateElement 来更新它们。


    通常需要在要显示的数据发生变化时调用它,包括对数据的添加、删除和修改。

    scrollToIndex 方法

    要滚动到指定的索引,可选择使用以下位置之一:


    • “start”:将项目的开头与滚动条可见部分的开头对齐;

    • “center”:将项目的中心与滚动条可见部分的中心对齐;

    • “end”:将项目的末尾与滚动条可见部分的末尾对齐;

    • “nearest”:如果项目位于滚动条可见部分的中心之前,那么与“start”一样;如果它位于滚动条可见部分的中心之后,则与“end”一样。

    “rangechange”事件

    Bubbles: false / Cancelable: false / Composed: false


    当滚动条完成渲染新的项目范围时触发,例如,用户滚动了滚动条。这个事件是 RangeChangeEvent 的一个实例,它具有以下属性:


    • first:一个数字,给出当前渲染的第一个项目的索引。

    • last:一个数字,给出当前渲染的最后一个项目的索引。

    ItemSource 类

    ItemSource 类代表了一种将索引转换为 JavaScript 值的方法。你可以像这样创建它们:


    const source = new ItemSource({  item(index) { ... },  getLength() { ... },  key(index) { ... }});
    复制代码


    例如,要创建一个从 contacts 数组中获取项目的 ItemSource,并使用 contact.id 作为键,你可以这样:


    const contactsSource = new ItemSource({  item(index) { return contacts[index]; },  getLength() { return contacts.length; },  key(index) { return contacts[index].id; }});
    复制代码


    还有一个工厂方法 ItemSource.fromArray(array [,key])可以更容易地完成这个操作:


    const contactsSource = ItemSource.fromArray(contacts, c => c.id);
    复制代码


    将一个项目传给 fromArray()的参数 key,并且返回该对象的唯一键。如果没有指定参数 key,则将项目索引作为键。


    ItemSource 类的主要用途是赋值给<virtual-scroller>元素的 itemSource 属性,所以目前它唯一的公共 API 中只有一个 length 属性。


    参考链接:https://github.com/valdrinkoshi/virtual-scroller


    活动推荐:

    2023年9月3-5日,「QCon全球软件开发大会·北京站」 将在北京•富力万丽酒店举办。此次大会以「启航·AIGC软件工程变革」为主题,策划了大前端融合提效、大模型应用落地、面向 AI 的存储、AIGC 浪潮下的研发效能提升、LLMOps、异构算力、微服务架构治理、业务安全技术、构建未来软件的编程语言、FinOps 等近30个精彩专题。咨询购票可联系票务经理 18514549229(微信同手机号)。

    2018-11-16 08:002710
    用户头像

    发布了 731 篇内容, 共 422.2 次阅读, 收获喜欢 1988 次。

    关注

    评论

    发布
    暂无评论
    发现更多内容

    程序员的修行之路-关于编程语言

    牧马人

    程序员

    linux 账户及安全管理(一 账户管理)

    牧马人

    Linux

    系统化服务构建-软件工程分层

    图南日晟

    微服务 软件工程 架构设计

    C#刷遍Leetcode面试题系列连载(1) - 入门与工具简介

    Python名人堂

    C# .net 算法 LeetCode

    配置国内的pip源以提高使用pip安装python软件包的速度

    良少

    Python pip

    数据产品经理实战-DMP搭建

    第519区

    产品经理 营销

    短视频时代下的知识摄取

    Neco.W

    学习 知识管理 知识体系 短视频

    美国播客节目《指数视角》专访李飞飞:疫情、 AI 伦理、人才培养

    神经星星

    人工智能 程序员 李飞飞 硅谷 AI 伦理

    2020年3月北京BGP机房网络质量评测报告

    博睿数据

    运维 APM 机房 数据中心 拨测

    2020年3月云主机性能评测报告

    博睿数据

    云计算 运维 机房 数据中心 主机

    Flink 完美搭档:数据存储层上的 Pravega

    Apache Flink

    大数据 flink 流计算 实时计算

    我们都可能陷入经济困境

    董一凡

    生活

    docker19.03读取NVIDIA显卡

    首富手记

    Docker Dockerfile

    我的时间管理之路(附工具集合及使用心得)

    YoungZY

    App 时间管理

    ARTS打卡 第1周

    引花眠

    ARTS 打卡计划

    卡巴斯基产品本地化用时能缩短 77%,怎么做到的?

    葛仲君

    项目管理 软件开发 本地化 开发流程

    程序员的修行之路-保持良好的心态

    牧马人

    程序员

    Java运算符实际运用

    凌轩

    Java 编程语言

    如何在团队中做好Code Review

    Ken

    团队协作 代码审查 Code Review 代码质量

    关于用户体验的一些思考

    dstweihao

    android 产品开发

    自制操作系统

    贾献华

    是什么在背后支撑起“带货一哥”李佳琦?

    博睿数据

    负载均衡 APM 压测 秒杀 并发

    程序员的修行之路-关于编程语言

    牧马人

    程序员

    df 和 ls 命令执行夯主

    首富手记

    生产力

    使用Spring Boot和Docker构建微服务架构(四)

    Tux Hu

    Docker 架构 容器 微服务 Spring Boot

    世界那么大,你有偏见吗?

    谢锐 | Frozen

    创业 技术管理

    字符与编码

    引花眠

    计算机基础 utf-8

    使用Spring Boot和Docker构建微服务架构(三)

    Tux Hu

    Docker 架构 容器 微服务 Spring Boot

    游戏夜读 | 世界两大游戏评论!

    game1night

    谈谈控制感(10):怎么做一个靠谱的人

    史方远

    职场 心理 成长

    ARTS week 1

    丽子

    • 扫码添加小助手
      领取最新资料包
    Web长列表的救星?谷歌推出Virtual Scroller_大前端_Chrome官方团队_InfoQ精选文章