要计算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小时内与您取得联系。