SAP Fiori开发中的JavaScript基础知识8 - 分支,循环,函数,高阶函数

1. 前言

JavaScript中分支和循环的概念和ABAP中类似,在此仅给出了语法和简单的示例。本文将着重介绍JavaScript中的“一等公民” - 函数Function。

2. 分支

在JavaScript中,实现条件分支的语法有三种,分别是if, swtich和三元表达式。

2.1 if…else

它们的语法如下:

if( ){

}
else if ( ) {

}
else{

}

2.2 switch

switch ( ) {
case 1:
break;
case 2:
break;
default:
break;
}

2.3 三元表达式

三元表达式: var result = (iNum < 0) ? “Negative” : “Positive”

2.4 示例代码:

let num = 10;

if (num > 10) {
    console.log('num is greater than 10');
} else if (num < 10) {
    console.log('num is less than 10');
} else {
    console.log('num is equal to 10');
}

switch (num) {
    case num > 10:
        console.log('num is greater than 10');
        break;
    case num < 10:
        console.log('num is less than 10');
        break;
    default:
        console.log('num is equal to 10');
        break;
}

let result = (num < 0) ? "Negative" : "Positive";
console.log(result);  // 输出 Positive

3. 循环

在JavaScript中,实现循环有三种方式,分别是for, while和do-while。

2.1 for

它们的语法如下:

for (var i = 0 ; i < 5; i ++){

}

遍历对象属性
for (var prop in obj){

}

遍历数组内容
for (var item of arr){

}

示例代码:

let obj = {
    key1: 'value1',
    key2: 'value2',
    key3: function () { },
    key4: ['content1', 'content2']
};

let arr = ['item1', 'item2'];

for (let i = 0; i < 5; i++) {
    console.log(i);
}

for (prop in obj) {
    console.log(prop);
}

for (item of arr) {
    console.log(item);
}

2.2 while, do-while

示例代码:

let i = 0;

while (i < 5) {
    console.log(i);
    i++;
}

do {
    console.log(i);
    i++;
} while (i < 10);

4. 函数

在JavaScript中,函数是一种可重用的代码块,可以接受输入(参数),并返回输出(结果)。函数可以使代码更易于阅读和维护,同时避免重复。

对于传统的ABAP开发人员,要注意区分JavaScript中函数的概念与ABAP中的function概念在设计上的不同。

  1. JavaScript中的函数也是一种 值类型。函数的输入,输出参数都也可以是函数。
  1. JavaScript函数只能有一个返回值。但是,如果你需要返回多个值,你可以通过返回一个对象或数组来实现。
  1. JavaScript中函数的输入参数、输出参数都没有类型的(变量无类型)
  1. JavaScript的函数调用时,并不要求输入所有的参数

4.1 函数的声明

函数使用function关键字声明,后跟函数名称和括号内的参数列表。函数体(即要执行的代码)包含在大括号中。

function greet(name) {
    return "Hello, " + name;
}

在上述代码中,greet是一个接受一个参数name的函数,返回一个字符串。

4.2 函数的调用

要调用(或执行)函数,使用函数名称后跟括号和要传递的参数。

let message = greet("Alice");
console.log(message);  // 输出 "Hello, Alice"

4.3 匿名函数和函数表达式

函数也可以是匿名的,即没有名称。这些通常用作函数表达式,或者作为其他函数的参数(如回调函数)。

let greet = function(name) {
    return "Hello, " + name;
}

console.log(greet("Bob"));  // 输出 "Hello, Bob"

4.4 箭头函数

ES6引入了箭头函数,这是创建函数的更简洁的语法。

let greet = (name) => {
    return "Hello, " + name;
}

console.log(greet("Charlie"));  // 输出 "Hello, Charlie"

如果箭头函数只有一个参数并且函数体只有一行,那么可以省略括号和return关键字:

let greet = name => "Hello, " + name;

console.log(greet("Dave"));  // 输出 "Hello, Dave"

4.5 复杂函数设计

4.5.1 返回对象 / 数组

例如,如果你想返回多个值,你可以将它们放在一个对象中:

function getSize(width, height, depth) {
    let area = width * height;
    let volume = width * height * depth;
    let sizes = {'area': area, 'volume': volume};
    return sizes;
}

let result = getSize(3, 2, 3);
console.log(result.area);   // 输出 6
console.log(result.volume); // 输出 18

在上述代码中,getSize函数返回一个包含area和volume属性的对象。

或者,你也可以将它们放在一个数组中:

function getSize(width, height, depth) {
    let area = width * height;
    let volume = width * height * depth;
    return [area, volume];
}

let result = getSize(3, 2, 3);
console.log(result[0]); // 输出 6
console.log(result[1]); // 输出 18

在这个例子中,getSize函数返回一个包含area和volume的数组。

4.5.2 高阶函数(输入参数/输出也为函数)

JavaScript中的函数可以接受其他函数作为参数。这种类型的函数通常被称为高阶函数

以下是一个例子,其中一个函数接受另一个函数作为参数:


function greet(name) {
    return "Hello, " + name;
}

function shout(func, name) {
    let message = func(name);
    console.log(message);
}

shout(greet, "Alice");  // 输出 "Hello, Alice"

在上述代码中,shout函数接受两个参数:一个函数func和一个字符串name。shout函数调用func函数,将name作为参数。

这种模式在JavaScript中非常常见,特别是在处理异步操作(如网络请求)或在数组方法(如map,filter和reduce)中时。

以下是一个例子,其中一个函数返回另一个函数:

function createGreet(name){
    return function(){
        return "Hello," + name;
    }
}

let greetAlice = createGreet("Alice");
console.log(greetAlice()); // 输出 "Hello, Alice"

在上述代码中,createGreeting函数接受一个参数name,并返回一个新的函数。这个新的函数在被调用时会打印一条问候语。

这种模式在JavaScript中非常常见,特别是在函数式编程和闭包中。

4 小结

本文介绍了JavaScript中分支和循环的语法,同时详细介绍了函数的概念,并比较了与ABAP语言中Function概念的异同。希望对你有帮助!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/499257.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AcWing 4609:火柴棍数字 ← 贪心算法

【题目来源】 https://www.acwing.com/problem/content/4612/【题目描述】 给定 n 个火柴棍&#xff0c;你可以用它们摆出数字 0∼9。 摆出每个数字所需要的具体火柴棍数量如下图所示&#xff1a; 请你用这些火柴棍摆成若干个数字&#xff0c;并把这些数字排成一排组成一个整数…

Netty学习——源码篇5 EventLoop 备份

1 Reactor线程模型 Reactor线程模型 中对Reactor的三种线程模型——单线程模型、多线程模型、主从多线程模型做了介绍&#xff0c;这里具体分析Reactor在Netty中的应用。 1.1单线程模型 单线程模型处理流程如下图&#xff1a; 单线程模型&#xff0c;即Accept的处理和Handler…

(科研篇)如何做科研

1.科研周期&#xff1a; 2.CCF列表 1.搜索论文&#xff08;顶会&#xff09; 2.谷歌学术检索 3.如何阅读文献 最重要的部分是abstract introduction 和related work&#xff0c;要明白某个东西的历史&#xff0c;从而进一步发现的缺陷&#xff0c;然后通过实现实验去证明。 通…

HubSpot出海CRM的团队协作与流程优化

在数字化营销日益盛行的今天&#xff0c;团队协作与流程优化已成为企业获取竞争优势的关键因素。HubSpot出海CRM不仅提供了强大的客户管理工具&#xff0c;更在团队协作与流程优化方面展现出卓越的能力。 一、团队协作在营销中的重要性 团队协作在营销中的重要性不言而喻。一…

光伏智慧管理平台:全周期全流程光伏业务管理

随着光伏技术的快速发展和光伏电站规模的不断扩大&#xff0c;光伏业务的管理变得越来越复杂。为了提高管理效率、降低运营成本并提升光伏电站的运行效益&#xff0c;光伏智慧管理平台应运而生。本文将重点介绍光伏智慧管理平台的功能及其在全周期全流程光伏业务管理中的应用。…

最长有效括号(C语言)

题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 这道题&#xff0c;我看了一种解法&#xff0c;觉得很好&#xff0c;来分享一下 这道题主要是 思考 当前 ) 与之匹配 ( 在哪里 &#xff0c;记录下来&#xff0c;最后比较最大值 例子&#xff1a; 第…

浅谈 kafka

引言 同事在公司内部分享了关于 kafka 技术一些相关的内容&#xff0c;所以有了这篇文章&#xff1b;部分图片选自网络摘抄&#xff1b; 1 Kafka概述 1.1 定义 Kafka传统定义&#xff1a;kafka是一个分布式的基于发布/订阅模式的消息队列。 Kafka最新定义&#xff1a;kafka…

【Frida】【Android】05_Objection实战

&#x1f6eb; 系列文章导航 【Frida】【Android】01_手把手教你环境搭建 https://blog.csdn.net/kinghzking/article/details/136986950【Frida】【Android】02_JAVA层HOOK https://blog.csdn.net/kinghzking/article/details/137008446【Frida】【Android】03_RPC https://bl…

Kibana操作Elasticsearch教程

文章目录 简介ES文档操作创建索引查看索引创建映射字段查看映射关系字段属性详解typeindexstore 字段映射设置流程 新增数据新增会随机生成id新增自定义id智能判断 修改数据删除数据查询基本查询查询所有&#xff08;match_all&#xff09;匹配查询多字段查询词条匹配多词条精确…

HarmonyOS 应用开发之创建PageAbility

开发者需要重写app.js/app.ets中的生命周期回调函数&#xff0c;开发者通过DevEco Studio开发平台创建PageAbility时&#xff0c;DevEco Studio会在app.js/app.ets中默认生成onCreate()和onDestroy()方法&#xff0c;其他方法需要开发者自行实现。接口说明参见前述章节&#xf…

maven 依赖机制

安全工程师为啥关注maven依赖 log 4j事件之后&#xff0c;大家开始更加关注开源组件安全漏洞这个事。纷纷引入SCA 软件成分分析工具来识别项目中存在的开源组件和漏洞。 在sca工具扫描之后&#xff0c;会报出一大堆组件&#xff0c;review这个事就是安全团队投入时间来研判了…

【Linux多线程】线程的同步与互斥

【Linux多线程】线程的同步与互斥 目录 【Linux多线程】线程的同步与互斥分离线程Linux线程互斥进程线程间的互斥相关背景概念问题产生的原因&#xff1a; 互斥量mutex互斥量的接口互斥量实现原理探究对锁进行封装(C11lockguard锁) 可重入VS线程安全概念常见的线程不安全的情况…

是谁?阻止CXL在AI场景大展身手~

CXL虽然被视为业内新宠&#xff0c;但好像在AI场景的应用反而没有得到广泛的响应。 AI场景对内存带宽、容量以及数据一致性有着极高需求&#xff0c;特别是在深度学习训练和推理过程中&#xff0c;大量数据需要在CPU、GPU、加速器以及内存之间快速、高效地流动。CXL作为一种新…

Java基础入门day24

day24 abstract 抽象&#xff1a;似是而非&#xff0c;像又不是&#xff0c;具备某种对象的特征&#xff0c;但不完整 生活中的抽象&#xff1a;动物&#xff0c;并不真实存在的事物 程序中的抽象&#xff1a;不应该被创建的对象&#xff0c;动物近视一种会吃会睡的对象&#…

Netty核心原理剖析与RPC实践16-20

Netty核心原理剖析与RPC实践16-20 16 IO 加速&#xff1a;与众不同的 Netty 零拷贝技术 今天的课程我们继续讨论 Netty 实现高性能的另一个高阶特性——零拷贝。零拷贝是一个耳熟能详的词语&#xff0c;在 Linux、Kafka、RocketMQ 等知名的产品中都有使用&#xff0c;通常用于…

【单调栈】力扣84.柱状图中最大的矩形

上篇文章我们介绍了使用 无重复值 单调栈代码解决 含有重复值 的问题&#xff0c;在文章的最后&#xff0c;留下了一道考察相同思想的题目&#xff0c;今天我们来看看如何套路解决该题。 &#xff08;还没看过前几篇介绍的小伙伴赶快关注&#xff0c;在 「单调栈」 集合里查看…

通过node 后端实现颜色窃贼 (取出某个图片的主体rgb颜色 )

1.需求 我前端轮播图的背景色 想通过每一张轮播图片的颜色作为背景色 这样的话 需要通过一张图片 取出图片的颜色 这个工作通过前端去处理 也可以通过后端去处理 前端我试了试 color-thief 的插件 但是 这个插件是基于canvas 的模式来的 我需要在小程序中使用这个插件 而且是…

HarmonyOS-如何使用ArkTS声明式语法和基础组件,实现待办列表。

介绍 本篇Codelab将介绍如何使用ArkTS声明式语法和基础组件&#xff0c;实现简易待办列表。效果为点击某一事项&#xff0c;替换标签图片、虚化文字。效果如图所示&#xff1a; 相关概念 ArkTS语法&#xff1a;ArkTS是HarmonyOS的主要应用开发语言。ArkTS基于TypeScript&…

2024/3/29(MybatisPlus插件代码生成,静态工具,逻辑删除,枚举处理器.JSON处理器,分页插件,通用分页实体)

jdbc:mysql://localhost:3306/mp?useUnicodetrue&characterEncodingutf8&serverTimezoneUTC 需要这样 日志查看级别

【C++杂货铺】内管管理

目录 &#x1f308;前言&#x1f308; &#x1f4c1; C/C中内存分布 &#x1f4c1; new 和 delete的使用 &#x1f4c1; new 和 delete的优点 &#x1f4c1; new 和 delete的原理 &#x1f4c2; operator new 和 operator delete函数 &#x1f4c2; 内置类型 &#x1f4c2…
最新文章