call apply bind 异同

三者都可以改变函数中都this指向

let fn = function (a, b) {
    console.log(this);
};
let obj = {name: "OBJ"};

call

1、非严格模式下,如果参数不传或者第一个传递的是null/undefined,this都是执行window

2、在严格模式下(“use strict”),第一个参数是谁,this就指向谁(包括null/undefined),不传this是undefined

// 非严格模式
fn.call(obj,10,20) 
//this=>obj a=10 b=20
fn.call(10,20)
//this=>10 a=20 b=undefined
fn.call() 
//this=>window a undefined b= undefined
fn.call(unll) //this => window
fn.call(undefined) //this => window

apply

apply和call基本一模一样,唯一的区别在于传參方式

fn.call(obj,10,20)
fn.apply(obj,[10,20])
// apply 需要把传递给fn的参数放到一个数组(或者类数组)中传递进去,虽然写的是一个数组,但是也相当于给fn一个个的传递

bind

语法和call一模一样,唯一的区别在于立即执行还是等待执行

fn.call(obj,10,20) 
//改变fn中的this,并且把fn立即执行
fn.bind(obj,10,20)
// 改变fn中的this,此时的fn并没有执行(不兼容IE6~8)


document.onclick = fn; 
//把fn绑定给点击事件,点击的时候执行
document.onclick = fn()
// 在绑定的时候,先把fn执行,在把执行的返回值(undifined)绑定给事件,当点击的时候执行的是undefined
//需求:点击的时候执行fn,让fn的this是obj
document.onclick = fn.call(obj)
// 虽然this确实改为obj了,但是绑定的时候就把fn执行了(call是立即执行函数),点击的时候执行的是fn的返回值
document.onclick = fn.bind(obj)
// bind属于把fn的this预处理味obj 此时fn没有执行,当前点击的时候才会把fn执行
案例需求:获取数组中的最大值(最小值)
let ary = [12,13,14,23,24,13,15,12]
排序法
// 给数组排序(由大到小),第一项就是最大值
let max = ary.sort(function(a,b){
    return b-a;
})[0]
假设法
/* 假设第一个值是最大值,
然后依次便利数组中后面的每一项,
和假设的值比较,
如果比假设的值要大,
把当前项赋值给max */
let max = ary[0]
for(let i =0;i<ary.length;i++){
    let item = ary[i];
    item > max ? max = item : null;
}
console.log(max)
基于Math.max完成
Math.max(12,13,14,23,24,13,15,12)
// 24
Math.max(ary) 
//NaN
//Math.max是获取一堆数中大最大值,需要我们把比较的数一个个的传递给这个方法
 
基于apply
Math.max.apply(,ary)
// apply特征 虽然放的是一个数组,但是执行方法的时候,也是把数组中的每一项一个个的传递给函数
Math.min.apply(ary)
// 最小值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值