超越函数界限:探索JavaScript函数的无限可能

🎬 岸边的风:个人主页

 🔥 个人专栏 :《 VUE 》 《 javaScript 》

⛺️ 生活的理想,就是为了理想的生活 !


目录

📚 前言

📘 1. 函数的基本概念

📟 1.1 函数的定义和调用

📟 1.2 参数和返回值

📟 1.3 匿名函数

📘 2. 函数的高级概念

📟 2.1 作用域

📟 2.2 闭包

📟 2.3 高阶函数

📘 3. 函数的应用场景

📟 3.1 回调函数

📟 3.2 递归

📟 3.3 函数柯里化

📚  写在最后


📚 前言

 

 

JavaScript中的函数是一种重要的编程概念,它允许我们封装可重用的代码块,并在需要时进行调用。本文将深入介绍JavaScript函数的各个方面,包括函数定义和调用、参数和返回值、作用域和闭包、高阶函数以及常见的函数应用场景。 

📘 1. 函数的基本概念

JavaScript中,函数是一段封装了可执行代码的命名代码块。它允许我们将代码组织成逻辑单元,并在需要时进行调用。函数具有以下特点:

📟 1.1 函数的定义和调用

函数的定义使用 function 关键字,后跟函数名、参数列表和函数体,如下所示:

function add(a, b) { return a + b; }

函数名称是一个标识符,用于在调用函数时引用它。调用函数时,可以通过在函数名称后加上小括号,并传递参数的方式调用函数,如下所示:

var result = add(2, 3); // 调用add函数,并将结果赋值给result变量 
console.log(result); // 输出:5

📟 1.2 参数和返回值

函数可以接受零个或多个参数,并且可以返回一个值。参数是函数定义时的占位符,用于在调用函数时传递数据。返回值是函数执行完毕后返回给调用者的结果。下面是一个带有参数和返回值的函数示例:


function multiply(a, b) { return a * b; } 
var result = multiply(2, 3); 
console.log(result); // 输出:6

📟 1.3 匿名函数

除了使用函数名定义函数外,还可以使用匿名函数(没有函数名)来创建函数。匿名函数通常作为回调函数或立即执行函数使用。以下是一个匿名函数的示例:

var greet = function(name) 
{ console.log('Hello, ' + name + '!'); }; 
greet('Alice'); // 输出:Hello, Alice!

📘 2. 函数的高级概念

除了基本概念外,JavaScript函数还具有一些高级概念,包括作用域、闭包和高阶函数

📟 2.1 作用域

作用域定义了变量可访问的范围。JavaScript中有全局作用域和函数作用域。在函数内部定义的变量只能在函数内部访问,而在函数外部定义的变量则可以在整个脚本中访问。以下是一个作用域的示例:

var globalVar = 'Global Variable'; 
function foo() 
{ var localVar = 'Local Variable'; console.log(localVar); // 输出:Local Variable console.log(globalVar); // 输出:Global Variable 
} 
foo(); 
console.log(localVar); // 抛出ReferenceError异常,因为localVar不在全局作用域中

📟 2.2 闭包

 

闭包指的是函数能够访问其定义时所在的词法作用域。它使函数可以记住并访问在其外部定义的变量。以下是一个闭包的示例: 


function outer() 
{ 
var outerVar = 'Outer Variable'; function inner() { console.log(outerVar); // 输出:Outer Variable } 
return inner; 
} 
var closure = outer(); 
closure(); // 输出:Outer Variable

📟 2.3 高阶函数

高阶函数是以函数作为参数或返回值的函数。它们允许我们编写更灵活和可复用的代码。常见的高阶函数包括 mapfilterreduce 等。以下是一个高阶函数的示例:

function multiplyBy(factor) { 
return function(number) { 
return number * factor; }; 
} 
var double = multiplyBy(2); 
var triple = multiplyBy(3); 
console.log(double(4)); // 输出:8 
console.log(triple(4)); // 输出:12

📘 3. 函数的应用场景

JavaScript函数在各种应用场景中发挥着重要作用。以下是几个常见的应用场景:

📟 3.1 回调函数

 

回调函数是作为参数传递给其他函数,并在特定事件发生时被调用的函数。它们常用于处理异步操作、事件处理和请求响应等场景。

function download(url, onSuccess, onError) { 
// 下载操作... 
if (downloadCompleted) { 
onSuccess(data); } 
else 
{ onError(error); 
} 
} 
function handleSuccess(data) { 
console.log('下载成功:' + data); 
} 
function handleError(error) { 
console.log('下载失败:' + error); 
} download('https://example.com/file', handleSuccess, handleError);

📟 3.2 递归

递归是一种函数调用自身的技术。它可以用于解决需要重复执行相似任务的问题,例如树遍历、阶乘计算和斐波那契数列等。

function factorial(n) { 
if (n === 0 || n === 1) { 
return 1; 
} else { 
return n * factorial(n - 1); 
} 
} 
console.log(factorial(5)); // 输出:120

📟 3.3 函数柯里化

函数柯里化是将一个接受多个参数的函数转换为一系列接受单个参数的函数的技术。它可以使函数更加灵活,便于部分应用和组合

function add(a, b) { 
return a + b; 
} 
function curry(fn) { 
return function(a) { 
return function(b) { 
return fn(a, b); 
}; 
}; } 
var curriedAdd = curry(add); 
var add2 = curriedAdd(2); 
console.log(add2(3)); // 输出:5

📚  写在最后

JavaScript函数是封装可重用代码块的重要工具。它们通过定义和调用来实现代码组织和复用。函数可以接受参数并返回值,提供了灵活性和通用性。作用域和闭包帮助保持代码的隔离性和安全性,允许函数访问封闭环境中的变量。高阶函数允许函数作为参数或返回值,增强了函数的组合和操作能力。在实践中,函数用于事件处理、异步编程、模块化开发等。JavaScript函数是开发高效、可维护代码的必备工具。

 

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

动态内存管理

目录 为什么要用动态内存开辟 动态内存有关函数 void* malloc (size_t size); void free (void* ptr); void* calloc (size_t num, size_t size); void* realloc (void* ptr, size_t size); C/C程序的内存开辟 柔性数组 特点: 柔性数组的使用: 为什么要用…

【nodejs】用Node.js实现简单的壁纸网站爬虫

1. 简介 在这个博客中,我们将学习如何使用Node.js编写一个简单的爬虫来从壁纸网站获取图片并将其下载到本地。我们将使用Axios和Cheerio库来处理HTTP请求和HTML解析。 2. 设置项目 首先,确保你已经安装了Node.js环境。然后,我们将创建一个…

学习笔记|基于Delay实现的LED闪烁|u16是什么|a--和--a的区别|STC32G单片机视频开发教程(冲哥)|第六集(上):实现LED闪烁

文章目录 摘要软件更新什么是闪烁Tips:u16是什么? 语法分析:验证代码Tips:a--和--a的区别(--ms 的用法)测试代码: 摘要 1.基于Delay实现的LED闪烁 2.函数的使用 3,新建文件,使用模块化编程 软件更新 打…

macOS(m1/m2)破解Sublime Text和Navicat16

破解Sublime Text 说明:全程使用的是终端操作 1. 下载Sublime Text,建议使用brew下载 2. 进入到下载的app的文件夹 cd "/Applications/Sublime Text.app/Contents/MacOS/"3. 执行以下操作以确认版本是否匹配 md5 -q sublime_text | grep -i…

消息中间件的选择:RabbitMQ是一个明智的选择

💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! MQ(Message Queue) MQ(消息队列)是一种用于在应用程序之间进行异步通信的技术;允许应用程序通过发送和接收…

css学习3(三种样式表与样式控制优先级)

1、外部样式表&#xff1a;当样式需要应用于很多页面时&#xff0c;外部样式表将是理想的选择。在使用外部样式表的情况下&#xff0c;你可以通过改变一个文件来改变整个站点的外观。每个页面使用 <link> 标签链接到样式表&#xff0c;也要放到<head>中。 2、外部…

上网课用什么耳机和麦克风,分享几款骨传导耳机上网课用

各位耳机狂热者&#xff0c;咱们都了解传统的蓝牙耳机相对于老式有线耳机来说确实方便得多。但是&#xff0c;也别忘了蓝牙耳机会导致耳道不断堵塞&#xff0c;引发细菌滋生等问题。好在近年来&#xff0c;骨传导耳机如火如荼地走红&#xff0c;解决了这些难题&#xff0c;简直…

飞天使-jenkins进行远程linux机器修改某个文件的思路

文章目录 jenkins配置的方式jenkins中执行shell的思路 jenkins配置的方式 jenkins中执行shell的思路 下面的脚本别照抄&#xff0c;只是一个思路 ipall"$ips"# 将文本参数按行输出为变量 while IFS read -r line; doecho "$line" if [[ ! -z $line ]] &…

ubuntu 22.04 LTS 在 llvm release/17.x 分支上编译 cookbook llvm example Chapter 02

不错的资料&#xff1a; LLVMClang编译器链接器--保值【进阶之路二】 - 掘金 —————————————————————————————————————— 下载 llvm-cookbook example: $ git clone https://github.com/elongbug/llvm-cookbook.git 也可以参照llvm-pr…

Vue实现动态遍历生成el-input

实现效果: el-input的label是measureName, el-input绑定的值是formDatat.measureCode 接口返回的数据格式如下 处理过的formData的格式如下

SpringBoot+微信小程序奶茶在线点单小程序系统 附带详细运行指导视频

文章目录 一、项目演示二、项目介绍三、运行截图四、主要代码 一、项目演示 项目演示地址&#xff1a; 视频地址 二、项目介绍 项目描述&#xff1a;这是一个基于SpringBoot微信小程序框架开发的奶茶在线点单小程序系统。首先&#xff0c;这是一个前后端分离的项目&#xff…

机器学习深度学习——NLP实战(情感分析模型——textCNN实现)

&#x1f468;‍&#x1f393;作者简介&#xff1a;一位即将上大四&#xff0c;正专攻机器学习的保研er &#x1f30c;上期文章&#xff1a;机器学习&&深度学习——NLP实战&#xff08;情感分析模型——RNN实现&#xff09; &#x1f4da;订阅专栏&#xff1a;机器学习…

SpringBoot复习:(56)使用@Transactional注解标记的方法的执行流程

首先&#xff0c;如果在某个类或某个方法被标记为Transactional时&#xff0c;Spring boot底层会在创建这个bean时生成代理对象&#xff08;默认使用cglib) 示例&#xff1a; 当调用studentService的addStudent方法时&#xff0c;会直接跳到CglibAopProxy类去执行intercept方…

jenkins 安装nodejs 14

参考&#xff1a; jenkins容器安装nodejs-前端问答-PHP中文网

VR漫游:720度实景参观,打造魅力生态小区

随着城市的不断发展&#xff0c;小区的建设越发具有生态化、绿色化的特点&#xff0c;人们也会偏向选择更加适合居住的小区。为了让更多的用户体验小区的舒适性&#xff0c;不少地产开发商准备引入VR漫游技术。 VR漫游不仅能够真实地展示现场环境&#xff0c;还可以改变传统网络…

【大虾送书第六期】搞懂大模型的智能基因,RLHF系统设计关键问答

目录 ✨1、RLHF是什么&#xff1f; ✨2、RLHF适用于哪些任务&#xff1f; ✨3、RLHF和其他构建奖励模型的方法相比有何优劣&#xff1f; ✨4、什么样的人类反馈才是好的反馈 ✨5、RLHF算法有哪些类别&#xff0c;各有什么优缺点&#xff1f; ✨6、RLHF采用人类反馈会带来哪些局…

Android13新特性之通知权限提升

Android13新特性之通知权限提升 随着移动通信的高速发展&#xff0c;保障通信的安全性变得尤为重要。在Android 13的最新版本中&#xff0c;通知权限的管理得到了进一步加强。为了实现安全的通信和确保用户的隐私&#xff0c;必须正确申请通知权限。本文将详细探讨如何在Andro…

人类反馈强化学习RLHF;微软应用商店推出AI摘要功能

&#x1f989; AI新闻 &#x1f680; 微软应用商店推出AI摘要功能&#xff0c;快速总结用户对App的评价 摘要&#xff1a;微软应用商店正式推出了AI摘要功能&#xff0c;该功能能够将数千条在线评论总结成一段精练的文字&#xff0c;为用户选择和下载新应用和游戏提供参考。该…

excel常见的数学函数篇2

一、数学函数 1、ABS(number)&#xff1a;返回数字的绝对值 语法&#xff1a;ABS(数字)&#xff1b;返回数字的绝对值&#xff1b;若引用单元格&#xff0c;把数字换为单元格地址即可 2、INT(number)&#xff1a;向小取整 语法&#xff1a;INT(数字)&#xff1b;若引用单元格…

神经网络基础-神经网络补充概念-14-逻辑回归中损失函数的解释

概念 逻辑回归损失函数是用来衡量逻辑回归模型预测与实际观测之间差异的函数。它的目标是找到一组模型参数&#xff0c;使得预测结果尽可能接近实际观测。 理解 在逻辑回归中&#xff0c;常用的损失函数是对数似然损失&#xff08;Log-Likelihood Loss&#xff09;&#xff…