jquery的each循环与javascript的for循环性能比较

最近开发了H5,其中有一个页面的列表数据是由ajax获取接口的数据进行渲染的,页面渲染的速度非常慢,首先考虑的是接口响应的速度,经测试接口响应的速度平均值在1s之内,属于正常速度,之后发现是jquery的each循坏处理速度慢,后改成javascript的for循环处理数据,页面加载速度有明显的的提升。

请看下面的例子:

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
    <title>for循环与each循环性能比较</title>
</head>
<body>
    <div>
            <div id="ceshi"></div>
            <input type="button" value="for" οnclick="csfor();"/>
            <input type="button" value="each" οnclick="cseach();" />
    </div>
</body>
</html>

<script src="jquery-1.2.6.min.js" type="text/javascript"></script>
<script type="text/javascript" language="javascript">

    $(function(){
        //加数据
        for(var i=0;i<1024;i++){
            $("#ceshi").append('<div class="cece" title="">000</div>');
        }
        
    });
    function csfor(){
        var cc = $(".cece");
        var length = cc.length;
        var time1 = new Date().getTime();
        for(var i=0;i<length;i++){
            cc[i].title = 'hhh';
        }
        var time2 = new Date().getTime();
        alert("for耗时:"+(time2-time1));
    }
    function cseach(){
        var time3 = new Date().getTime();
        $(".cece").each(function(){
            $(this).attr('title','ggg');
        });
        var time4 = new Date().getTime();
        alert("each耗时:"+(time4-time3));
    }
</script>

浏览器测试结果:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值