前端基础(八)_JavaScript循环(for循环、for-in循环、for-of循环、while、do-while 循环、break 与 continue)

简介: 本文介绍了JavaScript中的循环语句,包括for循环、for-in循环、for-of循环、while循环、do-while循环以及break和continue的使用。

让一段特定的代码执行指定的次数。

一、for循环

1.1、for的语法及简单使用

语法 :

for( 表达式 1;条件表达式 2;表达式 3){
    条件成立执行的代码块 }
for(初始化循环变量;判断条件(循环结束的条件);更新循环变量){
   
循环体
}

例1:控制台输出 1-20

for(var i = 1;i <= 20;i++){
   
    console.log(i);
}

在这里插入图片描述
上面的写法还可以这样写:

var i = 1
for(;i <= 20;){
   
    console.log(i);
    ++i
}

在这里插入图片描述

1.2、for循环的执行过程

for(var i = 1;i <= 10;i++){
   
    console.log(i);
}

上面的循环的执行过程为:
for(1. 初始化循环变量;2. 判断条件(循环结束的条件);4. 更新循环变量){
3. 循环体
}
执行步骤 :

  1. 初始化循环变量 i= 1;
  2. 判断,判断条件是否成立 1<=10;
    a. 条件成立,执行循环体,然后到第 3 步;
    b. 条件不成立,结束循环;
  3. 更新循环变量 i = i + 1;
  4. 回到第二步开始执行。
    循环三要素:初始化循环变量,跳出循环的条件,更新循环变量,在循环中必须有结
    束循环的条件,要更新循环变量,否则会成为死循环。

1.3、for循环操作标签

例:给所有的div标签都添加点击事件,并打印当前节点的内容

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>LiuQing</title>
  <style>
    #box {
   
      background-color: red;
    }
  </style>
</head>

<body>
  <div class="Liuqing"> Liuqing1 </div>
  <div class="Liuqing"> Liuqing2 </div>
  <div class="Liuqing"> Liuqing3 </div>
  <div class="Liuqing"> Liuqing4 </div>
  <div class="Liuqing"> Liuqing5 </div>

  <script>
    var Liuqing = document.querySelectorAll('.Liuqing')
    console.log(Liuqing, 'LiuqingLiuqing')
    // 这里目前先使用  let  声明变量
    for (let i = 0; i < Liuqing.length; i++) {
   
      Liuqing[i].onclick = function () {
   
        console.log(Liuqing[i], 'innerHTML')
      }
    }
  </script>
</body>

</html>

在这里插入图片描述
这里点击了Liuqing1、Liuqing3、Liuqing5。

例2:循环生成 10 个标签p添加到第一个div中

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>LiuQing</title>
  <style>
    #box {
   
      background-color: red;
    }
  </style>
</head>

<body>
  <div class="Liuqing"> Liuqing1 </div>
  <div class="Liuqing"> Liuqing2 </div>
  <div class="Liuqing"> Liuqing3 </div>
  <div class="Liuqing"> Liuqing4 </div>
  <div class="Liuqing"> Liuqing5 </div>

  <script>
    var Liuqing = document.querySelectorAll('.Liuqing')
    console.log(Liuqing, 'LiuqingLiuqing')
    // 这里目前先使用  let  声明变量
    for (let i = 0; i < Liuqing.length; i++) {
   
      Liuqing[i].onclick = function () {
   
        console.log(Liuqing[i], 'innerHTML')
      }
    }
    var box = Liuqing[0]
    var boxStr = ''
    for (let i = 0; i < 10; i++) {
   
      boxStr += '<p>我是p</>'
    }
    box.innerHTML = boxStr
  </script>
</body>

</html>

在这里插入图片描述
点击了Liuqing1、Liuqing2。

1.4、for循环嵌套 ( 双重 for 循环 )

例:实现下图所示图形
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>LiuQing</title>
  <style>
    #box {
   
      background-color: red;
    }
  </style>
</head>

<body>
  <div class="Liuqing"> Liuqing1 </div>
  <div class="Liuqing"> Liuqing2 </div>
  <div class="Liuqing"> Liuqing3 </div>
  <div class="Liuqing"> Liuqing4 </div>
  <div class="Liuqing"> Liuqing5 </div>

  <script>
    var Liuqing1 = document.getElementsByTagName("div")[0];
    Liuqing1.innerHTML = ''
    // 外循环控制行,内循环控制例
    for (var i = 0; i < 5; i++) {
   
      for (var j = 0; j <= i; j++) {
   
        Liuqing1.innerHTML += "*";
      }
      Liuqing1.innerHTML += "<br>";
    }
  </script>
</body>

</html>

在这里插入图片描述

二、for-in循环

for-in 循环是专门为循环对象设置的,因为对象没有长度没有顺序,所以不能使用for 循环。
如果真想的话我们可以使用Object.keys和Object.values获取在进行for循环,这个后续说。
for-in循环可以循环数组和对象,推荐循环对象的时候使用。

语法:

 for( var 键值 in 对象名){
   操作对象}
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>LiuQing</title>
  <style>
    #box {
   
      background-color: red;
    }
  </style>
</head>

<body>
  <div class="Liuqing"> Liuqing1 </div>

  <script>
    const obj = {
   
      name: "LiuQing",
      age: 18,
      sex: '男'
    }
    for (const key in obj) {
   
      console.log(key, "代表obj的属性:name,age,sex")
      console.log(obj[key], "代表obj的属性值:LiuQing,18,男")
    }
  </script>
</body>

</html>

在这里插入图片描述

三、for-of循环

for-of循环不能循环对象!!!,可以循环字符串、数组

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>LiuQing</title>
  <style>
    #box {
   
      background-color: red;
    }
  </style>
</head>

<body>
  <div class="Liuqing"> Liuqing1 </div>

  <script>
    let str = '我是六卿!'
    let arr = ['L', 'i', 'u', 'Q', 'i', 'n', 'g']
    for (const key of str) {
   
      console.log(key, '对应下边的值1')
    }
    console.log("==================")
    for (const key of arr) {
   
      console.log(key, '对应下边的值2')
    }
    console.log("==================")
    console.log(arr.join(''))
  </script>
</body>

</html>

在这里插入图片描述

四、while、do-while 循环

4.1、while

while 循环先判断后执行

例1:打印 1-20 的数字
var a = 1; // 初始化循环变量
while (a <= 20 ){ // 结束循环的条件
console.log(a);
a++; // 更新循环变量
}

执行步骤:初始化循环变量,判断条件,成立执行循环体,更新循环变量,判断条件,不成立结束。
在这里插入图片描述

4.2、do-while

跟 while 循环是一样的,只是 do-while 先执行,后判断。
例2:

var a = 0;
do {
   
console.log(a);
}while (a > 0);

两者的区别,只在第一次条件不成立的时候有区别,do-while 会执行一次,因为是先执行后判断。
在这里插入图片描述

五、break 与 continue

break 与 continue 都是在循环中,中止循环的操作。break 是结束循环,后面的循环都不再执行。continue 是结束本次循环,即本次循环中 continue 以后代码都不再执行,直接执行下一次循环。

break:终止当前循环体;
continue:跳出本次循环,继续下次循环;

例1:获取到数组中第一个偶数能被 2 整除

    var arr = [1, 6, 9, 3, 4, 7, 5];
    for (var k = 0; k < arr.length; k++) {
    // 遍历
      if (arr[k] % 2 === 0) {
   
        console.log(arr[k]);
        // 在中途结束循环
        // break; // 跳出循环 ( 结束循环 )
        continue;// 跳出本次循环 本次循环这行代码后面的语句不再执行,直接执行下一次循环
      }
    }

continue:
在这里插入图片描述
break:
在这里插入图片描述
以前写的:
JS循环for、for…of、for…in

目录
相关文章
|
2月前
|
JavaScript 前端开发
JS循环for、for...of、for...in
本文介绍了JavaScript中不同的循环语句,包括传统的`for`循环、`for...of`循环用于遍历数组和类数组对象、`for...in`循环用于遍历对象的属性,并通过示例代码展示了它们的用法和区别。
45 6
JS循环for、for...of、for...in
|
1月前
|
JavaScript 前端开发
js循环有几种
js循环有几种
32 0
|
18天前
|
JavaScript
js动画循环播放特效源码(上班族的一天)
js动画循环播放特效是一段实现了包含形象的卡通小人吃、睡、电脑工作的网页动画,js循环动画,简单的画面设计。非常丝滑有意思,欢迎对此代码感兴趣的朋友前来下载参考。
27 2
|
2月前
|
JavaScript 前端开发 索引
|
1月前
|
JavaScript
自动循环提交js
自动循环提交js
17 0
|
1月前
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
133 2
|
1月前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
43 0
|
1月前
|
人工智能 自然语言处理 运维
前端大模型应用笔记(一):两个指令反过来说大模型就理解不了啦?或许该让第三者插足啦 -通过引入中间LLM预处理用户输入以提高多任务处理能力
本文探讨了在多任务处理场景下,自然语言指令解析的困境及解决方案。通过增加一个LLM解析层,将复杂的指令拆解为多个明确的步骤,明确操作类型与对象识别,处理任务依赖关系,并将自然语言转化为具体的工具命令,从而提高指令解析的准确性和执行效率。
|
1月前
|
存储 弹性计算 算法
前端大模型应用笔记(四):如何在资源受限例如1核和1G内存的端侧或ECS上运行一个合适的向量存储库及如何优化
本文探讨了在资源受限的嵌入式设备(如1核处理器和1GB内存)上实现高效向量存储和检索的方法,旨在支持端侧大模型应用。文章分析了Annoy、HNSWLib、NMSLib、FLANN、VP-Trees和Lshbox等向量存储库的特点与适用场景,推荐Annoy作为多数情况下的首选方案,并提出了数据预处理、索引优化、查询优化等策略以提升性能。通过这些方法,即使在资源受限的环境中也能实现高效的向量检索。
|
1月前
|
机器学习/深度学习 弹性计算 自然语言处理
前端大模型应用笔记(二):最新llama3.2小参数版本1B的古董机测试 - 支持128K上下文,表现优异,和移动端更配
llama3.1支持128K上下文,6万字+输入,适用于多种场景。模型能力超出预期,但处理中文时需加中英翻译。测试显示,其英文支持较好,中文则需改进。llama3.2 1B参数量小,适合移动端和资源受限环境,可在阿里云2vCPU和4G ECS上运行。
下一篇
无影云桌面