JavaScript 中call和apply的详细讲解 —— 连10岁的小朋友都能看懂!

🌟 一、先搞清楚"函数"和"this"是什么

✅ 函数(Function)

函数就像一个"小机器人",你告诉它做什么,它就去做。比如:

javascript 复制代码
function sayHi() {
  console.log("你好!");
}
sayHi(); // 输出:你好!

✅ this 是什么?

this 就像一个"遥控器",指向当前正在使用这个函数的对象。

javascript 复制代码
const 小明 = {
  name: "小明",
  sayName: function() {
    console.log("我是" + this.name);
  }
};

小明.sayName(); // 输出:我是小明

这里的 this 指向"小明"这个对象。

🧩 二、问题来了:如果我想让"小红"也用"小明"的 sayName 函数怎么办?

这时候就需要 callapply !它们的作用是:临时借用别人的函数,并指定"this"是谁

🔍 三、call 的基本用法

📌 语法:

javascript 复制代码
函数.call(新的this对象, 参数1, 参数2, ...)

👶 举个超简单的例子:

javascript 复制代码
function greet() {
  console.log("你好,我是 " + this.name);
}

const 小明 = { name: "小明" };
const 小红 = { name: "小红" };

greet.call(小明); // 输出:你好,我是 小明
greet.call(小红); // 输出:你好,我是 小红

👉 callgreet 函数借给小明/小红用,并让 this 指向他们!

🔍 四、apply 的基本用法

📌 语法:

javascript 复制代码
函数.apply(新的this对象, [参数数组])

注意:参数要用数组传进去!

👶 例子(带参数):

javascript 复制代码
function introduce(age, hobby) {
  console.log(`我是 ${this.name},今年 ${age} 岁,喜欢 ${hobby}`);
}

const 小刚 = { name: "小刚" };

// 用 call:
introduce.call(小刚, 10, "打篮球");
// 输出:我是 小刚,今年 10 岁,喜欢 打篮球

// 用 apply(参数必须放数组里):
introduce.apply(小刚, [10, "打篮球"]);
// 输出:我是 小刚,今年 10 岁,喜欢 打篮球

总结区别:

  • call:一个个写参数 → func.call(obj, a, b, c)
  • apply:把参数打包成数组 → func.apply(obj, [a, b, c])

... [省略了部分内容以保持简洁]

🎁 八、终极总结(一句话记住)

callapply 就是"借函数 + 指定主人(this)"的魔法咒语!

  • call:参数一个个说。
  • apply:参数打包成数组说。

🧪 九、动手练习(试试看!)

javascript 复制代码
function describe(color, size) {
  console.log(`${this.item} 是 ${color} 色,尺寸是 ${size}`);
}

const shirt = { item: "T恤" };
const hat = { item: "帽子" };

// 请用 call 和 apply 分别让 shirt 和 hat 描述自己!
describe.call(shirt, "红", "L");
describe.apply(hat, ["蓝", "M"]);

输出:

复制代码
T恤 是 红 色,尺寸是 L
帽子 是 蓝 色,尺寸是 M
相关推荐
Mr.Jessy6 分钟前
JavaScript高级:深浅拷贝、异常处理、防抖及节流
开发语言·前端·javascript·学习
唐叔在学习12 分钟前
30s让ai编写「跳过外链中转页」的油猴脚本
前端·javascript
API技术员1 小时前
item_get_app - 根据ID取商品详情原数据H5数据接口实战解析
javascript
八哥程序员1 小时前
Chrome DevTools 详解系列之 Elements面板
javascript·浏览器
coderHing[专注前端]1 小时前
告别 try/catch 地狱:用三元组重新定义 JavaScript 错误处理
开发语言·前端·javascript·react.js·前端框架·ecmascript
UIUV1 小时前
JavaScript中this指向机制与异步回调解决方案详解
前端·javascript·代码规范
momo1001 小时前
IndexedDB 实战:封装一个通用工具类,搞定所有本地存储需求
前端·javascript
San301 小时前
从零到一:彻底搞定面试高频算法——“列表转树”与“爬楼梯”全解析
javascript·算法·面试
JellyDDD1 小时前
h5上传大文件可能会导致手机浏览器卡死,重新刷新的问题
javascript·上传文件
T___T2 小时前
一个定时器,理清 JavaScript 里的 this
前端·javascript·面试