当前位置: 首页 > news >正文

javascript 流程控制,数组【知识点整理】

javascript

    • JS 流程控制
      • 条件控制语句
      • 循环语句
      • 跳转语句:
      • 异常处理:
    • JS 数组
      • 数组的方法

JS 流程控制

条件控制语句

  • if 语句:用于在满足特定条件时执行代码块。

    if (condition) {// 如果条件为真,则执行代码块
    }
    
  • if…else 语句:在条件为真时执行一段代码,条件为假时执行另一段代码。

    if (condition) {// 如果条件为真,则执行代码块
    } else {// 如果条件为假,则执行代码块
    }
    
  • if…else if…else 语句:用于多个条件的判断。

    if (condition1) {// 如果条件1为真,则执行代码块
    } else if (condition2) {// 如果条件1为假且条件2为真,则执行代码块
    } else {// 如果条件1和条件2都为假,则执行代码块
    }
    
  • switch 语句:用于多个条件的判断,比多个 if…else 更清晰。

    switch (expression) {case value1:// 如果表达式等于value1,则执行代码块break;case value2:// 如果表达式等于value2,则执行代码块break;// ...default:// 如果表达式不等于任何case的值,则执行代码块
    }
    

循环语句

  • for循环:用于在满足特定条件时重复执行代码块。

    for (initialization; condition; final-expression) {// 代码块
    }
    

    打印二维表格:

    document.write("<table border='1'>");for(var i = 0; i<4 ;i++){document.write("<tr>");for(var j = 0 ;j<8 ; j++){document.write("<td>第"+(i+1)+"行</td>")}document.write("</tr>");}document.write("</table>");
    

    九九乘法表:

     for(var i = 1 ; i < 10 ; i++){for(var j = 1 ; j<=i ;j++){document.write("&nbsp"+j +"*"+ i +"="+ (i*j));}document.write("<br/>")}
    
  • while循环:当条件为真时重复执行代码块。

    while (condition) {// 代码块
    }
    
  • do…while 循环:至少执行一次代码块,然后检查条件是否为真,如果为真则继续循环。

    do {// 代码块
    } while (condition);
    
  • for…in 循环:遍历对象的属性。

    for (variable in object) {// 代码块
    }
    
  • for…of 循环:遍历可迭代对象(如数组、字符串等)的值。

    for (value of iterable) {// 代码块
    }
    

跳转语句:

  • break 语句:终止 switch 语句或循环的执行。
  • continue 语句:跳过当前循环的剩余代码,并开始下一次迭代。
  • return 语句:从函数中返回一个值,并终止函数的执行。
  • throw 语句:抛出一个错误,终止程序的执行。

异常处理:

  • try 块:尝试执行代码块。
  • catch 块:如果 try 块中抛出错误,则执行 catch 块。
  • finally 块:无论是否抛出错误,都会执行 finally 块中的代码。
try {// 尝试执行的代码块
} catch (error) {// 如果try块中抛出错误,则执行catch块
} finally {// 无论是否抛出错误,都会执行finally块
}

JS 数组

JavaScript中的数组是一种特殊的对象,用于存储多个值的有序集合。数组可以包含任意类型的值,包括数字、字符串、对象、函数,甚至是其他数组。以下是一些常用的数组操作方法:

  1. 创建数组

    var arr = new Array(); // 空数组
    arr[0] = "lee";  //赋值
    arr[1] = 12;var arr = new Array(10); // 长度为10的数组,初始值为undefined
    var arr = [1, 'Kimi', true, {name: 'Moonshot'}];
    
  2. 访问数组元素

    var arr = ['a', 'b', 'c'];
    console.log(arr[0]); // 输出 'a'
    
  3. 数组长度

    var arr = ['a', 'b', 'c'];
    console.log(arr.length); // 输出 3
    

数组的方法

  1. 添加元素

    push():在数组末尾添加一个或多个元素,并返回新的长度。
    unshift():在数组开头添加一个或多个元素,并返回新的长度。

    javascript

    var arr = [1, 2];
    arr.push(3); // [1, 2, 3]
    arr.unshift(0); // [0, 1, 2, 3]
    
  2. 删除元素

    pop():删除数组的最后一个元素,并返回被删除的元素。
    shift():删除数组的第一个元素,并返回被删除的元素。

    var arr = [1, 2, 3];
    arr.pop(); // [1, 2]
    arr.shift(); // [2]
    
  3. 遍历数组

    forEach():对数组中的每个元素执行一次提供的函数。
    map():创建一个新数组,其结果是该数组中的每个元素是调用一次提供的函数后的返回值。
    filter():创建一个新数组,包含通过所提供函数实现的测试的所有元素。
    reduce():对数组中的值进行汇总,将其减少为单个返回值。

    var arr = [1, 2, 3, 4];
    arr.forEach((item, index) => console.log(item, index)); // 遍历数组
    let squares = arr.map(item => item * item); // [1, 4, 9, 16]
    var even = arr.filter(item => item % 2 === 0); // [2, 4]
    var sum = arr.reduce((accumulator, currentValue) => accumulator + currentValue, 0); // 10
    
  4. 数组排序

    sort():对数组元素进行排序。

    var arr = [4, 2, 5, 1, 3];
    arr.sort((a, b) => a - b); // [1, 2, 3, 4, 5]
    
  5. 数组查找

    indexOf():返回在数组中可以找到一个给定元素的第一个索引,如果不存在,则返回-1。
    lastIndexOf():返回在数组中可以找到一个给定元素的最后一个索引,如果不存在,则返回-1。

    let arr = [1, 2, 3, 4, 5];
    console.log(arr.indexOf(3)); // 2
    console.log(arr.lastIndexOf(3)); // 2
    
  6. 数组合并

    concat():用于合并两个或多个数组。

    var arr1 = [1, 2];
    var arr2 = [3, 4];
    var combined = arr1.concat(arr2); // [1, 2, 3, 4]
    
  7. 数组切片

    slice():提取原数组的片段,并返回一个新的数组。

    var arr = ['a', 'b', 'c', 'd', 'e'];
    var sliced = arr.slice(1, 3); // ['b', 'c']
    

这些是JavaScript数组的一些基本操作。数组是JavaScript中非常强大的数据结构,支持许多其他方法和操作。

   <script>// 冒号排序// var arr = [46,24,50,35,17,98];// for(var i = 0; i<=arr.length-1 ; i++){//     for(var j = 0 ; j<arr.length-i ; j++){//         if(arr[j]>arr[j+1]){//             var temp = arr[j];//             arr[j] = arr[j+1];//             arr[j+1] = temp;//         }//     }// }// console.log(arr);// 选择排序// var arr = [7,5,6,3,9,10,100,26,6];// var minIndex ,temp;// for(var i = 0 ; i<arr.length-1 ; i++){//     minIndex = i;//     for(var j = i+1 ; j<arr.length; j++){//         if(arr[minIndex]>arr[j]){//             minIndex = j;//         }//     }//     temp = arr[i];//     arr[i] = arr[minIndex];//     arr[minIndex] = temp;// }// console.log(arr)// 判断字符串中那个字符出现的最多和次数// var str = "jahdjaskkkkkkkkkkkkkkkk;;pkmAss";// var obj = {};// for(var i = 0 ; i < str.length ; i++){//     if(!obj[str[i]]){//         obj[str[i]] = 1;//     }else{//         obj[str[i]]++;//     }// }// console.log(obj);// var word = "";// var count = 0;// for(var key in obj){//     if(count<obj[key]){//         count = obj[key];//         word = key;//     }// }// console.log("出现最多的字符:"+word+"  出现次数:"+count);//数组去重// var arr = ["e",1,4,2,1,"e",6,"bb"]// var obj = {};// for(var i = 0 ; i<arr.length ;i++){//     obj[arr[i]] = "";// }// arr = [];// var i = 0;// for(var k in obj){//     arr[i] = isNaN(k)? k: Number(k);//     i++;// }// console.log(arr);<!--输出数组中两个值的和为目标值的下标-->// var arr = [1,2,4,6,7,3];// var indexs = [];// var target = 10;// var flag = false;// for(var i = 0 ; i<arr.length ; i++){//     for(var j = 0 ; j<arr.length ; j++){//         if(arr[i]+arr[j] == target){//             indexs = [i,j];//             flag = true;//             break;//         }//     }//     if(flag == true) break;// }// console.log(indexs);// 法二var arr = [1,2,4,6,7,2];target = 10;obj = {};indexs = [];for(var i = 0 ; i<arr.length ; i++){if(obj[arr[i]] === undefined){var x = target - arr[i];obj[x] = i;}else{indexs = [obj[x],i];}} console.log(indexs);</script>

相关文章:

javascript 流程控制,数组【知识点整理】

javascript JS 流程控制条件控制语句循环语句跳转语句&#xff1a;异常处理&#xff1a; JS 数组数组的方法 JS 流程控制 条件控制语句 if 语句&#xff1a;用于在满足特定条件时执行代码块。 if (condition) {// 如果条件为真&#xff0c;则执行代码块 }if…else 语句&#x…...

2.索引:SQL 性能分析详解

SQL性能分析是数据库优化中重要的一环。通过分析SQL的执行频率、慢查询日志、PROFILE工具以及EXPLAIN命令&#xff0c;能够帮助我们识别出数据库性能的瓶颈&#xff0c;并做出有效的优化措施。以下将详细讲解这几种常见的SQL性能分析工具和方法。 一、SQL 执行频率 SQL执行频率…...

Flink SQL

进入 JobManager 容器&#xff1a; docker exec -it 21442d9ca797 /bin/bash 启动 Flink 的 SQL 客户端&#xff1a; /opt/flink/bin/sql-client.sh embedded 尝试创建 Kafka 表&#xff1a; 在启动的 SQL 客户端中&#xff0c;尝试创建一个 Kafka 表&#xff0c;看看是否能…...

鸿蒙UI开发——实现环形文字

1、背 景 有朋友提问&#xff1a;您好关于鸿蒙UI想咨询一个问题 如果我想实现展示环形文字是需要通过在Text组件中设置transition来实现么&#xff0c;还是需要通过其他方式来实现。 针对这位粉丝朋友的提问&#xff0c;我们做一下解答。 2、实现环形文字效果 ❓ 什么是环形…...

QT版发送邮件程序

简单的TCP邮箱程序 **教学与实践目的&#xff1a;**学会网络邮件发送的程序设计技术。 1.SMTP协议 邮件传输协议包括 SMTP&#xff08;简单邮件传输协议&#xff0c;RFC821&#xff09;及其扩充协议 MIME&#xff1b; 邮件接收协议包括 POP3 和功能更强大的 IMAP 协议。 服务…...

JavaSE:初识Java(学习笔记)

java是高级语言的面向对象语言 .[最贴近生活.最快速分析和设计程序] 一&#xff0c;计算机语言发展历史 二&#xff0c;Java体系结构 1&#xff0c;JavaSE&#xff08;Java Standard Edition&#xff09; 标准版&#xff0c;定位在个人计算机上的应用 这个版本是Jav…...

ClickHouse创建分布式表

ClickHouse创建分布式表 当数据量剧增的时候&#xff0c;clickhouse是采用分片的方式进行数据的存储的&#xff0c;类似于redis集群的实现方式。然后想进行统一的查询的时候&#xff0c;因为涉及到多个本地表&#xff0c;可以通过分布式表的方式来提供统一的入口。由于是涉及到…...

Flink转换算子

Apache Flink 是一个用于处理无界和有界数据的开源流处理框架。在 Flink 中&#xff0c;转换&#xff08;Transformation&#xff09;是数据流处理的核心组件之一&#xff0c;它们定义了如何从输入数据集生成输出数据集。以下是 Flink 中一些常见的转换算子&#xff1a; Map: 将…...

ThinkBook 14+ 2024 Ubuntu 触控板失效 驱动缺失问题解决

首先我的电脑是thinkbook14 2024&#xff0c;从ubuntu18到ubuntu24&#xff0c;笔者整个都试了一遍&#xff0c;触摸板都没反应&#xff0c;确认不是linux系统内核问题&#xff0c;原因为驱动缺失。 解决步骤&#xff1a; &#xff08;1&#xff09;下载驱动&#xff0c;网址如…...

【青牛科技】应用方案 | D75xx-150mA三端稳压器

概 述 D75XX系列是一套三端高电流低压稳压器。它们可以提供 150mA 的输出电流和允许输入电压高达30V。它们有几个固定的输出电压范围为3.0 V至5.0 V。CMOS 技术确保低电压降和低静态电流。 虽然这些设备主要设计为固定电压调节器&#xff0c;但它们可以与外部元件一起使用&…...

WPF之iconfont(字体图标)使用

1&#xff0c;前文&#xff1a; WPF的Xaml是与前端的Html有着高度相似性的标记语言&#xff0c;所以Xaml也可同Html一般轻松使用阿里提供的海量字体图标&#xff0c;从而有效的减少开发工作度。 2&#xff0c;下载字体图标&#xff1a; 登录阿里图标库网iconfont-阿里巴巴矢量…...

08、Java学习-面向对象中级:

Java学习第十二天——面向对象中级&#xff1a; IDEA&#xff1a; 创建完新项目后&#xff0c;再src里面创建.java文件进行编写。 src——存放源码文件&#xff08;.java文件&#xff09;&#xff1b;out——存放编译后的字节码文件&#xff08;.class文件&#xff09; 在I…...

springboot集成onlyoffice(部署+开发)

前言 最近有个项目需求是实现前端页面可以对word文档进行编辑&#xff0c;并且可以进行保存&#xff0c;于是一顿搜索&#xff0c;找到开源第三方onlyoffice&#xff0c;实际上onlyOffice有很多功能&#xff0c;例如文档转化、多人协同编辑文档、文档打印等&#xff0c;我们只用…...

LabVIEW编程基础教学(二)--数据类型

在LabVIEW中&#xff0c;数据类型是非常重要的基本概念&#xff0c;因为它们决定了如何存储和操作数据。掌握这些基础数据类型对于编写有效的程序非常关键。以下是LabVIEW中的基础数据类型介绍&#xff1a; 1. 数值类型&#xff08;Numeric&#xff09; 整型&#xff08;Inte…...

「Mac畅玩鸿蒙与硬件29」UI互动应用篇6 - 多选问卷小应用

本篇将带你实现一个多选问卷小应用&#xff0c;用户可以勾选选项并点击提交按钮查看选择的结果。通过本教程&#xff0c;你将学习如何使用 Checkbox 组件、动态渲染列表、状态管理及用户交互&#xff0c;构建完整的应用程序。 关键词 UI互动应用Checkbox 组件状态管理动态列表…...

Flutter中文字体设置指南:打造个性化的应用体验

在使用Flutter进行开发时&#xff0c;可能会遇到中文字体显示不正常或者字体不符合设计需求的情况。Flutter默认的中文字体往往无法满足某些用户对个性化和美观的需求。今天&#xff0c;我们就来详细探讨如何在Flutter应用中设置中文字体&#xff0c;并结合不同场景提供相应的解…...

git下载慢下载不了?Git国内国外下载地址镜像,git安装视频教程

git安装下载的视频教程在这 3分钟完成git下载和安装&#xff0c;git国内外下载地址镜像&#xff0c;Windows为例_哔哩哔哩_bilibili 一、Git安装包国内和国外下载地址镜像 1.1国外官方下载地址 打开Git的官方网站&#xff1a;Git官网下载页面。在页面上选择对应的系统&…...

安卓属性动画插值器(Interpolator)详解

属性动画&#xff08;Property Animation&#xff09;是 Android 中一个强大的动画框架&#xff0c;允许开发者对视图的任意属性&#xff08;如位置、透明度、尺寸、颜色等&#xff09;进行平滑的动态变化。插值器&#xff08;Interpolator&#xff09;作为属性动画的一部分&am…...

OSPF总结

1.定义及相关信息 (1)全称:Open ShortestPath First,开放式最短路径优先 (2)是一种基于链路状态算法的路由协议 (3)目前针对IPv4协议使用的是OSPF Version2(RFC2328) 目前针对IPv6 协议使用的是 OSPF Version3 ( RFC2740 ) (4)运行 OSPF 路由器之间…...

Spring Boot驱动的多维分类知识管理系统

1 绪论 1.1 研究背景 在这个推荐个性化的时代&#xff0c;采用新技术开发一个多维分类的知识管理系统来分享和展示内容是一个永恒不变的需求。本次设计的多维分类的知识管理系统有管理员和用户两个角色。 管理员可以管理用户信息&#xff0c;知识分类&#xff0c;知识信息等&am…...

运维老鸟复盘:一次CentOS7物理机安装踩坑全记录(从RAID0到安装源验证)

运维实战&#xff1a;CentOS7物理机安装全流程避坑指南 引言 那台尘封已久的联想RD550服务器静静躺在仓库角落&#xff0c;表面覆盖着一层薄灰。作为运维工程师&#xff0c;我们总会遇到这样的挑战——老旧设备突然需要重新部署系统。这次任务看似简单&#xff1a;为这台双盘…...

信息量模型避坑指南:用ArcGIS做地灾评价,这3个细节错了全盘皆输

信息量模型避坑指南&#xff1a;用ArcGIS做地灾评价&#xff0c;这3个细节错了全盘皆输 地质灾害易发性评价是地质工程领域的核心课题之一。在山区开发、城市规划等场景中&#xff0c;准确预测地质灾害风险区域&#xff0c;能够为防灾减灾提供科学依据。信息量模型因其计算简单…...

C语言字符串处理算法:反转、回文检测等实用技巧终极指南

C语言字符串处理算法&#xff1a;反转、回文检测等实用技巧终极指南 【免费下载链接】c Implementation of All ▲lgorithms in C Programming Language 项目地址: https://gitcode.com/gh_mirrors/c3/c 你是否在寻找C语言字符串处理的高效方法&#xff1f;&#x1f914…...

如何判断孩子是否适合学GESP

判断孩子是否适合学GESP&#xff0c;核心是看年龄、兴趣、逻辑能力与长期目标是否匹配‌。以下是结合当前&#xff08;2026年&#xff09;政策与实践的系统性判断标准&#xff1a; 一、适龄范围&#xff1a;6–18岁&#xff0c;但分阶段更关键 年龄段 是否适合 说明 ‌6–9岁…...

第5章 集群初始化

本章说明: 集群初始化是 Kubernetes 部署过程中最核心的一步。本章使用 kubeadm 在 master01 节点上初始化高可用集群控制平面。初始化时需要指定 VIP(192.168.3.59:6443)作为控制平面统一入口,这样后续加入的其他 Master 节点和 Worker 节点都通过 VIP 访问 API Server,…...

技术Leader的“预期管理”艺术:承诺80分,交付100分

在软件测试领域&#xff0c;我们擅长用技术手段管理缺陷、管理风险&#xff0c;却常常忽略一项更重要的软技能——管理上级的预期。许多测试Leader带着一身硬本领走上管理岗位&#xff0c;却在“预期差”上栽了跟头&#xff1a;明明团队加班加点测出了所有P0级缺陷&#xff0c;…...

终极指南:3分钟掌握Mouse Jiggler鼠标模拟器完整使用方法

终极指南&#xff1a;3分钟掌握Mouse Jiggler鼠标模拟器完整使用方法 【免费下载链接】mousejiggler Mouse Jiggler is a very simple piece of software whose sole function is to "fake" mouse input to Windows, and jiggle the mouse pointer back and forth. …...

Arm MPS3 FPGA开发板LED闪烁控制实战

1. 项目概述在嵌入式系统开发领域&#xff0c;FPGA&#xff08;现场可编程门阵列&#xff09;因其可重构特性成为硬件原型设计的首选平台。Arm MPS3 FPGA开发板作为一款功能强大的原型验证工具&#xff0c;为开发者提供了从算法验证到系统集成的完整解决方案。本次我们将通过经…...

基于Milvus混合检索与Java SpringBoot的全栈实现

阿里云有数千份产品文档&#xff0c;腾讯云有上万页技术规格&#xff0c;华为云的价格清单每天都在更新&#xff0c;开发者如何在浩如烟海的资料中&#xff0c;3秒内找到“ECS g6.2xlarge在华东区的按量计费价格”&#xff1f;传统关键词搜索解决不了语义理解&#xff0c;纯向量…...

NoFences:你的Windows桌面整理革命,告别杂乱无章的终极方案

NoFences&#xff1a;你的Windows桌面整理革命&#xff0c;告别杂乱无章的终极方案 【免费下载链接】NoFences &#x1f6a7; Open Source Stardock Fences alternative 项目地址: https://gitcode.com/gh_mirrors/no/NoFences 你是否每天都要在几十个图标中寻找需要的应…...