为了账号安全,请及时绑定邮箱和手机立即绑定

请问在jQuery()中,on()方法,求大神解释!

请问在jQuery()中,on()方法,求大神解释!

慕哥6287543 2021-11-04 07:07:19
1.7以后,live()方法就被on()方法替代了,我用PHP+jQuery+Ajax做了一个用户登录界面,初始的时候没有<p><a href='#' id='logout'>【退出】</a></p>这个按钮,是在点击登录以后出来的,现在想写一个$("#logout").on('click',function()这个方法,但是根据定义:$('#Grid1Table').on('click', '#count', function() { //function code here. }); #Grid1Table是#count的父节点以上的节点 问该怎么写,#logout有父节点嘛?求代码
查看完整描述

3 回答

?
不负相思意

TA贡献1777条经验 获得超10个赞

概述

1、#Grid1Table不是#conut的父节点,p标签是#logout的父节点

2、代码写法:

$('p').on('click', '#count', function() {
//function code here.
});

解析

1、p包裹a标签(id = logout),所以logout的父节点(父标签)为p(没有标注id或者class)

<p><a href='#' id='logout'>【退出】</a></p>

2、$("#logout").on('click',function() 方法要求参数为非随动变量(全局变量),所以#logout为不可行参数,且由于代码没有贴全所以这里我先断定#Grid1Table为非父节点,而p为#logout父节点,所以这里可以改成:

$('p').on('click', '#count', function() {
//function code here.
});

拓展内容

juqery on()方法详解

定义和用法

on() 方法在被选元素及子元素上添加一个或多个事件处理程序。

自 jQuery 版本 1.7 起,on() 方法是 bind()、live() 和 delegate() 方法的新的替代品。该方法给 API 带来很多便利,我们推荐使用该方法,它简化了 jQuery 代码库。

注意:使用 on() 方法添加的事件处理程序适用于当前及未来的元素(比如由脚本创建的新元素)。

提示:如需移除事件处理程序,请使用 off() 方法。

提示:如需添加只运行一次的事件然后移除,请使用 one() 方法。

语法

$(selector).on(event,childSelector,data,function)

参数

event                必需。规定要从被选元素移除的一个或多个事件或命名空间。由空格分隔多个事件值,也可以是数组。必须是有效的事件。    

childSelector    可选。规定只能添加到指定的子元素上的事件处理程序(且不是选择器本身,比如已废弃的 delegate() 方法)。    

data                  可选。规定传递到函数的额外数据。    

function            可选。规定当事件发生时运行的函数。    



查看完整回答
反对 回复 2021-11-09
?
慕侠2389804

TA贡献1719条经验 获得超6个赞

$("#logout").on('click',function(){});

也是可以的。不过有个限制,你的这个$("#logout"),不能是后期动态添加的节点。

如果像表格里动态添加的行,要使用事件,就要用下面你说的方法。

$('#Grid1Table').on('click', '#count', function() {
//function code here.
});

#logout有父节点嘛?当然有。

<p><a href='#' id='logout'>【退出】</a></p>

p就是父节点。

$('p').on('click', '#count', function() {
//function code here.
});



查看完整回答
反对 回复 2021-11-09
?
慕森卡

TA贡献1806条经验 获得超8个赞

on的用法:
.on( events [, selector ] [, data ], handler(eventObject) )
描述: 在选定的元素上绑定一个或多个事件处理函数。
events
类型: String
一个或多个空格分隔的事件类型和可选的命名空间,或仅仅是命名空间,比如"click", "keydown.myPlugin", 或者 ".myPlugin"。
selector
类型: String
一个选择器字符串,用于过滤出被选中的元素中能触发事件的后代元素。如果选择器是 null 或者忽略了该选择器,那么被选中的元素总是能触发事件。
data
类型: Anything
当一个事件被触发时,要传递给事件处理函数的event.data。
handler(eventObject)
类型: Function()
事件被触发时,执行的函数。若该函数只是要执行return false的话,那么该参数位置可以直接简写成 false。

.on()方法事件处理程序到当前选定的jQuery对象中的元素。在jQuery 1.7中,.on()方法 提供绑定事件处理的所有功能。要删除的.on()绑定的事件,使用.off()。要绑定一个事件,并且只运行一次,然后删除自己, 使用.one()


查看完整回答
反对 回复 2021-11-09
  • 3 回答
  • 0 关注
  • 381 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信