zoukankan      html  css  js  c++  java
  • 遍历

    想到的有for in循环;for循环;forEach循环

    (1)for in

    性能问题:

    for-in 需要分析出array 的每个属性,这个操作性能开销很大。用在 key 已知的数组上是非常不划算的。所以尽量不要用 for-in,除非你不清楚要处理哪些属性,例如 JSON 对象这样的情况。

    (2)for

    性能问题:循环每进行一次,就要检查一下数组长度。读取属性(数组长度)要比读局部变量慢,尤其是当 array 里存放的都是 DOM 元素,因为每次读取都会扫描一遍页面上的选择器相关元素,速度会大大降低。

      for (var i=0; i<arr.length; i++){
    
        //do sth with arr[i];
    
      }

    加速方案:

    var arr = [1,2,3,4,5];
    
    var length =arr.length;
    
    for(var i=0; i<length; i++){
    
      fn(arr[i]);
    
    }

    思路:

    现在只需要读取一次 array 的 length 属性,速度已经加快

    加速且优雅:

     var arr = [1,2,3,4,5];
    
    var i = arr.length;
    
    while(i--){
    
      fn(arr[i]);
    
    }

    思路:如果循环终止条件不进行比较运算,那么循环的速度还可以更快。

    (3)forEach

    var arr = [1,2,3,4,5];

    arr.forEach(

      fn(value,index){

        //Do sth with value ;

      }

    )

    注意:

    • 这里的 forEach回调中两个参数分别为 value,index,其位置刚好和 jQuery 的$.each 相反;
    • forEach 无法遍历对象;
    • IE不支持该方法;Firefox 和 chrome 支持;
    • forEach 无法使用 break,continue 跳出循环,且使用 return 是跳过本次循环;
    • 可以添加第二个参数,为一个数组,回调中的 this 会指向这个数组,若没有添加,则是指向 window;
  • 相关阅读:
    【7】用Laravel5.1开发一个简单的博客系统
    【6】Laravel5.1的migration数据库迁移
    【5】说说Laravel5的blade模板
    【4】优化一下【3】的例子,顺便说说细节
    【3】创建一个简单的Laravel例子
    【2】最简单的Laravel5.1程序分析
    【1】Laravel5.1 安装
    【0】Laravel 5.1 简介
    MySQL常用命令
    Windows8.1使用博客客户端写博客
  • 原文地址:https://www.cnblogs.com/wang715100018066/p/7992790.html
Copyright © 2011-2022 走看看