有人知道如何在jquery中禁用一个链接而不使用return false吗?

具体来说,我要做的是禁用一个项目的链接,使用jquery执行点击它触发一些东西,然后重新启用该链接,以便如果它再次单击它作为默认工作。

谢谢。 戴夫

更新 这是代码。在应用.expanded类之后,它需要做的是重新启用被禁用的链接。

$('ul li').click(function(e) {
    e.preventDefault();
    $('ul').addClass('expanded');
    $('ul.expanded').fadeIn(300);
    //return false;
});

当前回答

试试这个:

$("a").removeAttr('href');

编辑-

从您更新的代码:

 var location= $('#link1').attr("href");
 $("#link1").removeAttr('href');
 $('ul').addClass('expanded');
 $('ul.expanded').fadeIn(300);
 $("#link1").attr("href", location);

其他回答

$('#myLink').click(function(e) {
    e.preventDefault();
    //do other stuff when a click happens
});

这将防止超链接的默认行为,即访问指定的href。

jQuery教程:

对于点击和大多数其他事件,您 可以防止默认行为- 点击链接,进入jquery。com -通过在事件处理程序中调用event. preventdefault ()

如果只希望在满足某个条件(例如隐藏了某些东西)时才使用preventDefault(),则可以使用扩展的类测试ul的可见性。如果它是可见的(即不隐藏),链接应该正常触发,因为If语句不会被输入,因此默认行为将不会被阻止:

$('ul li').click(function(e) {
    if($('ul.expanded').is(':hidden')) {
        e.preventDefault();
        $('ul').addClass('expanded');
        $('ul.expanded').fadeIn(300);
    } 
});

只需设置preventDefault并返回false

   $('#your-identifier').click(function(e) {
        e.preventDefault();
        return false;
    });

这将是禁用链接,但仍然,你会看到一个可点击的图标(手)图标。你也可以删除下面

$('#your-identifier').css('cursor', 'auto');

您可以删除点击链接按以下;

$('#link-id').unbind('click');

您可以通过以下操作重新启用链接,

$('#link-id').bind('click');

不能对链接使用“disabled”属性。

unbind()在jQuery 3中已弃用,请使用off()方法代替:

$("a").off("click");

只要触发东西,设置标志,返回false。如果设置了flag -什么都不做。