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

如何实现动态添加元素添加点击事件

在页面开发过程中常常遇到需要动态添加元素,然后给这一元素绑定相关事件情况,这种情况下一般需要给元素加上相关属性,然后写这些元素事件函数即可。动态添加元素怎么绑定事件呢?...原生JavaScript 原生JavaScript主要有2种实现方式,第一种是在动态添加html代码中添加oclick事件,然后传递一个唯一参数来判断点击是哪个,然后做相应操作。...第二种是通过事件委托原理进行处理,事件委托将一个 事件监听器实际上绑定到整个容器,然后每个列表项被点击就可以访问,这样效率更高。...该事件附加到staticAncestors应处理元素静态父级 ( )。 每次在此元素或后代元素之一上触发事件时,都会触发此 jQuery 处理程序。...eventName, function(){} ); 可以替换为以下on()方法: $(document).on( eventName, selector, function(){} ); ---- 例如,如果您页面使用类名动态创建元素

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

Js - JQ事件委托( 适用于给动态生成脚本元素添加事件

最近一段时间打了一个大仗,现在总算消停点,才有时间来做个总结吧算是: 移动端遇到一个项目,是一个列表侧滑栏,在我这里用jq写交互事件。自测各方面都挺好,美滋滋给了研发。...研发也美滋滋开始开发。 但是,好景不长。。。 研发加了ajax事件后,我交互效果有部分受了影响! 一个小姑娘,在一群大老爷们研发堆里,对着昏暗电脑和看不太懂后台代码,改了半天。最后没解决。...,是通过获取元素类名被点击后执行对应方法,但是研发套完模板,他会把所有的结构先清空,导致jq根本找不到那个元素,所以事件就不得执行了。...正规点说:JS异步加载,JQ事件不被执行解决方法(百度标题,hah) jquery中动态新增元素节点无法触发事件问题(同上) 解决方法: ? ?...值得注意是:亲测此方法无效,可能是我用jq版本太高了,1.9多,已经不支持这个方法了 第二个方法: ? 但是缺点是:给一个元素添加多个事件委托机制时,他就挂了。  王者方法:on ?

4.8K50

【IOC 控制反转】Android 事件依赖注入 ( 事件依赖注入具体操作细节 | 创建 事件监听器 对应 动态代理 | 动态代理数据准备 | 创建调用处理程序 | 创建动态代理实例对象 )

文章目 前言 一、创建 事件监听器 对应 动态代理 二、动态代理 数据准备 三、动态代理 调用处理程序 四、动态代理 实例对象创建 前言 Android 依赖注入核心就是通过反射获取 类 / 方法...| 监听器回调方法 ) ; 事件依赖注入比较复杂 , 涉及到动态代理 , 本博客分析 【IOC 控制反转】Android 事件依赖注入 ( 事件依赖注入代码示例 ) 事件依赖注入详细步骤 ; 本博客核心是...onClick , onLongClick , onTouch 方法 , 执行自己方法 , 其它方法正常执行 ; 一、创建 事件监听器 对应 动态代理 ---- 为组件设置监听器可能是 View.OnClickListener..., 创建一个 代理对象 , 代理 上述 匿名内部类 被代理对象 , 要在调用 onClick 方法时 , 注入自己业务逻辑 ; 该动态代理中元素梳理 : 目标对象 ( 主题对象 ) : View.OnClickListener...方法 , 创建动态代理 实例对象 , 传入到代理接口数组 , 这个接口数组元素可以是 View.OnClickListener.class 或 View.OnLongClickListener.class

2.3K10

前端JavaScript中动态事件添加

前言 在前端开发中,交互性是至关重要动态事件添加是一种在JavaScript中实现交互重要技术。本文将介绍动态事件添加概念和优势,并详细介绍两种常用动态事件添加方法。...减少重复代码: 可以通过动态事件添加方式,避免在HTML中为每个元素都编写相同事件处理代码。...可以通过以下步骤动态添加事件: 1.获取需要添加事件DOM元素。 2.使用addEventListener()方法,指定要添加事件类型和对应事件处理函数。...3.事件处理函数中编写具体操作逻辑。 通过事件委托实现动态事件绑定 事件委托是一种利用事件冒泡原理动态事件绑定技术。通过将事件绑定到父元素上,可以在父元素上捕获子元素触发事件。...3.在父元素事件处理函数中,通过判断事件目标元素,确定要执行操作。 总结 动态事件添加是前端开发中实现交互性重要手段。通过动态事件添加,我们可以实现灵活、可扩展交互效果,减少重复代码编写。

18620

「1 分钟学 DOM 基础操作」添加和移除元素样式、添加元素内、添加和移除事件、计算鼠标相对元素位置

一、添加或移除样式 1、添加相关样式至对应 DOM 元素 注意:如果添加多个样式至 DOM 元素,IE11 不兼容。...ele.classList.toggle('class-name'); 二、将元素添加至指定DOM元素末尾 将 ele 元素添加至 target 元素末尾 target.appendChild...(ele); 三、添加和移除事件 1、使用 ON 属性添加事件(不推荐) 你可以在 dom 元素使用 on{eventName} 属性,eventName 代表事件名,代码如下: ele.onclick...= function() { ... }; // Remove the event handler delete ele.onclick; 不推荐这种方法,主要是因为很容易造成事件覆盖问题...四、计算鼠标在元素相对位置 要计算鼠标点击事件,鼠标在元素相对位置,我们需要用到 getBoundingClientRect() 这个关键方法,示例代码如下: ele.addEventListener

1.6K30

JSjQuery获取不到动态添加元素节点解决方法

今天写了一个添加图片功能,要求右上角要有删除按钮,我使用 jQuery 动态添加方式。...发现后添加元素无法删除,打印显示 undefined ,原来 JavaScript 和 jQuery 无法获取动态添加元素节点。...解决方法: 动态添加标签要事件委托才能获取到节点,也就是说要用: $(selector).on(events,[selector],[data],fn) 属性解析: 参数 描述 events 一个或多个用空格分隔事件类型和可选命名空间...我们追加元素父节点添加事件委托,就调用里面子节点了: 举个栗子,我在 .sup-img-box 中添加了子节点 .cert-img 。...,这里要保证该父级节点不是动态添加,不然同样会获取不到。

6.8K10

Angular动态创建元素一些坑

在html文件中 用ngFor 动态生成子html 元素自定义属性,比如data-title ,发现angular报错,不让用 。解决办法:采用 attr.自定义属性名 即可 ?...实现拖拽功能 需要复制html元素 append到其他元素时 希望将原始html标签上 (click) 事件属性也一起复制,发现angular会自动将(click) 删除 ,无奈需要在ts里动态添加click...angular在页面渲染时会为html元素自动增加属性 _ngcontent-c[数字] ,angular某些class样式和这类属性密切耦合影响页面样式 ;而在ts代码中动态复制html标签时该属性还没有生成...,动态复制html元素不会被再次渲染生成 _ngcontent-c[数字] 属性,因此复制html与原始html样式无法一致 。...解决方法, 复制html代码时候通过 dom对象.attributes[0].name 获取该属性名 ,将该属性名 添加动态html属性上 新对象.setAttribute(属性,'') ?

2.4K20

原生js怎么为动态生成标签添加各种事件

这几天用zepto.js写了不少事件,突然想到一个问题,那就是原生js如何给动态生成标签添加事件?...因为这些标签都是后来通过ajax或者运行其他点击事件生成,那么如果之前给他们写事件他们这个dom对象是找不到,jq通过事件委托解决了这个问题,但是原生js这个问题该怎么解决呢?...我在网上查了很多资料,好像只有一种办法,那就是在生成标签并把标签添加到html结构中后再添加对于这个新标签各种事件,如果有更好方法,欢迎提出来。 <!...document.getElementById('a').appendChild(myp); alert(document.getElementsByTagName('p')[0]) myp.innerHTML = '我是新建<em>的</em>p...标签'; document.getElementsByTagName('p')[0].onclick = function(){ alert('我是p点击事件') } } <

7.9K50
领券