前序:我一直对于for跟for..in存在一种误解,我觉得for都能把事情都做了,为啥还要for...in...这玩意了,有啥用,所以今天就说说JavaScript里的循环语句。

循环

要计算1+2+3,我们可以直接写表达式:

但是当需要计算1+2+3+4+5......+10000,

如果通过表达式来写,估计我们会奔溃,

所以我们现在就可以使用循环(for)来搞定,

其实也很简单,javaScript的循环有两种,一种是for循环,通过初始条件、结束条件和递增条件来循环执行语句块:

这一种估计大家都很熟悉很熟悉。没啥疑问在工作中也会经常用到。那就简单点,代码如下

var x = 0;
var i;
for (i=1; i<=10000; i++) {
x = x + i;
}
x; //

因为这个大家比较熟悉就不说那么多了

让我们简单的来分析一下for循环的控制条件:

  • i=1 这是初始条件,将变量i置为1;
  • i<=10000 这是判断条件,满足时就继续循环,不满足就退出循环;
  • i++ 这是每次循环后的递增条件,由于每次循环后变量i都会加1,因此它终将在若干次循环后不满足判断条件i<=10000而退出循环。

那么接下来要好好说下的是for...in...,不知道大家是不是跟我一样,都很容易弄混这个。也许大家会嘲笑说,这么简单谁不懂啊。

for循环的一个变体是for ... in循环,它可以把一个对象的所有属性依次循环出来:

不多说,先看代码

var o = {
name: 'Jack',
age: 20,
city: 'Beijing'
};
for (var k in o) {
console.log(k); // 'name', 'age', 'city'
}

很简单吧,也很容易理解吧,k无非就是o对象里面的属性,那也就是我们刚刚在上面加粗的一个,把对象所有属性遍历出来。然后要对对象进行操作就很简单了。

那可能有人好奇,for...in...用来遍历数组应该也可以吧,

嗯,没错。是的没的问题。废话不多说

var a = ['A', 'B', 'C'];
for (var i in a) {
console.log(i); // '0', '1', '2'
console.log(a[i]); // 'A', 'B', 'C'
}

没错,就是这么简单,有人会说咋不一样了,你刚刚明明说是遍历对象的属性啊,咋现在又不一样了。

一切皆对象,没错,数组也是个对象,由于Array也是对象,它的每个元素的索引被视为对象的属性,因此,for ... in循环可以直接循环出Array的索引:

大家不要误解,不要出去就说,一切皆对象,见到漂亮的女生就说你是我对象,这就尴尬了嘛。

毕竟撸码的都知道此对象非彼对象。

while

for循环在已知循环的初始和结束条件时非常有用。而条件的for循环容易让人看不清循环的逻辑,此时用while循环更佳。

while循环只有一个判断条件,条件满足,就不断循环,条件不满足时则退出循环。比如我们要计算100以内所有奇数之和,可以用while循环实现:

var x = 0;
var n = 99;
while (n > 0) {
x = x + n;
n = n - 2;
}
x; //

在循环内部变量n不断自减,直到变为-1时,不再满足while条件,循环退出。

别人会问为啥n=99,这个嘛,看清题,是所有奇数的和,不是偶数哈。

do ... while

大家可能没怎么使用个这个,不过这玩意也是挺有用的

do { ... } while()循环,它和while循环的唯一区别在于,不是在每次循环开始的时候判断条件,而是在每次循环完成的时候判断条件:

var n = 0;
do {
n = n + 1;
} while (n < 100);
n; //

可能大家对es6更感兴趣,反而觉得这循环有啥说的,嗯,怎么说基础都很重要,有些知识点不能忽视。es6大家想了解的话,也可以跟我讨论,或者相了解更多前端知识啊,比如vuejs,nodejs等等,可以一起学习,一起进步,毕竟知识日新月异的,几乎每天都有新知识出来。工作中有啥有趣的都可以跟我分享,可能接下来会弄一个微信公众号。

公司最近可能要弄小程序,大家如果已经做过这方面项目可以指导下,毕竟很久没关注小程序这块了。现在需要重新去看看小程序api。

javascript里的循环语句的更多相关文章

  1. javascript里for循环的一些事情

    今天在给一个学妹调她的代码BUG时,她的问题就是在一个for循环里不清楚流程的具体流向,所以导致了页面怎么调都是有问题,嗯确实你如果不清楚语句流向很轻易就会出问题,所以说for循环不会用或者说用的不恰 ...

  2. JavaScript里的循环方法总结

    JavaScript诞生已经有20多年了,我们一直使用的用来循环一个数组的方法是这样的: for (var index = 0; index < myArray.length; index++) ...

  3. JavaScript里的循环方法之forEach,for-in,for-of

    JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型.它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标 ...

  4. JavaScript里的循环方法:forEach,for-in,for-of

    JavaScript诞生已经有20多年了,我们一直使用的用来循环一个数组的方法是这样的: for (var index = 0; index < myArray.length; index++) ...

  5. 你可能不知道的java、python、JavaScript以及jquary循环语句的区别

    一.概述 java循环语句分为四种形式,分别是 while, do/while, for, foreach: python中循环语句有两种,while,for: JavaScript中循环语句有四种, ...

  6. javascript语法之循环语句

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. javascript总结13:循环语句

    1 While循环 While(条件表达式){ 只要条件表达式结果为true,循环一直执行,当条件表达式结果为false的时候,循环终止 } While循环语句需现在循环体外定义变量. 2 for循环 ...

  8. JavaScript、for循环语句知识巩固,while(){}语句以及do{}while()语句以及switch()语句

    一.for循环语句练习 关于for循环存在的两个问题类型 穷举:在不知道什么情况下才真的寻要我们的结果,自能让我们一个个走一遍. 迭代:在现有的条件根据规律不断求解,中间情况,最终推测出来的结果 1. ...

  9. javascript系列-class3.循环语句

    欢迎加入前端交流群来py: 转载请标明出处! while循环   while(循环终止条件){       }   案例     输出0~100个数字  1 . 3 .  5 不输出   输出一百数字 ...

随机推荐

  1. Python-ORM之sqlalchemy的简单使用

    ORM之sqlalchemy 基础章节 使用SQLAlchemy链接数据库 from sqlalchemy import create_engine from sqlalchemy.ext.decla ...

  2. spring中自定义Event事件的使用和浅析

    在我目前接触的项目中,用到了许多spring相关的技术,框架层面的spring.spring mvc就不说了,细节上的功能也用了不少,如schedule定时任务.Filter过滤器. intercep ...

  3. vxworks for x86读取bios时间的解决方法

    vxworks for x86读取bios时间的解决方法 系统时间与bsp有关,在vzworks for x86系列的目标没有直接读取RTC(实时时钟控制器)的函数,用time.h中的函数读到的始终是 ...

  4. freemarker基本数据类型

    freemarker基本数据类型 1.基本数据类型 (1)字符串 (2)数字 (3)布尔值 (4)日期 2.展示示例 <html> <head> <meta http-e ...

  5. Linux显示以log结尾的日志文件

    Linux显示以log结尾的日志文件 youhaidong@youhaidong-ThinkPad-Edge-E545:~$ find -name "*.log" find: `. ...

  6. ubuntu14.04 64位 安装JDK1.7

    ubuntu14.04 64位 安装JDK1.7 1 新建文件夹 youhaidong@youhaidong:~$ sudo mkdir /usr/lib/jvm 2 解压文件 youhaidong@ ...

  7. web开发性能优化---数据库篇

    1. 查询出的数据量过大(可以采用多次查询,其他的方法降低数据量),尽量采取分页查询数据 2.锁或者死锁(这也是查询慢最常见的问题,是程序设计的缺陷) 3.返回了不必要的行和列 用OR的字句可以分解成 ...

  8. input【type="checkbox"】标签与字体对齐

    今天分享一个比较实用的技巧,在实际项目中我们会经常遇到表单的input标签多选和单选的问题,但是往往由于标签自身的样式和我们项目的风格很不搭调,就不能实现了,今天就来告诉大家怎么去实现吧. 第一种:利 ...

  9. java实现全排列问题

    1.问题描述: 一组字符串的全排列,按照全排列的顺序输出,并且每行结尾无空格. 2.输入: 输入一个字符串 3.输入示例: 请输入全排列的字符串: abc 4.输出示例: a b c a c b b ...

  10. WPF自学入门(三)WPF路由事件之内置路由事件

    有没有想过在.NET中已经有了事件机制,为什么在WPF中不直接使用.NET事件要加入路由事件来取代事件呢?最直观的原因就是典型的WPF应用程序使用很多元素关联和组合起来,是否还记得在WPF自学入门(一 ...