为了账号安全,请及时绑定邮箱和手机立即绑定

js笔记三十九之call,apply和bind的区别

标签:
JavaScript

call

var obj = {name:"lilei"};function fn(num1,num2){    console.log(num1+num2);    console.log(this);
}
fn(100,200); // -> 300 window -> num1=100,num2=200  this - windowfn.call(100,200); // -> NaN Number {100} -> num1=200,num2=undefined  this - 100fn.call(obj,100,200); // -> NaN Number {100} -> num1=100,num2=200  this - obj// fn.call传的值,第一个参数是给fn的this关键字的,后面的参数是给fn传的参数fn.call(); // -> this - windowfn.call(null); // -> this - windowfn.call(undefined); // -> this - window
// 严格模式"use strict"; // -> 告诉当前浏览器接下来的js代码将按照严格模式进行编写var obj = {name:"lilei"};function fn(num1,num2){    console.log(num1+num2);    console.log(this);
};

fn.call(); // -> this - undefinedfn.call(null); // -> this - nullfn.call(undefined); // -> this - undefined

apply

apply和call的方法的作用是一模一样的,都是用来改变方法的this关键字并且把方法执行;
而且在严格模式下和非严格模式下对于第一个参数是null和undefined这种情况的规律也是一样的;

var obj = {name:"lilei"};function fn(num1,num2){    console.log(num1+num2);    console.log(this);
};// fn.call(obj,100,200);fn.apply(obj,[100,200]);

call在给fn传递参数的时候,是一个个的传递值的,而apply不是一个个传
而是把要给fn传递的参数值统一的放在一个数组中进行操作
但是也相当于一个个的给fn的形参赋值

bind

ie6~8不兼容
和call/apply类似都是用来改变this关键字的

var obj = {name:"lilei"};function fn(num1,num2){    console.log(num1+num2);    console.log(this);
};// fn.call(obj,100,200);fn.bind(obj,100,200);

call: 改变this和执行fn函数是一起完成了
bind: 只是改变了fn中的this为obj,并且给fn传递两个参数值1,2;但是此时并没有把fn这个函数执行;
执行bind会有一个返回值,这个返回值tempFn就是我们把fn的this改变后的那个结果

var obj = {name:"lilei"};function fn(num1,num2){    console.log(num1+num2);    console.log(this);
};var tempFn = fn.bind(obj,100,200); 
tempFn();
  • bind中的预处理思想:
    预处理: 事先把fn的this改变为我们想要的结果,并且把对应的参数值也准备好,以后要用到了,直接执行即可



作者:uplyw
链接:https://www.jianshu.com/p/dba0cd51dd9e

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消