时间:2021-07-01 10:21:17 帮助过:24人阅读
bind:这个方法在IE6-8下不兼容 ->和call和apply类似都是用来改变this关键字的
'use strict' //告诉当前浏览器接下来的js代码将按照严格模式进行编写var obj = {name:'张三'}function fn(num1,num2){ console.log(num1+num2); console.log(this) } fn(100,200); //this ->window num1=100 num2=200fn.call(100,200); // this->100 num1 = 200 num2=undefined NaNfn.call(obj,100,200) //this->obj call在给fn传递参数的时候,是一个个传递值的,而apply不是一个个传,而是把要传递的参数值放在一个数组中进行操作。但是也相当于一个个的给fn的形参赋值fn.apply(obj,[100,200]); // //预处理:事先把fn的this改变为我们想要的结果,并且把对应的参数值也准备好,以后要用到了,直接的执行即可。bind这里实现了预处理的效果var tempFn = fn.bind(obj,100,200); //只是改变了fn中的this为obj,并且给fn传递了两个参数值100和200,但此时并没有把fn这个函数执行,执行bind会有一个返回值,这个返回值tempFn就是我们把fn的this改变后的那个结果 tempFn(); fn.call(); //this->window 在严格模式下this->undefinedfn.call(null); //this->window 在严格模式下this->nullfn.call(undefined) //this->window 在严格模式下this->undefined
以上就是apply和call的方法介绍的详细内容,更多请关注Gxl网其它相关文章!