js中循环总结,多种循环遍历的实现介绍(while,for,map,foreach等)

时间: 2017-10-31阅读: 553标签: js知识

循环是所有语言最基础的语法,这篇文章将总结javascript的多种实现循环的方法,希望对大家能有一定的学习和帮助。

while循环

while 语句可以在某个条件表达式为真的前提下,循环执行指定的一段代码,直到那个表达式不为真时结束循环。

var i = 0;
while (i < 3) {
  i++;
  console.log(i);//输出1,2,3.
}
//当i=3的时候跳出,循环了3次
do...while循环

do...while循环至少迭代一次,当while的条件为false的时候跳出

var i = 0;
do {
   i++;
   console.log(i);//输出1
} while (i < 0);

这个例子说明了,即使在不满足while内条件的时候,do...while里也迭代循环了一次。

for循环
for(var i= 0;i<arr.length;i++){  
       console.log(i+'/'+arr[i]);  
}

//for ([变量初始化];[条件];[变量递增或递减]) { //代码块 }

for是普通的循环遍历方式,便于理解 。循环的变量声明和初始化,条件查询和循环变量的递增或递减都可以在相同的行中完成。它增加了可读性,降低了出错的几率。

for...in循环
var obj = {a:1, b:2, c:3};  
for (var o in obj) {
  console.log(o + " = " + obj[o]);
}
//语法:variable在每次迭代时,将不同的属性名分配给变量。 object 被迭代枚举其属性的对象
for (variable in object) {...}

for...in主要用于遍历一个对象的可枚举属性,注意点:

1.用于遍历数组,结果不一定按次序访问元素 。2.遍历对象他会对原型上的元素进行遍,如果你只要考虑对象本身的属性,而不是它的原型,那么使用 getOwnPropertyNames() 或hasOwnProperty()来确定某属性是否是对象本身的属性。代码如下

for (var o in obj) {
    if (obj.hasOwnProperty(o)) {
        console.log(o + " = " + obj[o]);
   }
}
for...of循环

for...of可用于“Array,Map,Set,String,TypedArray,arguments对象等”上创建一个迭代循环。这是ES6中新引入的一种循环类型。

let arr = [1, 2, 3];
for (let v of arr) {
    ++v;
    console.log(v);//输出2 3 4
}

针对其他类型的循环这里就不一一介绍了。

foreach循环
Firefox 和Chrome 的Array 类型都有forEach的函数。 主要IE是不没有foreach方法的,如果使用了会抛出异常: 对象不支持“forEach”属性或方法。   使用forEach遍历数组是非常简单的。因为不用担心循环变量、条件和其他任何东西,它会处理所有迭代的问题。
var arr=[];
arr.push(1);
arr.push(2);
arr.forEach(function(e){  
    console.log(e);  
})

如果要实现,考虑到兼容IE的话, 我们需要给它手动添加这个原型方法。代码如下:

if (!Array.prototype.forEach) {  
    Array.prototype.forEach = function(callback, thisArg) {  
        var T, k;  
        if (this == null) {  
            throw new TypeError(" this is null or not defined");  
        }  
        var O = Object(this);  
        var len = O.length >>> 0;
        if ({}.toString.call(callback) != "[object Function]") {  
            throw new TypeError(callback + " is not a function");  
        }  
        if (thisArg) {  
            T = thisArg;  
        }  
        k = 0;  
        while (k < len) {  
            var kValue;  
            if (k in O) {  
                kValue = O[k];  
                callback.call(T, kValue, k, O);  
            }  
            k++;  
        }  
    };  
}
map循环

map数组的另一个原型方法,通过map方法将创建一个新的数组,该数组的返回值由一个给定的数组的函数执行生成。代码如下

var arr=[1, 2, 3].map(function(x) { 
    console.log(x);//输出1,2,3
    return x*2;
});
console.log(arr);//输出[2,4,6]

注意的是:map()的方法以函数作为参数,函数内包括了3个参数,3个参数都是可以选填的。

currentValue在数组中处理的当前元素 ,index:数组中正在处理的当前元素的索引值 ,array:数组映射的调用 


js判断是否为IE浏览器的多种方法总汇

这篇文章主要整理通过js来判断浏览器是否为IE的多种方法。使用js脚本判断浏览器是否为ie,这里分享六种判断是否为ie的方法,有需要的朋友参考学习下。

js中return关键词的作用_return的用法详解

return从字面意思来看就是返回,官方定义return语句将终止当前函数并可以返回当前函数的值; 也就是说return后面可以跟一个value,也就是说可以跟javascript中的任何数据类型

js记录用户行为浏览记录和停留时间

原来是想使用 cookie 来记录,但是考虑到 cookie 所能记录的数据最大为 4k ,可能不够用。于是使用了 HTML5 的 localStorage (最大数据 5M )来存储( IE8 以上浏览器支持)。这里使用到了 jquery.cookie 的插件,所以页面要引入 jquery 和 jquery.cookie 。

Web Worker 详细介绍_Web Workers的使用

web worker 是运行在后台的 JavaScript,独立于其他脚本,也就是说在Javascript单线程执行的基础上,开启一个子线程,进行程序处理,而不影响主线程的执行。Service Worker 是一个由事件驱动的 worker,它由源和路径组成,以加载 .js 文件的方式实现的。

数字在JavaScript中是如何编译的

JavaScript中的所有数字都是浮点数。这篇博客文章解释了这些浮点数如何在64位二进制内部表示。浮点数并不一定等于小数,定点数也并不一定就是整数。所谓浮点数就是小数点在逻辑上是不固定的,而定点数只能表示小数点固定的数值

window.location.href的用法(动态输出跳转)

javascript中的location.href有很多种用法,window.location.href 语句可以实现一个框架的页面在执行服务器端代码后刷新另一个框架的页面

js的解析的两个阶段_预解析阶段、执行阶段

js不像C语言那样只要编译一次之后成.exe文件之后就不用在编译可以直接使用了,js是一种解释型语言,js同理是边解析边执行。js的解析分为两个阶段 1.预解析阶段 2.执行阶段。

js秒数转换成时分秒_js如何将秒拼接为时分秒显示?

接口返回的是int类型的秒数,在前端显示要求拼接为时分秒显示,这篇文章主要讲解实现js秒数转换成时分秒的方法。

JavaScript中变量提升和函数提升的意义理解

在ES6之前,Js中是没有块级作用域的,只存在全局作用域和函数作用域。变量提升即将变量声明提升到它所在作用域的最开始的部分;函数提升只有函数声明中才发生。

JavaScript中公有、私有、静态、受保护的属性和方法

在开发中,我们需要限制某些属性和方法的暴露程度,使得它们不能通过对象实例本身被访问、修改或调用。要了解js面向对象,就必需先了解js中什么是公有、私有、静态、受保护。