news 2026/5/7 22:41:51

HoRain云--JavaScript函数调用的4种方式详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
HoRain云--JavaScript函数调用的4种方式详解

🎬 HoRain云小助手:个人主页

🔥 个人专栏: 《Linux 系列教程》《c语言教程》

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


⛳️ 推荐

前些天发现了一个超棒的服务器购买网站,性价比超高,大内存超划算!忍不住分享一下给大家。点击跳转到网站。

专栏介绍

专栏名称

专栏介绍

《C语言》

本专栏主要撰写C干货内容和编程技巧,让大家从底层了解C,把更多的知识由抽象到简单通俗易懂。

《网络协议》

本专栏主要是注重从底层来给大家一步步剖析网络协议的奥秘,一起解密网络协议在运行中协议的基本运行机制!

《docker容器精解篇》

全面深入解析 docker 容器,从基础到进阶,涵盖原理、操作、实践案例,助您精通 docker。

《linux系列》

本专栏主要撰写Linux干货内容,从基础到进阶,知识由抽象到简单通俗易懂,帮你从新手小白到扫地僧。

《python 系列》

本专栏着重撰写Python相关的干货内容与编程技巧,助力大家从底层去认识Python,将更多复杂的知识由抽象转化为简单易懂的内容。

《试题库》

本专栏主要是发布一些考试和练习题库(涵盖软考、HCIE、HRCE、CCNA等)

目录

⛳️ 推荐

专栏介绍

JavaScript 函数调用

1. 函数的4种调用方式

(1) 作为普通函数调用

(2) 作为对象方法调用

(3) 使用构造函数调用(使用new关键字)

(4) 使用call()和apply()方法调用

2. 参数传递机制

3. 函数调用的注意事项

(1) 参数处理

(2) 返回值

(3) 函数提升

(4) 箭头函数的限制

4. 实际应用示例

(1) 函数作为回调函数

(2) 递归函数

(3) 使用call/apply改变this指向

5. 最佳实践


JavaScript 函数调用

JavaScript 函数有4种主要调用方式,每种方式的this指向不同。以下是详细说明:

1. 函数的4种调用方式

(1) 作为普通函数调用

function myFunction(a, b) { return a * b; } myFunction(10, 2); // 返回 20

(2) 作为对象方法调用

var myObject = { firstName: "John", lastName: "Doe", fullName: function() { return this.firstName + " " + this.lastName; } } myObject.fullName(); // 返回 "John Doe"

(3) 使用构造函数调用(使用new关键字)

function MyFunction(arg1, arg2) { this.firstName = arg1; this.lastName = arg2; } var x = new MyFunction("John", "Doe"); x.firstName; // 返回 "John"

(4) 使用call()apply()方法调用

function myFunction(a, b) { return a * b; } // 使用call()方法 myFunction.call(null, 10, 2); // 返回 20 // 使用apply()方法 myFunction.apply(null, [10, 2]); // 返回 20

2. 参数传递机制

3. 函数调用的注意事项

(1) 参数处理

(2) 返回值

(3) 函数提升

(4) 箭头函数的限制

4. 实际应用示例

(1) 函数作为回调函数

// 函数表达式适合作为回调 setTimeout(function() { console.log("Timeout completed"); }, 1000);

(2) 递归函数

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

(3) 使用call/apply改变this指向

const person = { name: "John", greet: function(greeting) { return greeting + ", " + this.name; } }; const anotherPerson = { name: "Jane" }; console.log(person.greet.call(anotherPerson, "Hello")); // "Hello, Jane"

5. 最佳实践

  1. 避免全局函数:尽量将函数定义为对象方法,减少全局命名空间污染
  2. 使用函数表达式:当需要将函数作为参数传递时(如回调函数)
  3. 注意this指向:在需要动态this的场景(如事件处理器)中,避免使用箭头函数
  4. 检查参数:在函数内部检查必要参数是否传入
  5. 使用return:确保函数返回预期值,特别是在链式调用中

记住:JavaScript函数是对象,它们可以被赋值给变量、作为参数传递、返回其他函数,这些都是函数式编程的基础。

❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍

🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 17:28:59

一句话生成会说话的数字人,Live Avatar黑科技实测

一句话生成会说话的数字人,Live Avatar黑科技实测 1. 引言:一句话唤醒一个“活人” 你有没有想过,只需要一句话、一张图、一段声音,就能让一个虚拟人物在屏幕上开口说话,表情自然、口型精准、动作流畅?这…

作者头像 李华
网站建设 2026/5/6 3:59:59

小白也能懂的YOLOv12:官方镜像快速上手指南

小白也能懂的YOLOv12:官方镜像快速上手指南 你是不是也经历过这样的场景?看到一篇目标检测的新论文,兴致勃勃地想跑个demo,结果光是配置环境就卡了三天:依赖冲突、CUDA版本不匹配、PyTorch装不上……最后只能放弃。 …

作者头像 李华
网站建设 2026/5/6 14:58:56

别再骂量化了!这三类散户,正在悄悄靠它赚钱

一、量化交易是敌是友?谈到“量化交易”,许多散户投资者的第一反应可能是厌恶和恐惧。在大家看来,这股由算法驱动的神秘力量似乎总是在市场上兴风作浪,收割着普通投资者。量化交易真的只是百害而无一利吗?凡事都具有两…

作者头像 李华
网站建设 2026/5/4 12:29:58

setprop测试属性验证法,简化调试流程

setprop测试属性验证法,简化调试流程 在Android系统开发过程中,开机启动脚本的调试是一项常见但容易出错的任务。尤其是在涉及Selinux权限、执行路径、脚本语法等问题时,传统通过创建文件或打印日志的方式往往难以快速定位问题。本文将介绍一…

作者头像 李华
网站建设 2026/5/4 12:28:32

iOSDeviceSupport终极解决方案:告别Xcode调试兼容性困扰

iOSDeviceSupport终极解决方案:告别Xcode调试兼容性困扰 【免费下载链接】iOSDeviceSupport All versions of iOS Device Support 项目地址: https://gitcode.com/gh_mirrors/ios/iOSDeviceSupport 还在为Xcode提示"无法定位设备支持文件"而烦恼吗…

作者头像 李华