首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js的动态绑定的this

在JavaScript中,this关键字的指向是在运行时基于函数的执行上下文来确定的,这种机制被称为动态绑定。这与静态绑定(如通过callapplybind方法显式指定this的指向)形成对比。

基础概念

  1. 默认绑定:在全局作用域中调用函数时,this指向全局对象(在浏览器中是window)。在严格模式下,this将是undefined
  2. 隐式绑定:当函数作为对象的方法调用时,this指向调用该方法的对象。
  3. 显式绑定:通过callapplybind方法,可以显式地指定this的指向。
  4. new绑定:当使用new关键字调用构造函数时,this指向新创建的对象实例。

优势

  • 灵活性:动态绑定允许函数在不同的上下文中以不同的方式工作,提高了代码的复用性。
  • 简洁性:不需要在编写函数时预先知道this的指向,使得代码更简洁。

类型

  • 默认绑定function foo() { console.log(this.a); },在全局作用域调用foo()this指向全局对象。
  • 隐式绑定var obj = { a: 2, foo: foo }; obj.foo();this指向obj
  • 显式绑定foo.call(obj);this被显式绑定到obj
  • new绑定var bar = new foo();this指向新创建的bar实例。

应用场景

  • 事件处理器:在DOM事件处理器中,this通常指向触发事件的元素。
  • 对象方法:当函数作为对象的方法被调用时,this指向该对象。
  • 构造函数:在构造函数中,this指向新创建的对象实例。

遇到的问题及解决方法

问题:在回调函数中,this的指向可能不是预期的对象。

原因:回调函数在执行时,其执行上下文可能不是原来的对象,导致this指向全局对象或undefined(在严格模式下)。

解决方法

  1. 使用箭头函数:箭头函数不会创建自己的this,它会捕获其所在上下文的this值。
  2. 使用箭头函数:箭头函数不会创建自己的this,它会捕获其所在上下文的this值。
  3. 使用.bind()方法:显式地将this绑定到回调函数。
  4. 使用.bind()方法:显式地将this绑定到回调函数。
  5. 使用变量保存this:在函数外部保存this的引用,然后在回调函数中使用该变量。
  6. 使用变量保存this:在函数外部保存this的引用,然后在回调函数中使用该变量。

通过理解this的动态绑定机制,可以更有效地编写和调试JavaScript代码,避免常见的this指向问题。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

js 动态生成 input 的绑定事件 blur 无效

https://blog.csdn.net/u011415782/article/details/89230040 ☯ 背景描述 今天在进行代码编写时,我需要根据ajax返回的数据动态生成一个表格...最开始编写的 js 代码如下: /** * 当sku库存量变化时,对应总库存进行更新 */ $(".input-sku-stock").blur(function ()...,而动态新生成的却无法触发blur事件 因为测试失败后,转而考虑新的写法,且可以正常实现 ?...ி 附录 1.针对我的问题,求助度娘,发现了下面的一个帖子,可作参考 动态添加的blur事件失效 [问题点数:60分,结帖人lawrendc] 时间相当久远... 2.最接近解决需求的文章如下...,建议可自行测试 动态生成input绑定事件无效如:blur 意见:异步导致绑定事件失败,需使用全局绑定事件 3.w3school 文档 - onblur 事件 这就是官方文档

8.9K00
  • Java中的静态绑定和动态绑定

    这里首先我们将确定这种调用何种方法实现或者变量的操作叫做绑定。 在Java中存在两种绑定方式,一种为静态绑定,又称作早期绑定。另一种就是动态绑定,亦称为后期绑定。...而虚方法(可以被子类重写的方法)则会根据运行时的对象进行动态绑定。 静态绑定使用类信息来完成,而动态绑定则需要使用对象信息来完成。...重载(Overload)的方法使用静态绑定完成,而重写(Override)的方法则使用动态绑定完成。 重载方法的示例 这里展示一个重载方法的示例。...,所以只能丢给运行时的动态绑定来处理。...所以,有些实际可以静态绑定的,考虑到安全和一致性,就索性都进行了动态绑定。 得到的优化启示? 由于动态绑定需要在运行时确定执行哪个版本的方法实现或者变量,比起静态绑定起来要耗时。

    1.8K10

    Java中的静态绑定和动态绑定

    而虚方法(可以被子类重写的方法)则会根据运行时的对象进行动态绑定。 静态绑定使用类信息来完成,而动态绑定则需要使用对象信息来完成。...重载(Overload)的方法使用静态绑定完成,而重写(Override)的方法则使用动态绑定完成。 重载方法的示例 这里展示一个重载方法的示例。...这一结果的产生的原因是因为在运行时发生了动态绑定,在绑定过程中需要确定调用哪个版本的call方 法实现。...,所以只能丢给运行时的动态绑定来处理。...所以,有些实际可以静态绑定的,考虑到安全和一致性,就索性都进行了动态绑定。 得到的优化启示? 由于动态绑定需要在运行时确定执行哪个版本的方法实现或者变量,比起静态绑定起来要耗时。

    2.1K10

    JS动态加载数据绑定事件--delegate() 方法

    JS动态加载数据绑定事件-委托delegate() 方法 ---- W3C规范定义 定义和用法 delegate() 方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数...使用 delegate() 方法的事件处理程序适用于当前或未来的元素(比如由脚本创建的新元素)。...---- JavaScript动态加载的数据,同时给他加载绑定事件,我选用Jquwey中的 delegate() 方法 我的理解,delegate()方法属于异步式加载绑定,dom元素加载未完成之前,可以委托给...delegate() 方法来实现的绑定操作。...第二个参数为 要绑定的事件 详情,请翻阅delegate() 方法 ---- 效果如图的返回按钮:

    7.9K30

    Java中的静态绑定和动态绑定

    而虚方法(可以被子类重写的方法)则会根据运行时的对象进行动态绑定。 静态绑定使用类信息来完成,而动态绑定则需要使用对象信息来完成。...重载(Overload)的方法使用静态绑定完成,而重写(Override)的方法则使用动态绑定完成。 重载方法的示例 这里展示一个重载方法的示例。...这一结果的产生的原因是因为在运行时发生了动态绑定,在绑定过程中需要确定调用哪个版本的call方 法实现。...,所以只能丢给运行时的动态绑定来处理。...所以,有些实际可以静态绑定的,考虑到安全和一致性,就索性都进行了动态绑定。 得到的优化启示? 由于动态绑定需要在运行时确定执行哪个版本的方法实现或者变量,比起静态绑定起来要耗时。

    1.5K30

    js动态绑定事件,无法使用for循环中变量i的问题

    ❝小闫语录:我一直在幻想,那些伟大的预言家都来自未来,那些畅销小说家都是真实经历过... ❞ 每天不是在写 bug,就是在解 bug 的路上~更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选...』 1.问题描述 在一个 for 循环中,我动态给一堆 a 标签绑定 onclick 事件时,发现点击事件不正确。...但是上述代码点击每一个链接总是弹出一个值,而且还是个不正常的值。之所以说它不正常,是因为上面我获取到了 5 个标签,正常下标应该到 4 结束,但是总是弹出 5 ????...调用时,发现内部没有定义变量 i ,所以就去外面找一下,发现外层有,就取外层的值了,但是为什么是 5 呢?...那是因为 for 循环的结束条件是 i 不满足 i的值就是 5,匿名函数到外层取值正好取到了它。

    3.9K10

    动态绑定和静态绑定

    Java的动态/静态绑定是比较偏门的知识点之一,可能你不经常听到,但是关于他们的应用,有Java开发经验的朋友应该看一眼就明白。 静态绑定 先说静态绑定。...所谓静态绑定,既是说方法的实现在编译期就已经确定了的。这么一说,马上能想到的就是静态方法。 没错,只有静态方法是属于静态绑定,或者称之为前期绑定。而对象方法则是在运行期绑定的。...动态绑定 对于动态绑定,或者叫运行期绑定,说的是在编译期不知道实现的是哪个具体的对象,直到运行期才能确定。 让我们来举个例子。...,用的是我们经常见到的工厂模式,具体的实现类型可以在DrinkFactory工厂类中根据运行时的情况再确定。...而在编译期时是不知道的。可以用这个例子来理解动态绑定的意义所在。

    1.8K30

    动态绑定与静态绑定

    的类型D* 12 C* pC = new C(); 13 pB = pC;//pB的动态类型是可以更改的,现在它的动态类型是C* 3、静态绑定:绑定的是对象的静态类型,某特性(比如函数)依赖于对象的静态类型...4、动态绑定:绑定的是对象的动态类型,某特性(比如函数)依赖于对象的动态类型,发生在运行期。...函数,这是一个不好的设计,会导致名称遮掩;这里只是为了说明动态绑定和静态绑定才这样使用。...因为vfun是一个虚函数,它动态绑定的,也就是说它绑定的是对象的动态类型,pB和pD虽然静态类型不同,但是他们同时指向一个对象,他们的动态类型是相同的,都是D*,所以,他们的调用的是同一个函数:D::vfun...至于那些事动态绑定,那些事静态绑定,有篇文章总结的非常好: 我总结了一句话:只有虚函数才使用的是动态绑定,其他的全部是静态绑定。目前我还没有发现不适用这句话的,如果有错误,希望你可以指出来。

    2.4K30

    js绑定事件代理的坑

    js通过事件代理的方式绑定跳转事件,我这里的逻辑是把click事件绑定在最外层container上面,如果e.target包含我已经写好的class,则执行跳转逻辑。...但是这种方式好像只能是在点击的元素的上面,也就是最内层的元素上面有相应的class才能跳转,在外层加同样的class不生效,说明是我对于事件代理的理解不够深刻,其实事件代理的作用就是为了把目标元素的事件绑定在外层做代理...document.querySelector('#container').addEventListener('click', function (e) { console.log(e.currentTarget) //获得当前绑定监听事件的元素...) } },false) document.getElementById("container").classList.add('jumpUrl');//写在后面也可以绑定成功...注意:内层元素,即点击的目标元素必须是点击时真正的目标元素,而不是外面一层; currentTarget绑定相应想要点击的class的时候必须是做代理的即做事件监听的元素。

    5K20

    jQuery 动态绑定

    这是在项目过程中所遇到的一个问题,给 JS 动态生成的元素绑定事件失效,代码如下所示:$(".more-btn").on('click', function() { console.log("peace...and love")};其中,more-btn 按钮是通过 layer 模块动态生成的,而我们在按钮上绑定的点击事件却没能生效,这是因为 DOM 节点还没有渲染出来,我们就将点击事件就绑定上了而通过查阅...jQuery 的 API 文档,on() 方法是支持给动态元素绑定事件的,即事件委托模式,我们首先要获取需要绑定的 selector 的父级元素或祖先元素,比较简单粗暴的办法就是使用 body 或者...document,然后在你绑定的事件后面跟上你的 selector 即可,代码如下所示:$(document).on('click',".more-btn", function() { console.log

    2K30

    理解静态绑定与动态绑定

    绑定分类 绑定主要分为两种: 静态绑定 和 动态绑定 绑定的其他叫法 静态绑定 == 前期绑定 == 编译时绑定 动态绑定 == 后期绑定 == 运行时绑定 为了方便区分: 下面统一称呼为静态绑定和动态绑定...static 关键词所修饰,也是编译时绑定 动态绑定 概念 在运行时根据具体对象的类型进行绑定 除了由private、final、static 所修饰的方法和构造方法外,JVM在运行期间决定方法由哪个对象调用的过程称为动态绑定...上面的绑定方式称之为动态绑定,因为在你编写 Father son = new Son()的时候,编译器并不知道son对象真正引用的是谁,在程序运行时期才知道,这个son是一个Father类的对象,但是却指向了...动态绑定的过程 虚拟机提取对象的实际类型的方法表; 虚拟机搜索方法签名; 调用方法。...动态绑定和静态绑定的特点 静态绑定 静态绑定在编译时期触发,那么它的主要特点是 1、编译期触发,能够提早知道代码错误 2、提高程序运行效率 动态绑定 1、使用动态绑定的前提条件能够提高代码的可用性,使代码更加灵活

    1.8K80

    Python动态绑定属性slots的使用

    当我们定义了一个class,创建了一个class的实例后,我们可以给该实例绑定任何属性和方法,这就是动态语言的灵活性。...废话不多说,我们看一个例子: class Person(object): pass p = Person() p.name = 'mary' # 动态给实例绑定一个属性 print(p.name...print(p.sex) # female 这里需要注意:给一个实例绑定的方法,对另一个实例是不起作用的: p2 = Person() # 创建新的实例 p2.set_sex_fun('male')...p2.set_sex_fun('male') print(p2.sex) # male 通常情况下,上面的set_sex方法可以直接定义在class中,但动态绑定允许我们在程序运行的过程中动态给class...__slots__中,所以不能绑定age属性,试图绑定age将得到AttributeError的错误。

    1.7K40

    动态绑定机制

    动态绑定机制 java的动态绑定机制: 当调用对象方法的时候,该方法会和该对象的内存地址/运行类型绑定; 当调用对象属性时,没有动态绑定机制,在哪个类中声明就用哪个类中的属性; 代码示例: package...com.hspedu.poly_.dynamic_; /** * @author gaoqinghui * @date 2022/4/15 15:31 * java的动态绑定机制 * 1....当调用对象方法时,该方法会和该对象的内存地址/运行类型绑定 * 2.当调用对象属性时,没有动态绑定机制,哪里声明,哪里使用 */ public class DynamicBinding {...这个方法,调用这个方法后,返回的时geti() + 10,根据动态绑定机制,这时会根据我们a的运行内存去寻找这个geti()方法,a的运行类型时B,就去B中找是否有geti(),这时找到,返回i,因为返回...i是属性,属性没有动态绑定机制,返回的就是就是B类中定义的i,也就是20,然后返回父类,结果为30; System.out.println(a.sum()); System.out.println

    68220

    java — 静态绑定和动态绑定

    绑定:一个方法的调用与方法所在的类关联起来。java中的绑定分为静态绑定和动态绑定,又被称作前期绑定和后期绑定。...动态绑定:在运行根据具体对象的类型进行绑定。...隐藏和覆盖的区别在于,子类对象转换成父类对象后,能够访问父类被隐藏的变量和方法,而不能访问父类被覆盖的方法)。 2.动态绑定 调用的方法依赖于隐式参数的实际类型,并且在运行时实现动态绑定。...动态绑定的过程分为以下几个环节:   (1)编译器查看对象的声明类型和方法名;   (2)编译器查看调用方法时提供的参数类型。...(3)采用动态绑定调用方法的时候,一定调用与所引用对象的实际类型最合适的类的方法。

    3.6K90

    缺省参数是编译期间绑定的,而不是动态绑定

    " << number<<endl; } }; int main() { B b; A &a = b; a.Fun(); return 0; } //虚函数动态绑定...=>B,非A,缺省实参是编译时候确定的=>10,非20  输出:B::Fun with number 10 条款38:   决不要重新定义继承而来的缺省参数值  本条款的理由就变得非常明显:虚函数是动态绑定而缺省参数值是静态绑定的...这意味着你最终可能调用的是一个定义在派生类,但使用了基类中的缺省参数值的虚函数.  为什么C++坚持这种有违常规的做法呢?答案和运行效率有关。...如果缺省参数值被动态绑定,编译器就必须想办法为虚函数在运行时确定合适的缺省值,这将比现在采用的在编译阶段确定缺省值的机制更慢更复杂。...做出这种选择是想求得速度上的提高和实现上的简便,所以大家现在才能感受得到程序运行的高效;当然,如果忽视了本条款的建议,就会带来混乱。

    99460
    领券