- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在研究Pokedex site,由于现在有了721 Pokemon,所以ngFor会花很长时间才能第一次显示所有条目。加载完所有数据后,将它们实际放入DOM似乎要花费大约2400毫秒。
这是有问题的ngFor:
<entry *ngFor="let p of (pokedex | filter:search:SelectedVer), let i = index, let last = last"
[id]="'pokemon-entry-' + p.id"
[pokemon]="p"
[language]="SelectedLang"
(click)="SelectPokemon(p)"></entry>
XHR Load (/csv/pokemon_game_indices.csv)
)。根据时间轴,ajax调用本身需要0.02毫秒。我假设使这个很大的块是ajax请求完成后发生的更改检测。那就是当我拿起我一直在构建的模型并将它们放在ngFor上面使用的
pokedex
变量中的时候。我对时间轴的理解是,由ngFor添加的721个DOM元素的构建大约需要2.5秒的时间。
entry
组件取消组件化为仅html(该组件实际上不执行任何操作),但这似乎并没有以任何明显的方式影响时间。删除我用来过滤列表的管道也不会影响时间。
最佳答案
简短而甜美的回答是“不要遍历整个数组”,但这对我来说还不够好。我希望它看起来像是整个条目列都存在。所以我在上面放置了一个间隔,ngFor遍历了数组的一个子部分,在下面放置了一个间隔,这一起使列表看起来像所有元素一直存在。
这是我的html的简化版本,仅包含此问题的相关部分(full example on bitbucket):
<div (scroll)="ColScroll($event)">
<div [style.height]="Math.max(0, Math.max(0, scrollPos - 10) * 132)"></div>
<entry *ngFor="let p of (base.pokemon | filter:search:SelectedVer:SelectedLang) | justafew:scrollPos" [pokemon]="p"></entry>
<div [style.height]="Math.max(0,((base.pokemon | filter:search:SelectedVer:SelectedLang).length - scrollPos - 40)) * 132"></div>
</div>
<div> <!-- column -->
<div></div> <!-- spacer -->
<entry *ngFor='...'></entry>
<div></div> <!-- spacer -->
</div>
<entry>
总是正好为120像素高,底部边缘为12像素,总共占总空间132像素。 CSS做到了这一点。无论我要选择什么恒定大小,它都可以工作,但是我做出特殊的假设,即大小恰好是132像素。
scrollPos = 0;
...
ColScroll(event: Event) {
let pos = $(event.target).scrollTop();
this.scrollPos = Math.floor(pos / 132);
}
scrollPos
保留了我应该在屏幕上显示的第一项的第一个索引。
<entry>
元素的ngFor如下所示:
*ngFor="let p of (base.pokemon | filter:search:SelectedVer:SelectedLang) | justafew:scrollPos"
base.pokemon
是创建每个入口元素所需的口袋妖怪数据的数组。
... | filter:search:SelectedVer:SelectedLang)
用于搜索列表。我将其留在此处的示例中,以表明您仍然可以在我的黑客入侵之前使用列表。
... | justafew:scrollPos
是神奇的地方。这是整个过滤器(
bitbucket):
import { Pipe, PipeTransform } from '@angular/core';
import { MinPokemon } from '../models/base';
@Pipe({
name: 'justafew',
pure: false
})
export class JustAFewPipe implements PipeTransform {
public transform(value: MinPokemon[], start: number): MinPokemon[] {
return value.slice(Math.max(0, start - 10), start + 30);
}
}
scrollPos
作为
start
参数传入。例如,如果我向下滚动了13200个像素,则
scrollPos
将设置为100(请参见上方 Controller 中的滚动事件)。这将对数组进行 slice ,使其返回从90到130的元素。我想在屏幕上稍微溢出一点,以确保快速滚动不会导致可见的空白(疯狂的快速滚动可能仍会显示它,但是您移动得如此之快很容易想到浏览器的渲染速度还没有那么快,所以我让它滑动了)。我使用
Math.max
,所以我不会使用负数进行 slice ,例如当我位于列表的顶部并且
scrollPos
为0时。
[style.height]
并使用一些数学运算法则来使这些间隔符占用所需的空间。当我向下滚动时,顶部间隔物会变高,而底部间隔物会收缩完全相同的量,因此列始终处于相同的高度。当我向上滚动时,数学结果恰好相反:顶部缩小,底部增长。底部的分隔符使用与ngFor完全相同的过滤器逻辑,因此,如果我运行返回100而不是721 pokemon的搜索,它将调整为100个条目的高度。第一个分隔符使用
scrollPos - 10
,因为
justafew
过滤器返回10。出于相同的原因,底部分隔符使用
scrollPos - 30
,因为这就是返回的
justafew
多少。
关于angular - 如何为大型阵列加快ngFor?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37600154/
我想使用 ffmpeg 框架更改视频速度。我为此使用了这个命令: ffmpeg -y -i /storage/extSdCard/Video/1.avi -filter_complex [0:v]fp
我有以下数据数组,有 200 万个条目: [20965 1239 296 231 -1 -1 20976 1239 299 314 147 337 255
我正在使用 Oracle 数据库,并且想获取一个包含 3000 万条记录的表。 library(RODBC) ch <- odbcConnect("test", uid="test_user",
我在 android 上使用 FFmpeg 来: 1- 合并 3 个视频 2-添加音频 3-添加标志 4-修剪 3 个视频之一 5-改变输出的fps 我已经实现了正确的代码,但花了 30 分钟。对于(
我使用 GLPKMathProgInterface 和 JuMP 编写了一个程序来解决 Julia 中的线性程序。 Julia 代码由 python 程序调用,该程序通过多个命令行调用运行多个 Jui
我们使用 POV-Ray 每次运行生成大约 80 张图像,我们将这些图像拼接在一起形成两个移动的 GIF 文件(一个场景的两个 360 度 View )。我们正在寻找尽可能加快此镜像创建的方法(在 h
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我将数据从一个数据库插入到另一个数据库,所以我有 2 个连接(Conn1 和 Conn2)。下面是代码(使用pypyodbc)。 import pypyodbc Conn1_Query = "SE
在我的应用程序中,我显示 EKEvents 列表,我想在 UITableView 中显示一个月的所有事件,每个部分包含各自的日期。嗯,这可行,我得到了我需要的所有数据,但获取速度非常慢。 问题在于事件
我有一个移动速度非常慢的传送带。我不知道什么JS脚本控制速度,我需要它来加速。无法从主题制作者那里获得任何帮助。任何建议都会非常有帮助。谢谢 页面: http://krankgolf2017.wpen
有没有办法加快这段代码的速度?我需要它来删除相同的内容并将其写入单元格,以强制其他 VBA 代码运行另一列上的代码。这就是它的作用,只是 super 慢。有时此表上有 2000 个条目/行。每个单元大
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 LINQ 查询,它正在搜索包含大约 250,000 条记录的 SQL 表,并且仅搜索 2 个字段。这两个字段都已建立索引,但我发现它的运行速度仍然相当慢。 下面是代码,有人可以提出任何建议来
对于相对较大的 Pandas DataFrame(几十万行),我想创建一个应用函数结果的系列。问题是该功能不是很快,我希望它能以某种方式加快速度。 df = pd.DataFrame({ 'valu
这个问题在这里已经有了答案: Faster weighted sampling without replacement (3 个答案) 关闭 9 年前。 如何在 R 中加快概率加权采样。 # Let
在运行 PhantomJS 提供的 rasterize.js 示例时,我发现我必须等待 20 秒或更长时间才能生成网页图像。 有没有可能在不消耗大量资源的情况下加快速度的方法?我基本上希望快速生成从加
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 Excel 工作簿,用户通过单击按钮导入文本文件。我的代码完全按照我的需要工作,但是在填写 H 列“阅读日期”时速度非常慢。将文本文件导入 Excel 工作表后,我的 Excel 工作簿如下
我是一名优秀的程序员,十分优秀!