开发者社区> 问答> 正文

jQuery的`append`操作不能即时渲染

放在for循环内的append操作,本来应该是for循环执行一次就append一次,但是现在变成了整个for循环完成后才一次性append生成的元素到DOM中去。查了下说这个是因为重绘DOM耗费资源所以缓存掉了。想问下有办法解决么?
问题核心代码:

    for (var i = 0; i < testTimes; i++) {
        for (var j = 0; j < allFunc.length; j++) {
            var currentResult=$('.result').eq(j);
            var gapTime=test(times,allFunc[j]);
            var testTime=currentResult.find('span').length+1;
            if(!resultMatrix[testTime-1]){
                resultMatrix[testTime-1]=[];
            }
            console.log('1');
            var result="<span>第"+testTime+'次实验结果:耗时'+gapTime+'ms</span>';
            currentResult.append(result);//append不是一条一条加,而是全部结果出来后才加上去
            /* 这是后来改成原生appendChild的代码,但是依旧不起作用
            var result=document.createElement('span');
            result.innerHTML='第'+testTime+'次实验结果:耗时'+gapTime+'ms';
            currentResult.get(0).appendChild(result);
            */
            resultMatrix[testTime-1][j]=gapTime;
        };
    };

DEMO:
http://codepen.io/chitanda/full/NqeZag/点击预览

期望效果:
实验结果那里的数据每次计算完成后都即时更新,而不是全部计算完成后一次性更新上去。

PS
chrome下还有个很有趣的现象就是开发者工具的Elements面板里显示span已经加上去了,但是页面中没有任何反应。而IE和FF中则没有这种情况。不知道能否顺带解答下。
screenshot

展开
收起
小旋风柴进 2016-03-26 11:40:28 3569 0
1 条回答
写回答
取消 提交回答
  • JS在执行的过程中,UI渲染过程是不能够介入的
    只能等到所在的JS代码执行完毕,UI线程才开始执行页面渲染工作
    另外 append后 DOM结构树已经生成了,要显示出来需要UI渲染线程参与

    2019-07-17 19:15:58
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关课程

更多

相关电子书

更多
JS 语言在引擎级别的执行过程 立即下载
穆客带你快速定位 Node.js 内存泄露 立即下载
穆客带你快速定位Node.js内存泄露 立即下载