首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >JQuery:将onClick属性转换为jQuery单击

JQuery:将onClick属性转换为jQuery单击
EN

Stack Overflow用户
提问于 2011-10-20 08:27:02
回答 1查看 1.1K关注 0票数 0

我有一个带有100+超链接的网页,所有这些都设置了onClick和href属性。这在很大程度上是有效的,但是我遇到了这样的问题:像IE7这样的浏览器使用href属性而不是onClick属性。我需要将onClick属性设为默认值,这样我的函数才能在单击时加载。我想我可以使用jQuery并将单击事件设置为onClick属性值来轻松完成此操作,但我没有任何运气,我该如何做呢?现在,下面的代码将成吨的点击事件设置为一个超链接。当我单击一个超链接时,我可以多次查看为该超链接发送的GET事件。

代码语言:javascript
运行
复制
    $("a[href*='/RightSizeOption/NewForm.aspx']").click(function() {
        OpenPopUpPage($(this).attr('href'), RefreshPage); 
        return false;
    });
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-10-20 08:51:57

这似乎没有什么意义,除非确切的click处理程序实际上被多次绑定。绑定点击的一个更好的方法是使用委托(也可以使用preventDefault而不是return false ):

代码语言:javascript
运行
复制
$('#myParent').delegate("a[href*='/RightSizeOption/NewForm.aspx']", "click", function(event) {
  event.preventDefault();
  OpenPopUpPage($(this).attr('href'), RefreshPage); 
});

#myParent是任何不会被销毁的祖先元素;可以是包装器div或'body‘,尽管最好选择最接近的共同祖先,永远不会被销毁。

但是让我担心的是多重绑定;例如,如果您的示例代码在一个函数中,则该函数会被多次触发。

我也不确定您传递给OpenPopUpPage的"RefreshPage“。我必须看看OpenPopUpPage做了什么才能大胆猜测。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7829797

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档