高阶函数之分时函数

高阶函数

高阶函数是指至少满足下列条件之一的函数:

1.函数可以作为参数被传递
2.函数可以作为返回值输入


分时函数

应用场景:WebQQ的好友列表,列表中通常有成百上千个好友,如果一个好友用一个节点来表示,当我们在页面中渲染这个列表的时候,可能要一次性往页面中创建成百上千个节点。

在短时间内往页面大量添加DOM节点会让浏览器卡顿甚至卡死,代码如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
var ary = [];
for (var i = 1; i <= 1000; i++) {
ary.push(i);

}

var renderFriendList = function (data) {
for (var i = 0, l = data.length; i < l; i++) {
var div = document.createElement('div');
div.innerHTML = i;
document.body.appendChild(div);
}
};

renderFriendList(ary)

分时函数timeChunk,让创建节点的工作分批进行

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
var timeChunk = function (ary, fn, count) {
var obj,
t;

var len = ary.length;

var start = function () {
for(var i = 0; i < Math.min(count || 1, ary.length); i++) {
var obj = ary.shift();
fn(obj);
}
};

return function () {
t = setInterval(function () {
if (ary.length === 0) {
return clearInterval(t);
}
start();
}, 200);
};
}

var ary = [];
for (var i = 1; i <= 1000; i++) {
ary.push(i);

}

var renderFriendList = timeChunk(ary, function (n) {
var div = document.createElement('div');
div.innerHTML = n;
document.body.appendChild(div);
}, 8);

renderFriendList();

参考

《JavaScript设计模式与开发实践》

关注我的微信公众号[李一二],即时看更多的文章