zoukankan      html  css  js  c++  java
  • Javascript之数组遍历

    一、遍历数组的几种方式

         1、for...in遍历数组,会遍历数组的索引和数组原型上的对象

         2、for循环直接遍历

         3、迭代器:forEach(遍历数组中所有的值,并忽略回调函数返回的值)、every(一直运行直到返回false)、some(一直运行直到返回true)等遍历

         4、for...of直接遍历数组中的值

              对于for...of,只要是可以迭代的对象都可以用for...of来遍历,也就是内部实现了iterator的对象

    var arr = ["1", "4", "7", "9", "11"]
    for(v of arr) {
      console.log(v)
    }
    

       数组中内置@@iterator对象,使用方式如下:

    var arr = [1, 2, 4]
    var it = arr[Symbol.iterator]()
    it.next()//{value: 1, done: false}
    it.next()//{value: 2, done: false}
    it.next()//{value: 4, done: true}
    

      普通对象中没有实现@@iterator对象,但是我们可以给对象自定义@@iterator

          利用Object.defineProperty来给对象中的属性定义特性,利用闭包来实现值的移位。

    var obj = {
        a: '1',
        b: '5'
    }
    
    Object.defineProperty(obj, Symbol.iterator, {
      enumerable: false,
      writable: false,
      configurable: true,
      value: function() {
          var o = this;
          var idx = 0;
          var ks = Object.keys(o)
    return { next: function() { return { value: o[ks[idx++]], done: (idx >= ks.length) } } } } }) var it = obj[Symbol.iterator]() it.next() it.next()

      

      

  • 相关阅读:
    Win7 华硕电脑自带摄像头无法打开 方法思路介绍
    P3520 [POI2011]SMI-Garbage
    二分图的最大匹配(模板)
    #数列分块入门 2
    数列分块入门#1
    线段树(标记下传乘法和加法)
    最小费用最大流
    最大流算法(模板)
    编译器出现/mingw32/bin/ld.exe:Permission denied 错误
    1298 圆与三角形
  • 原文地址:https://www.cnblogs.com/yy95/p/9736468.html
Copyright © 2011-2022 走看看