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

js绑定事件代理的坑

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

4.9K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    react事件绑定

    React事件绑定是将事件处理函数与组件的交互操作关联起来的过程。通过事件绑定,我们可以在React组件响应用户的交互,并进行相应的操作。...React事件绑定特点React事件绑定具有以下特点:以驼峰命名:React事件名采用驼峰命名方式,如onClick、onChange等。...使用JSX语法:在JSX,通过将事件处理函数作为属性值来绑定事件。使用事件对象:事件处理函数接收一个事件对象作为参数,可以通过事件对象获取相关信息。...自动绑定this:在类式组件事件处理函数会自动绑定组件实例的this。绑定事件处理函数要绑定事件处理函数,可以通过在JSX中使用事件名作为属性,并将事件处理函数作为属性值。...使用事件对象在事件处理函数,可以通过参数获取事件对象,并从中获取相关信息,如事件的类型、目标元素等。

    3.1K30

    JS 事件绑定事件监听、事件委托详细介绍 转

    在JavaScript的学习,我们经常会遇到JavaScript的事件机制,例如,事件绑定事件监听、事件委托(事件代理)等。这些名词是什么意思呢,有什么作用呢?...在JavaScript,有三种常用的绑定事件的方法: 在DOM元素中直接绑定; 在JavaScript代码绑定绑定事件监听函数。...; } 在JavaScript代码绑定事件 在JavaScript代码(即 script 标签内)绑定事件可以使JavaScript代码与HTML标签分离,文档结构清晰,便于管理和开发。...事件监听 关于事件监听,W3C规范定义了3个事件阶段,依次是捕获阶段、目标阶段、冒泡阶段。 起初Netscape制定了JavaScript的一套事件驱动机制(即事件捕获)。...事件委托可以显著的提高事件的处理速度,减少内存的占用。 实例分析JavaScript事件委托和事件绑定 ,这篇文章写得还不错。

    8.8K31

    jQuery 事件绑定 和 JavaScript 原生事件绑定

    live、delegate 不多用,在Jquery1.7已经移除,这里不多说 重点介绍 bind、on bind(event,[data],function) bind 是使用频率较高的一种,作用就是在选择到的元素上绑定特定事件类型的监听函数...JavaScript支持在标签中直接绑定事件 2.在JavaScript代码onXXX绑定:在JavaScript代码绑定事件可以使JavaScript代码与HTML标签分离,文档结构清晰,便于管理和开发...在JavaScript代码onXXX绑定 在JavaScript代码绑定事件的语法为: elementObject.onXXX=function(){     // 事件处理代码 } 其中: elementObject...jQuery 事件绑定具有叠加性,JavaScript 的事件绑定则是可覆盖的。...执行 js 的 cm2 点击事件,控制台打印的是: ?

    5.7K20

    backbonejsView事件绑定源码分析

    其实上下文是接上一篇的,因为自己不理解backbone view事件绑定所以掉到了自己挖的一个坑里,调了两个晚上。把backbone view部分的代码看了之后才明白。 什么样的坑?...topbar">搜索 bla bla bla bla 对应的js...: { 'click .search': function(evt){console.log('search')}, } }); 大概就是这样的一个坑,在不理解backbone绑定事件的情况下...该函数的流程是: 判断events这个属性是否定义 先接触这个view的所有已委托的事件 一些合法性检验,如名称是否合法,是否是函数等 绑定到view实例上 最后就是绑定到 $el 上 看到这就明白了为啥我的那个...search始终无法触发了,因为它在 $el 根本就选择不到它。

    68720

    JavaScript 事件绑定

    事件绑定分为两种:一种是传统事件绑定(内联模型,脚本模型),一种是现代事件绑定(DOM2级模型)。现代事件绑定在传统绑定上提供了更强大更方便的功能。...一.传统事件绑定的问题 传统事件绑定有内联模型和脚本模型,内联模型我们不做讨论,基本很少去用。先来看一下脚本模型,脚本模型将一个函数赋值给一个事件处理函数。...; 问题一:一个事件处理函数触发两次事件 window.onload = function () {//第一组程序项目或第一个JS文件 alert('Lee'); }; window.onload = ...function () {//第二组程序项目或第二个JS文件 alert('Mr.Lee'); }; 当两组程序或两个JS文件同时执行的时候,后面一个会把前面一个完全覆盖掉。...PS:IE事件绑定函数attachEvent()和detachEvent()可能在实践不去使用,有几个原因:1.IE9就将全面支持W3C事件绑定函数;2.IE的事件绑定函数无法传递this;3

    3.4K60

    【Node.JS事件绑定与触发

    往期文章 【Node.JS】写入文件内容 【Node.JS】读取文件内容 目录 简介 绑定事件 on() addListener()  once() 监听事件emit()  传参  删除事件 removeListener...()  removeAllListeners() ---- 简介 node.js事件是使用events模块,通过实例化它里面的EventEmitter类,来绑定和监听事件。...绑定事件 on() const eve = require("events"); //导入模块 var event = new eve.EventEmitter(); //进行实例化声明 event.on...event.emit('namea', '小解');  once() once 只会绑定一次性的触发事件,触发一次后就会解除绑定。...event.removeListener('namea', name) event.emit('namea', '小解'); 删除 namea事件的name属性,设置两个,删除了一个name,只留下了

    11.1K40

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

    JS动态加载数据绑定事件-委托delegate() 方法 ---- W3C规范定义 定义和用法 delegate() 方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数...使用 delegate() 方法的事件处理程序适用于当前或未来的元素(比如由脚本创建的新元素)。...---- JavaScript动态加载的数据,同时给他加载绑定事件,我选用Jquwey的 delegate() 方法 我的理解,delegate()方法属于异步式加载绑定,dom元素加载未完成之前,可以委托给...delegate() 方法来实现的绑定操作。...top-nav-left","click",function() { window.history.back(); }); }); ---- 第一个参数为 要点击的标签属性 第二个参数为 要绑定事件

    7.9K30

    Vue事件绑定原理

    Vue事件绑定原理 Vue通过v-on或其语法糖@指令来给元素绑定事件并且提供了事件修饰符,基本流程是进行模板编译生成AST,生成render函数后并执行得到VNode,VNode生成真实DOM节点或者组件时候使用...addEventListener方法进行事件绑定。...== emptyObject) { newHandler.modifiers = modifiers } // 绑定事件可以多个,回调也可以多个,最终会合并到数组 const handlers...前面介绍了如何编译模板提取事件收集指令以及生成render字符串和render函数,但是事件真正的绑定到DOM上还是离不开事件注册,此阶段就发生在patchVnode过程,在生成完成VNode后,进行...patchVnode过程创建真实DOM时会进行事件注册的相关钩子处理。

    8.8K40

    Hooks与事件绑定

    Hooks与事件绑定 在React,我们经常需要为组件添加事件处理函数,例如处理表单提交、处理点击事件等。...此外,在定义事件处理函数时,通常需要使用bind方法来绑定函数的上下文,以确保在函数可以正确地访问组件实例的属性和方法,虽然我们可以使用箭头函数来减少bind,但是还是使用this语法还是没跑了。...事件绑定 使用Hooks进行普通的合成事件绑定是一件很轻松的事情,在这个例子,我们使用了普通的合成事件onClick来监听按钮的点击事件,并在点击时调用了add函数来更新count状态变量的值,这样每次点击按钮时...原生事件绑定 虽然React为我们提供了合成事件,但是在实际开发因为各种各样的原因我们无法避免的会用到原生的事件绑定,例如ReactDOM的Portal传送门,其是遵循合成事件事件流而不是DOM的事件流...我们分别对ref1与ref2两个button进行了原生事件绑定,其中ref1的事件绑定是在组件挂载的时候进行的,而ref2的事件绑定是在count发生变化的时候进行的,看起来代码上只有依赖数组[]和[count

    1.9K30
    领券