jQuery 查找on事件绑定元素的被绑定元素方法 遇到的问题 今天写了一个JQ插件,结果里面有一点问题.让我很郁闷.问题演示代码如下 $box.on('click', 'img', function(...){ $(this) }); 如上代码,当我点击这个图片的时候 $(this) 是指 img ....当然这是正确的. 而我需要找到 $box 也就是 img 的父级. 如果不是插件的话,我当然可以根据它的ID或者CLASS来进行查询.问题是,我是写的插件,也就是说,我并不知道它的这些信息是什么....解决方法 很多基础的东西不理解,就会出现我这样的问题.如同事所说,你是还不会爬呢,都学上跑了.因此,踩坑无数啊....解决方法如下: $box.on('click', 'img', function(){ $box.has($(this)) }); 如上,通过 .has 操作,就能找到唯一的父级被绑定元素了.
原生 js 直接作为方法调用即可触发。...div.login-content > div.content-right > div > div > div.login-panel-input.login-submit-panel > button"); // 调用按钮事件进行点击...login_btn.click(); 可以看到效果图: jquery 通过 trigger() 方法触发点击事件。...div.content-right > div > div > div.login-panel-input.login-submit-panel > button").trigger("click") 使用前提是该 dom 元素必须绑定的事件才能出发...,他的祖先元素绑定的事件他触发不了,所以这里要把 Ancestors All 取消勾选一下。
避免先写了DOM操作,但是元素是动态加载的,所以点击不生效,比较好的方法有两个: 1、动态添加的时候加行内事件,比如onclick="funcName()" 在js中写好方法名对应的方法就可以了,如果绑定方法的元素太多...,可以考虑使用方法二; 2、jquery的on事件绑定 eg: on事件可以给动态添加的元素也绑定事件。...console.log("aaa") let num = $(this).parents(".input-group").index(); console.log(num) }) 注意:on事件先是获取到父元素...,然后绑定到子元素上,父元素最好是已经存在的元素,而不是动态添加的。
前面业务里有个搜索功能 , 入口比较深 , 现在想要把入口挪到有公共header的地方 , 在不想完全实现一遍功能的情况下 , 就需要模拟进行多个点击事件来执行点击后的效果 ?...执行先点击1 ,再给inout赋值 ,再点击2 基本思路是类似jquery的trigger方法 , 原生js也是可以实现 , 代码如下 按钮1 按钮2 // 假如想通过点击 Button-1 触发 Button-2 的某个事件 let btn_1 = document.getElementById...// do something } <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.<em>js</em>...<em>方法</em> $( "#btn-3" ).click(function() { alert("按钮3"); $( "#btn-4" ).trigger( "click" ); }); $( "#btn
一个简单的记录,在调试jquery的事件绑定时会用到。查看某元素是否绑定上了事件。
JS动态加载数据绑定事件-委托delegate() 方法 ---- W3C规范定义 定义和用法 delegate() 方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数...使用 delegate() 方法的事件处理程序适用于当前或未来的元素(比如由脚本创建的新元素)。...---- JavaScript动态加载的数据,同时给他加载绑定事件,我选用Jquwey中的 delegate() 方法 我的理解,delegate()方法属于异步式加载绑定,dom元素加载未完成之前,可以委托给...delegate() 方法来实现的绑定操作。...要点击的标签属性 第二个参数为 要绑定的事件 详情,请翻阅delegate() 方法 ---- 效果如图的返回按钮:
mousedown: Array(1)} mousedown: [{…}] mouseout: [{…}] __proto__: Object getEventListeners() 方法可以获取到...dom 元素的监听。...可以看到当前 dom 节点的监听就是 mousedown 和 mouseout。 取消勾选 Ancestors All 可以排除当前元素所有祖先元素的监听。...反过来如果想通过代码获取某个元素所有祖先元素的监听可以遍历它的所有上级节点再依次获取所有 dom 节点的监听。
js通过事件代理的方式绑定跳转事件,我这里的逻辑是把click事件绑定在最外层container上面,如果e.target包含我已经写好的class,则执行跳转逻辑。...但是这种方式好像只能是在点击的元素的上面,也就是最内层的元素上面有相应的class才能跳转,在外层加同样的class不生效,说明是我对于事件代理的理解不够深刻,其实事件代理的作用就是为了把目标元素的事件绑定在外层做代理...jumpUrl的 class时执行点击事件,又想要外层元素含有class时执行点击事件,修改优化如下: document.querySelector('#container').addEventListener...('click', function (e) { console.log(e.currentTarget) //获得当前绑定监听事件的元素, container console.log...注意:内层元素,即点击的目标元素必须是点击时真正的目标元素,而不是外面一层; currentTarget绑定相应想要点击的class的时候必须是做代理的即做事件监听的元素。
方式一: btn.onclick = function (){ console.log("123"); }; btn.oncl...
3、当设置参数为 200 或者 200px的时候是设置元素的宽高为 200px。 4、以上方法不仅可以获取行内式元素的宽高,也可以获取嵌入式写法元素的宽高。...四、为元素绑定事件 1、方式一:(事件名) 语法: 元素.事件名(事件处理函数); 示例: // 绑定鼠标进入,离开,点击事件 $("#btn").mouseenter(function ()...4、方式四:(delegate方法) 语法:(父元素替子元素绑定事件) 父元素.delegate("子元素","事件名",事件处理函数); 示例: // 为div下p标签绑定点击事件 $("#dv")....语法: 父元素.on("事件名", "子元素", 事件处理函数); 示例: // 为div下p标签绑定点击事件 $("#dv").on("click", "p", function () { //....... }); PS:on 其实不仅可以给子元素绑定事件,还可以给自己绑定事件,这时候只需要把子元素的参数去掉就好了。
Code: $('code').click(function () { console.log($(this).text()); }); New Code:(.container 是所在的div...'.container').on("click", "code", function () { console.log($(this).text()); }); 之前只是知道官方推荐使用on来生成事件...,并不知道其好处,这次知道了 话说,,,真的好久没碰前端了,忘差不多了,O(∩_∩)O~ 动态加载JS 和 CSS 在线浏览PDF之PDF.JS (附demo) 几个比较有意思的JS脚本 经典JS
事件绑定 要想让 JavaScript 对用户的操作作出响应,首先要对 DOM 元素绑定事件处理函数。所谓事件处理函数,就是处理用户操作的函数,不同的操作对应不同的名称。...在JavaScript中,有三种常用的绑定事件的方法: 在DOM元素中直接绑定; 在JavaScript代码中绑定; 绑定事件监听函数。...; } 使用事件监听绑定事件 绑定事件的另一种方法是用 addEventListener() 或 attachEvent() 来绑定事件监听函数。下面详细介绍,事件监听。...DOM元素,不需要因为元素的改动而修改事件绑定。...说明传统的事件绑定无法对动态添加的元素而动态的添加事件。
往期文章 【Node.JS】写入文件内容 【Node.JS】读取文件内容 目录 简介 绑定事件 on() addListener() once() 监听事件emit() 传参 删除事件 removeListener...() removeAllListeners() ---- 简介 node.js的事件是使用events模块,通过实例化它里面的EventEmitter类,来绑定和监听事件。...('namea', function () { console.log("坚毅的小解同志"); }) 查看绑定的事件 const eve = require("events"); //导入模块..."); }) //查看对象属性 里面有绑定的事件 console.log(event); 里面有事件具体的属性,和事件的数量。...{a}同志`); }) //触发事件冰川入参数 event.emit('namea', '小解'); once() once 只会绑定一次性的触发事件,触发一次后就会解除绑定。
一、为元素绑定多个相同事件 1、方式一 $("#btn").click(function () { console.log("click1"); }).click(function...,只会执行最后一个相同的绑定事件。...先说结论:通过调用事件名的方式和 bind 的方式只能绑定之前存在的元素,后添加的元素不能绑定事件;而 delegate 和 on 的方式绑定元素的方式可以。...1、bind 解绑事件 语法: // 解绑单个或多个事件 绑定事件的元素.unbind("事件名1 事件名2 ..."); // 解绑所有的事件 绑定事件的元素.unbind(); PS:unbind...也可以解绑 元素.事件名(事件处理函数) 方式的绑定事件。
最先想到的是浏览器面板上面的,可以选中元素,看元素上面的事件绑定。 但浏览器上面看到的是结果量,也就是看到的是已经丢失了事件的元素,但我还是不知道什么时候丢失的。...我可以断点取到每个阶段的HTMLElement元素的状态,但是,这个时候,我却找不到观察其事件绑定情况的方法。 谷歌好久,发现JS原生是没法查看事件绑定情况的。...还好,我们都是用的jQuery,用的$.on()。 而jQuery自身事件绑定,额外添加了一层事件数组。...(也是这个原因,$.on()可以重复给一个元素的同一个事件绑定多个handler,而直接addEventListener则只能绑定一个,后面的会覆盖掉前面的) 扯了这么多,show me the code...,就会返回这个元素上面绑定的所有事件。
一、为元素绑定多个事件 前导:如果一个按钮绑定了多个点击事件,那么点击按钮的时候只会执行最后一个点击事件,前面的点击事件都被覆盖了。那么如何为一个按钮绑定多个相同的事件,并且每个事件都会执行呢?...3"); }); my("dv").onclick == my$("dv")["onclick"] 3、绑定事件的区别 方法名不同; 参数个数不同...---- 二、为元素解绑事件 1、三种方式 1.1、方式一 如果使用 元素.onclick = function(){}; 的方式绑定对象的话,解绑的方式为 元素.onclick = null; 1.2...、方式二 如果使用 元素.addEventListener("click", f1, false); 的方式绑定对象的话,解绑方式为 元素.removeEventListener("click", f1...1.3、方式三 如果使用 元素.attachEvent("onclick", f1); 的方式绑定对象的话,解绑方式为 元素.detachEvent("onclick", f1); 2、解绑事件兼容代码
在Web开发中,有时候我们可能会把页面中的某些按钮绑定到键盘的输入事件中。以下代码能方便实现我们需要的功能。...js代码: document.onkeyup = function (event... default: break; } } 在Web开发中,有时候我们可能会把页面中的某些按钮绑定到键盘的输入事件中...以上代码能方便实现我们需要的功能。...属性判断输入的键值 eg:if(event.keyCode==13)alert(“enter!”)
可对函数进行如下扩展 Function.prototype.bind = function(obj) { var _this = this; ...
HTML 中绑定事件类似,使用驼峰式命名指定要绑定的 onClick 属性为组件定义的一个方法 {this.handleClick.bind(this)}。...“合成事件”还提供了额外的好处: 2.1 事件委托 事件委托就是利用事件冒泡原理,把处理任务委托给父元素或者祖先元素(通常用父元素),我们通过目标对象来判断事件源,并执行事件处理。...2.2 原生事件 比如你在 componentDidMount 方法里面通过 addEventListener 绑定的事件就是浏览器原生事件。...3、事件绑定的几种方法 由于类的方法默认不会绑定this,因此在调用的时候如果忘记绑定,this的值将会是undefined。 通常如果不是直接调用,应该为方法绑定this。...3.1 方法在构造函数中绑定了 this,调用的时候不需要二次绑定 优点:只会生成一个方法实例,并且绑定一次之后如果多次用到这个方法也不需要绑定了。
领取专属 10元无门槛券
手把手带您无忧上云