《前端面试题》- JS基础 - call()、apply()、bind() 的区别

call 、bind 、 apply 这三个函数的功能都是改变this的指向问题,但是也存在一定的区别。

  • call 的参数是直接放进去的,第二第三第 n 个参数全都用逗号分隔,
  • apply 的所有参数都必须放在一个数组里面传进去
  • bind 除了返回是函数以外,它 的参数和 call 一样。

对比的时候,以call为基准,call的使用方式形如:obj.say.call(objCall,'YES', 'YES');, apply与call的区别在于,传参如果有多个,只能放到数组里面;bind与call的区别在于,并不会立即执行函数,而且会返回一个新函数,可延迟执行。

为了更好的理解,写个小例子对比下使用:

复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        @media print {
            .child {
                page-break-inside: avoid; 
            }
        }
    </style>
</head>

<body>
    <div class="container"></div>
</body>
<script>
    // 这里面的say方法里面的this指向就是obj,所以调用obj.say()
    // 会输出"我的名字是:zzh, 平时爱阅读么:YES, 平时爱运动么:YES"
    const obj = {
        name: 'zzh',
        age: 18,
        say(loveRead, loveSopot) {
            console.log(`我的名字是:${this.name}, 平时爱阅读么:${loveRead}, 平时爱运动么:${loveSopot}`);
        }
    };
    obj.say('YES', 'YES');

    /**
     * call
    */
    // 这个时候,我想使用call去改变this的指向需要怎么做呢
    let objCall = { name: 'new zzh'};
    // 将obj的say方法,利用call绑定到objCall上,并且立即执行函数
    obj.say.call(objCall,'YES', 'YES'); 
    // 输出结果:我的名字是:new zzh, 平时爱阅读么:YES, 平时爱运动么:YES

    /**
     * apply, 它与call的区别就是传参如果有多个,只能使用数组,而call可以单个传递
    */
    let objApply = { name: 'new zzh with apply'};
    obj.say.apply(objApply,['YES','NO']); 
    // 输出结果:我的名字是:new zzh with apply, 平时爱阅读么:YES, 平时爱运动么:NO

    /**
     * bind, 它与call的区别就是返回了一个函数,不会立即执行函数
    */
    let objBind = { name: 'new zzh with bind'};
    // 将obj的say方法,利用call绑定到objCall上,并且立即执行函数
    let objBindNew = obj.say.bind(objCall,'NO', 'YES');
    objBindNew();
    // 输出结果:我的名字是:new zzh, 平时爱阅读么:NO, 平时爱运动么:YES

</script>

</html>
相关推荐
m0_719084111 小时前
React笔记张天禹
前端·笔记·react.js
Ziky学习记录1 小时前
从零到实战:React Router 学习与总结
前端·学习·react.js
wuhen_n1 小时前
JavaScript链表与双向链表实现:理解数组与链表的差异
前端·javascript
wuhen_n1 小时前
JavaScript数据结构深度解析:栈、队列与树的实现与应用
前端·javascript
我是一只puppy1 小时前
使用AI进行代码审查
javascript·人工智能·git·安全·源代码管理
颜酱1 小时前
从二叉树到衍生结构:5种高频树结构原理+解析
javascript·后端·算法
狗哥哥2 小时前
微前端路由设计方案 & 子应用管理保活
前端·架构
TT哇2 小时前
【实习 】银行经理端两个核心功能的开发与修复(银行经理绑定逻辑修复和线下领取扫码功能开发)
java·vue.js
前端大卫2 小时前
Vue3 + Element-Plus 自定义虚拟表格滚动实现方案【附源码】
前端
却尘2 小时前
Next.js 请求最佳实践 - vercel 2026一月发布指南
前端·react.js·next.js