改变this指向(call、apply、bind)
来源:互联网 发布:中国网络资讯台无锡市 编辑:程序博客网 时间:2024/06/05 03:00
call:
bind:
定义的位置:Function.prototype.call 函数这个类的原型上,相对于每个Function这个类的实例来说都是公有方法。
执行步骤:
1.函数实例先找到定义在Function.prototype的call
2.call方法把这个函数实例中的this修改成了call的第一个参数
3.函数实例执行
ps:call从第二个参数开始都是传给调用call的函数实例的
ps:函数实例调用call方法之后,这个函数其实也执行结束了
apply:
apply和call方法的作用基本相同,apply的第二个参数是一个数组,会把数组中的每一项作为调用apply方法的函数实例的参数 ps:和call一样,都是在修改完this之后直接把函数执行了
var ary=[1,2,3,4,5];//第一种ary.sort(function(a,b){return b-a;});//第二种:利用就是apply这个方法特殊的传参方式Math.max.apply(null,ary);//第三种:假设这个假设思想var max=ary[0];for(var i=1;i<ary.length;i++){ if(ary[i]>max){ max=ary[i]; }}//第四种:eval() 把括号内的字符串执行 eval("Math.max(1,2,3,4,5)") 数组转换为字符串ary.jion("加想要的符号")或者用ary.toString();eval('Math.max('+ary.jion()+')');
bind:
call和apply都已经把函数执行结束,bind是返回一个修改好this的新函数。使用bind的时候一般只修改this,返回值执行的时候再传参 不兼容
阅读全文
1 1
- 改变this指向(call、apply、bind)
- js call() apply() bind() -改变this指向
- JavaScript中call,apply,bind方法的总结(改变this指向)
- js中this的改变指向的方法:call和apply、bind
- JavaScript中的call(),apply(),bind()方法 关于this指向
- setTimeout的this指向:学习apply、call、bind
- 函数中的this指向,以及 修改this指向的 call/apply/bind方法
- js改变this指向方法call,apply;jq改变this指向方法$.proxy()
- call、apply、bind和this
- js的this指针指向谁,以及相关的call、apply、bind方法
- JavaScript OOP(二):this关键字以及call、apply、bind
- JavaScript的this,call(),apply(),bind()
- JavaScript的this,call(),apply(),bind()
- Javascript中的this,call,apply,bind!
- Javascript中的this,call,apply,bind!
- javascript--关键字 apply bind call this
- this之后的call,apply,bind。
- Javascript中的this,call,apply,bind函数
- Kotlin Reference (三) Coding Conventions
- 雷军给程序员的五点建议--如何成为编程高手并以此创业
- [Muduo网络库源码分析] (5) base/FileUtil.cc_h_文件操作
- Scala定义函数的5种方式
- 有关数组的基础递归
- 改变this指向(call、apply、bind)
- cannot simultaneously fetch multiple bags[]不能抓取一对多的属性
- iOS pop到指定页面
- struts2把action交给spring托管
- 一个邮件钓鱼木马的分析 (一)
- 上拉加载
- JVM调优魔法棒-Java VisualVM
- I NEED A OFFER!
- 使程序在Linux下后台运行 (关掉终端继续让程序运行的方法)