1
alexrezit Jan 20, 2014
这玩意儿应该用 canvas 或者至少是 table 吧...
|
2
binux Jan 20, 2014
让我猜猜,你是不是一个div一个div追加到页面里面去的?
|
6
unstop Jan 20, 2014
用 DIV 画是 OK 的,但是如果一个一个追加会有性能问题,因为导致了页面回流(reflow)之类的。@binux 的方案是可以的,先在 JS 里面拼接完毕之后再一次性加进去。
另外,D3 有一个实现了类似效果的示例:http://mbostock.github.io/d3/talk/20111018/calendar.html 话说回来,用 JS 自己画 Canvas 应该是最好的方案。 |
7
ry_wang OP |
8
unstop Jan 20, 2014 @ry_wang 另外我刚刚在搜索 D3 的这个示例的时候找到了这个,可能有帮助: http://kamisama.github.io/cal-heatmap/
|
10
binux Jan 20, 2014
@ry_wang http://jsbin.com/aSelozi/1
很慢吗?根本没有啊,10w个div毫无压力啊,当然js执行是要很久,谁让数据量那么大 不能分页吗,或者分开部分加载 你确定是div的问题而不是模板引擎的问题,或者是reflow次数太多的问题? |
11
9hills Jan 20, 2014
这个想法很不错
|
12
ry_wang OP |
13
ayanamist Jan 20, 2014
|
15
alexapollo Jan 20, 2014
做tuning嘛,做异步加载就好了,先把主页面加载进去,然后一个一个把小灯点亮~
|
16
miniwade514 Jan 21, 2014
感觉用 canvas 会更快吧, JS 的运算量相当,但是不用碰 DOM
|
17
loading Feb 13, 2014
在个人主页导航做过类似的东西,就是一个个div,把它变成点阵屏幕。。。还写了26字幕的map。
IE爆卡。。。 |