bind改变this的指向】的更多相关文章

<script type="text/javascript"> var Hello = function(){ this.setT = function(){ window.setTimeout(function(){ console.log(this); }.bind(this),1000);//bind将内部this的指向,指向外部this的指向 } } var hello = new Hello(); hello.setT(); // var Hello = func…
最近开发的过程中遇到了this指向问题,首先想到的是call().apply().bind()三个方法,有些时候这三个方法确实是十分重要,现在我们就把他们的使用方法及异同点讲解一下. 1.每个函数都包含三个非继承而来的方法,call()方法.apply()方法和bind()方法       2.相同点:三者的作用都是一样的,都是在特定作用中调用函数,等于设置函数体内this的值,以扩充函数赖以运行的作用域. 一般来说,this总是指向调用某个方法的对象,但是使用call().apply()和bi…
用call()和apply()改变this的指向,那什么时候用this呢?(构造函数),那为什么要用构造函数呢?(为了生成对象). 1.解决函数内this指向的问题 (1)var that/_this=this;在函数外提前声明一个变量 (2)通过call()和apply()改变this的指向 2.call()和apply()的区别 用法是一样的,但是参数形式不一样 call()  :   fn.call(obj,a,b) apply()   :   fn.apply(obj,[a,b]) 二者…
要懂得JavaScript中this的用法,首先需要知道,JavaScript中的作用域相关知识. var fun = function(){ var flag = 1; console.log(flag): } var flag = 0; fun(); console.log(flag); 首先看上面这段代码,结果 : 1    0  这个很好理解了,打印的函数内部 flag 的值为 1,全局打印 flag 的值为0. 那么再如果函数内部打印 this.flag 呢? var fun = fu…
一.this指向详解(彻底理解js中this的指向,不必硬背) 首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(非箭头函数)(这句话有些问题,后面会解释为什么会有问题,虽然网上大部分的文章都是这样说的,虽然在很多情况下那样去理解不会出什么问题,但是实际上那样理解是不准确的,所以在你理解this的时候会有种琢磨不透的感觉),那么接下来我会深入的探讨这个问题. 为什么要学习this?如果你学过面…
<body>     <div style="width: 200px;height: 200px;hotpink;"></div>     <script> const fn = function(a,b){             console.log(this.name + this.age + "是个大傻瓜" + a + b )         }         const obj = {         …
react的事件处理会丢失this,所以需要绑定,为什么会丢失this? 首先来看摘自官方的一句话: You have to be careful about the meaning of this in JSX callbacks. In JavaScript, class methods are not bound by default. 这句话大概意思就是,你要小心jax回调函数里面的this,class方法默认是不会绑定它的 让我十分疑惑,在我的知识范围理解中,class是es6里面新增…
这个问题倒不是面向对象的,而是今天遇到js面向对象的时候一个例子的时候突然遇到了,call()方法,然后自己突然发现竟然忘记了,查了之后整理如下: xxx.call((对象名),参数a,参数b) xxx指需要改变this指向的对象名称. apply与它大致相同,不过传参格式为:xxx.call((对象名),[参数a,参数b]) xxx指需要改变this指向的对象名称.还有第三种bind()方法,bind方法会返回一个绑定好this以及参数的函数,并不会调用原函数.所以需要var一个新的变量去接受…
一.函数的定义方式 1.函数声明方式 function  关键字(命名函数) 2.函数表达式(匿名函数) 3.new  Function( ) var  fn = new  Function(‘参数1’,‘参数2’.....,‘函数体’) Function 里面参数都必须是字符串格式 第三种方式执行效率低,也不方便书写,很少使用 所有函数都是 Function 的实例(对象) 函数也属于对象 二. 函数的调用方式 // 1. 普通函数 this 指向 window(函数调用者) function…
这周自我学习的时间很宽裕.正巧一直对call和apply不甚理解(虽然bind还经常用到,仅仅是知道这么用有这个效果= =,而不知为何有这个效果),下午就自己写写demo,帮助自己理解. function add(a, b) { console.log(a + b); } function minus(a, b) { console.log(this) console.log(a - b); } minus(1, 2); minus.call(add, 1, 2); 非常简单的2个函数,下面先给…