news 2026/4/22 0:46:29

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/4/20 8:33:18

Obsidian科研知识管理模板:从零开始构建高效工作流

Obsidian科研知识管理模板:从零开始构建高效工作流 【免费下载链接】obsidian_vault_template_for_researcher This is an vault template for researchers using obsidian. 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian_vault_template_for_researcher…

作者头像 李华
网站建设 2026/4/20 9:01:03

Cursor Pro免费解锁终极指南:一键激活AI编程助手完整方案

Cursor Pro免费解锁终极指南:一键激活AI编程助手完整方案 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your …

作者头像 李华
网站建设 2026/4/20 15:46:52

Z-Image-Turbo镜像使用:7860端口冲突解决实战案例

Z-Image-Turbo镜像使用:7860端口冲突解决实战案例 Z-Image-Turbo是阿里巴巴通义实验室开源的高效AI图像生成模型,作为Z-Image的蒸馏版本,它以极快的生成速度(仅需8步)、卓越的图像质量(具备照片级真实感&a…

作者头像 李华
网站建设 2026/4/17 22:26:17

3分钟实现百度网盘全速下载的零成本方案

3分钟实现百度网盘全速下载的零成本方案 【免费下载链接】BaiduNetdiskPlugin-macOS For macOS.百度网盘 破解SVIP、下载速度限制~ 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduNetdiskPlugin-macOS 还在为百度网盘蜗牛般的下载速度而苦恼吗?作为macO…

作者头像 李华
网站建设 2026/4/21 11:33:27

Cursor Free VIP终极方案:2025年完全免费解锁AI编程助手全功能

Cursor Free VIP终极方案:2025年完全免费解锁AI编程助手全功能 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached …

作者头像 李华