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

原文链接:mp.weixin.qq.com

  译者|无明编辑|覃云在刚刚结束的 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

  

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

 

原文地址:https://www.cnblogs.com/Jiangchuanwei/p/9993169.html

时间: 2024-11-14 12:52:46

Web长列表的救星?谷歌推出Virtual Scroller[转]的相关文章

LoadRunner中的Web 函数列表

web test LoadRunner fuction_list D:\Program Files (x86)\Mercury Interactive\Mercury LoadRunner\bin>ls -l *.chm -rw-rw-rw-   1 user     group       25893 May 20  2004 FuncRef.chm -rw-rw-rw-   1 user     group       29443 May 20  2004 RPM_Configuration

Google谷歌推出goo.gl缩短网址服务 - Blog透视镜

Blog部落格文章的网址,例如本篇文章:http://blog.openyu.org/2014/01/google-goo.gl.html,通常都很冗长,分享到社群网站上,容易使得讯息内容过多,同时也会引起读者的反感,Google谷歌推出goo.gl缩短网址服务,不但可以把网址缩短,还能提供统计资料供查询. 阅读全文>> Google谷歌推出goo.gl缩短网址服务 - Blog透视镜,布布扣,bubuko.com

fiddler学习笔记--web session列表

Web Session列表是Fiddler中最重要的部分--它显示了Fiddler多捕捉到的每个Session的简短的摘要信息. 1. Web Session列表栏中各项信息代表的含义 (1)# - Fiddler为Session生成的ID (2)Result - 响应状态码 (3)Protocol - 该Session使用的协议(HTTP/HTTPS/FTP) (4)URL - 请求URL的路径.文件和查询字符串 (5)Host - 接收请求的服务器的主机名和端口号 (6)Body - 响应体

谷歌推出DAYDREAM开发包

<<< 谷歌推出Daydream开发包,VR应用爆发将至 >>> 2016年是虚拟现实元年,除了索尼.HTC和Oculus三大公司开发全功能头盔之外,不计其数的智能手机企业也推出了简易型头盔,希望能够在VR市场分一杯羹.在手机VR领域,野心勃勃的谷歌准备成为一家VR开发的标准制定企业.日前,谷歌面向VR开发准备的开发工具包"谷歌VR SDK 1.0"正式结束了测试期,面向所有虚拟现实开发者提供下载. 利用这一工具包,开发者可以面向所有符合Daydre

谷歌推出端对端邮件加密工具:对抗NSA监控

新浪科技讯 北京时间6月4日早间消息,谷歌周二发布了一个新的Chrome浏览器扩展的源代码,可以方便用户对电子邮件进行加密,使得美国国家安全局(以下简称"NSA")等情报机构的监听难度大幅增加. <<<-------------  <_< 向左看 这款名为End-to-End的加密工具使用OpenPGP开源加密程序编写,可以在用户的电子邮件离开浏览器后对其加密,直到被收件人解密.该工具还可以方便用户读取发送到其电子邮件服务器中的加密信息.不过,发送和接受邮

谷歌推出全新Android开发语言Sky:让App更流畅

土豆网同步更新:http://www.tudou.com/plcover/VHNh6ZopQ4E/ 使用HTML 创建Mac OS App 视频教程. 官方QQ群: (1)App实践出真知 434558944 (2)App学习交流 452180823 百度网盘同步:http://pan.baidu.com/s/1jG1Q58M 分享  [中文纪录片]互联网时代                 http://pan.baidu.com/s/1qWkJfcS 谷歌推出全新Android开发语言Sky

记一次vue长列表的内存性能分析和优化

好久没写东西,博客又长草了,这段时间身心放松了好久,都没什么主题可以写了 上周接到一个需求,优化vue的一个长列表页面,忙活了很久也到尾声了,内存使用和卡顿都做了一点点优化,还算有点收获 写的有点啰嗦,可以看一下我是怎么进行这个优化的,也许有点帮助呢 这个长列表页面,其实是一个实时日志上报的页面,随着页面打开时间的增加,日志数量也会增多,常规的页面布局和渲染免不了会遇到性能问题. 使用了vue框架,框架内部的虚拟DOM和组件缓存已经做了一些优化,比起原生实现是有了一些优化处理. 但这个页面是用到

谷歌推出Android 响应式布局控件 FlexboxLayout -盒子模型

今天github 排行榜上突然出现了 谷歌最新推出的Android 最新控件FlexboxLayout . FlexboxLayout 究竟是什么东西呢? fexbox 也称为盒子模型,广泛用于前端开发,做过前端 web 的都知道Bootstrap 中有一套强大的 CSS 网格样式. Bootstrap 的出现 大大提高了前端开发的效率,并且引领了响应式布局.跨平台开发的潮流. FlexboxLayout  就是类似于 bootstrap 中见网格系统的 强大控件 先上几张谷歌示例程序的截图 F

谷歌推出备份新工具:Google Drive将同步计算机文件

Google 正在将云端硬盘 Drive 转变成更强大的文件备份工具.很快,Google Drive 将能监测并备份你电脑上的(几乎)所有文件,只要是你勾选的文档,Drive 就能同步至云端. 具体来说,这项改变将在 6 月 28 日到来,届时 Google 将会推出一款名为 Backup and Sync(备份与同步)的应用.看起来 Backup and Sync 似乎在未来某个时间点将取代 Google 的 Drive 和 Photos(照片同步与管理)应用.目前 Google 正在向普通用