javascript中apply、call和bind的区别
2016-09-27 22:38
375 查看
相同点:
都是用来改变函数的this对象的指向的第一个参数都是this要指向的对象
都可以利用后续参数传参
举个例子来说明用处:
var xw = { name:"xiaowang", say:function(sex){ console.log("i am "+this.name+",i am a "+sex); } } var xh = { name:"xiaohong" }
xw.say.apply(xh,["girl"]);//i am xiaohong,i am a girl xw.say.call(xh,"girl");//i am xiaohong,i am a girl xw.say.bind(xh);//function(sex){console.log("i am "+this.name);} xw.say.bind(xh)("girl");//i am xiaohong,i am a girl
call和apply都是对函数的直接调用,而bind方法返回的仍然是一个函数,因此后面还需要()来进行调用才可以。
call后面的参数与say方法中是一一对应的,而apply的第二个参数是一个数组,数组中的元素是和say方法中一一对应的,这就是两者最大的区别。bind方法则在函数调用时传入参数,形式和call方法一样。
相关文章推荐
- javascript中apply、call和bind的区别
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- javascript中apply、call和bind的区别
- javascript中apply、call和bind的区别
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- JavaScript方法call、apply、caller、callee、bind的使用详解及区别
- JavaScript的函数call和apply的区别、以及bind方法
- javascript中this、apply、call、bind的用法和区别
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- JavaScript apply、call、caller、callee、bind使用方法与区别分析
- javascript中apply、call和bind的使用区别
- JavaScript中apply、call和bind的区别
- javascript -- apply/call/bind的区别
- javascript中apply、call和bind的区别
- javascript中apply、call和bind的区别
- Javascript中apply、call、bind的使用和区别
- JavaScript中的call、apply、bind方法的区别
- JavaScript方法call,apply,caller,callee,bind的使用详解及区别
- javascript中apply、call和bind的区别
- javascript中apply、call和bind的使用区别