全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript循环_动力节点Java学院整理

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

1 + 2 + 3; // 6

要计算1+2+3+...+10,勉强也能写出来。
但是,要计算1+2+3+...+10000,直接写表达式就不可能了。
为了让计算机能计算成千上万次的重复运算,我们就需要循环语句。
JavaScript的循环有两种,一种是for循环,通过初始条件、结束条件和递增条件来循环执行语句块:

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

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

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

练习

利用for循环计算1 * 2 * 3 * ... * 10的结果。

for循环最常用的地方是利用索引来遍历数组:

var arr = ['Apple', 'Google', 'Microsoft'];
var i, x;
for (i=0; i<arr.length; i++) {
  x = arr[i];
  alert(x);
}

for循环的3个条件都是可以省略的,如果没有退出循环的判断条件,就必须使用break语句退出循环,否则就是死循环:

var x = 0;
for (;;) { // 将无限循环下去
  if (x > 100) {
    break; // 通过if判断来退出循环
  }
  x ++;
}

for ... in

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

var o = {
  name: 'Jack',
  age: 20,
  city: 'Beijing'
};
for (var key in o) {
  alert(key); // 'name', 'age', 'city'
}

要过滤掉对象继承的属性,用hasOwnProperty()来实现:

var o = {
  name: 'Jack',
  age: 20,
  city: 'Beijing'
};
for (var key in o) {
  if (o.hasOwnProperty(key)) {
    alert(key); // 'name', 'age', 'city'
  }
}

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

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

请注意,for ... in对Array的循环得到的是String而不是Number。

while

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

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

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

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

do ... while

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

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

do { ... } while()循环要小心,循环体会至少执行1次,而for和while循环则可能一次都不执行。

练习

请利用循环遍历数组中的每个名字,并显示Hello, xxx!

请尝试for循环和while循环,并以正序、倒序两种方式遍历。

小结

循环是让计算机做重复任务的有效的方法,有些时候,如果代码写得有问题,会让程序陷入“死循环”,也就是永远循环下去。JavaScript的死循环会让浏览器无法正常显示或执行当前页面的逻辑,有的浏览器会直接挂掉,有的浏览器会在一段时间后提示你强行终止JavaScript的执行,因此,要特别注意死循环的问题。

在编写循环代码时,务必小心编写初始条件和判断条件,尤其是边界值。特别注意i < 100和i <= 100是不同的判断逻辑。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# js  # 循环  # js数组循环遍历数组内所有元素的方法  # Js setInterval与setTimeout(定时执行与循环执行)的代码(可以传入参数)  # JS数组的遍历方式for循环与for...in  # js 数组的for循环到底应该怎么写?  # javascript 循环读取JSON数据的代码  # js和jquery中循环的退出和继续下一个循环  # JavaScript中循环遍历Array与Map的方法小结  # javaScript如何跳出多重循环break、continue  # javascript forEach通用循环遍历方法  # javascript下for循环用法小结  # 这是  # 是在  # 不满足  # 遍历  # 会让  # 的是  # 都是  # 让人  # 都不  # 尤其是  # 让我们  # 就不  # 也能  # 两种  # 可以用  # 会在  # 我们可以  # 如果没有  # 可以直接  # 只有一个 


相关文章: 如何快速重置建站主机并恢复默认配置?  如何快速搭建安全的FTP站点?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  如何注册花生壳免费域名并搭建个人网站?  如何快速完成中国万网建站详细流程?  建站OpenVZ教程与优化策略:配置指南与性能提升  制作门户网站的参考文献在哪,小说网站怎么建立?  如何快速查询网站的真实建站时间?  网页设计网站制作软件,microsoft office哪个可以创建网页?  企业网站制作公司网页,推荐几家专业的天津网站制作公司?  模具网站制作流程,如何找模具客户?  如何在自有机房高效搭建专业网站?  c# 服务器GC和工作站GC的区别和设置  如何快速搭建高效简练网站?  如何使用Golang table-driven基准测试_多组数据测量函数效率  行程制作网站有哪些,第三方机票电子行程单怎么开?  如何选择高效稳定的ISP建站解决方案?  nginx修改上传文件大小限制的方法  广东企业建站网站优化与SEO营销核心策略指南  建站之星CMS五站合一模板配置与SEO优化指南  ,怎么用自己头像做动态表情包?  Python如何创建带属性的XML节点  建站主机选哪家性价比最高?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  建站之星安装模板失败:服务器环境不兼容?  如何选择域名并搭建高效网站?  微课制作网站有哪些,微课网怎么进?  网站制作企业,网站的banner和导航栏是指什么?  如何挑选高效建站主机与优质域名?  网站制作模板下载什么软件,ppt模板免费下载网站?  建站主机解析:虚拟主机配置与服务器选择指南  如何快速生成凡客建站的专业级图册?  如何快速搭建虚拟主机网站?新手必看指南  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  如何零基础开发自助建站系统?完整教程解析  如何基于云服务器快速搭建网站及云盘系统?  简历在线制作网站免费,免费下载个人简历的网站是哪些?  MySQL查询结果复制到新表的方法(更新、插入)  如何快速辨别茅台真假?关键步骤解析  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  建站之星代理商如何保障技术支持与售后服务?  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  如何快速使用云服务器搭建个人网站?  小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  陕西网站制作公司有哪些,陕西凌云电器有限公司官网?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  微信小程序 五星评分(包括半颗星评分)实例代码  高端云建站费用究竟需要多少预算? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。