154

How to enable or disable an anchor using jQuery?

3
  • Thanks for all your answer, Still it is not working so can You please make it work with document.ready function Commented Jul 22, 2009 at 12:21
  • It might help if you post the snippet of code that isn't working. Commented Jul 22, 2009 at 12:26
  • Actually My coding is in Rails and my coding is <%= foo.add_associated_link('Add email', @project.email.build) %> when it I render it into browser i can see the email but i cannot disabled it even i tried with coding such as e.preventDefault() but of no result Commented Jul 23, 2009 at 4:28

16 Answers 16

194

To prevent an anchor from following the specified href, I would suggest using preventDefault():

// jQuery 1.7+
$(function () {
    $('a.something').on("click", function (e) {
        e.preventDefault();
    });
});

// jQuery < 1.7
$(function () {
    $('a.something').click(function (e) {
        e.preventDefault();
    });

    // or 

    $('a.something').bind("click", function (e) {
        e.preventDefault();
    });
});

See:

http://docs.jquery.com/Events/jQuery.Event#event.preventDefault.28.29

Also see this previous question on SO:

jQuery disable a link

Sign up to request clarification or add additional context in comments.

6 Comments

I tried with those "attr" it is working only on form element not on Anchor tag.
@senthil - preventDefault is considered the 'proper' way of doing this, see my edit (link to another Q+A)
Actually My coding is in Rails and my coding is <%= foo.add_associated_link('Add email', @project.email.build) %> when it I render it into browser i can see the email but i cannot disabled it even i tried with coding such as e.preventDefault() but of no result
how do I reverse $('a.something').on("click", function (e) { e.preventDefault(); });?
Disagree, use CSS "pointer-events: none;" instead, just like in other unswers.
|
118

The app I'm currently working on does it with a CSS style in combination with javascript.

a.disabled { color:gray; }

Then whenever I want to disable a link I call

$('thelink').addClass('disabled');

Then, in the click handler for 'thelink' a tag I always run a check first thing

if ($('thelink').hasClass('disabled')) return;

4 Comments

Shouldn't that last line say "return false;"?
Good call, Prestaul. When tied in to an <a> tag, I'm using: <a href="whatever" onclick="return disableLink(this)"> .. then: function disableLink(node) { if (dojo.hasClass(node, 'disabled') return false; dojo.addClass(node, 'disabled'); return true; } .. this allows the link to be clicked once and action (return true) and after that it doesn't allow the action (returns false).
Note that in the handler you probably should use $(this) instead of $("thelink") since that could change or the user could that way easily copy/paste the code.
Suggest you also add 'cursor: default' to the disabled style.
41

I found an answer that I like much better here

Looks like this:

$(document).ready(function(){
    $("a").click(function () { 
        $(this).fadeTo("fast", .5).removeAttr("href"); 
    });
});

Enabling would involve setting the href attribute

$(document).ready(function(){
    $("a").click(function () { 
        $(this).fadeIn("fast").attr("href", "http://whatever.com/wherever.html"); 
    });
});

This gives you the appearance that the anchor element becomes normal text, and vice versa.

Comments

13

Selected Answer is not good.

Use pointer-events CSS style. (As Rashad Annara suggested)

See MDN https://developer.mozilla.org/en-US/docs/Web/CSS/pointer-events. Its supported in most browsers.

Simple adding "disabled" attribute to anchor will do the job if you have global CSS rule like following:

a[disabled], a[disabled]:hover {
   pointer-events: none;
   color: #e1e1e1;
}

1 Comment

Also with pointer-events you won't need to include the :hover state as that is a pointer event. You only need include the a[disabled] selector.
12
$("a").click(function(){
                alert('disabled');
                return false;

}); 

Comments

12

I think a nicer solution is to set disabled data attribute on and anchor an check for it on click. This way we can disable temporarily an anchor until e.g. the javascript is finished with ajax call or some calculations. If we do not disable it, then we can quickly click it a few times, which is undesirable...

$('a').live('click', function () {
    var anchor = $(this);

    if (anchor.data("disabled")) {
        return false;
    }

    anchor.data("disabled", "disabled");

    $.ajax({
        url: url,
        data: data,
        cache: false,
        success: function (json) {
            // when it's done, we enable the anchor again
            anchor.removeData("disabled");
        },
        error: function () {
             // there was an error, enable the anchor
            anchor.removeData("disabled");
        }
    });

    return false;
});

I made a jsfiddle example: http://jsfiddle.net/wgZ59/76/

Comments

10

Try the below lines

$("#yourbuttonid").attr("disabled", "disabled");
$("#yourbuttonid").removeAttr("href");

Coz, Even if you disable <a> tag href will work so you must remove href also.

When you want enable try below lines

$("#yourbuttonid").removeAttr("disabled");
$("#yourbuttonid").attr("href", "#nav-panel");

1 Comment

This is exactly what I needed when using JQuery with ASP.net MVC ActionLink. Thanks!
10
$('#divID').addClass('disabledAnchor');

In css file

.disabledAnchor a{
       pointer-events: none !important;
       cursor: default;
       color:white;
}

Comments

8

It's as simple as return false;

ex.

jQuery("li a:eq(0)").click(function(){
   return false;
})

or

jQuery("#menu a").click(function(){
   return false;
})

Comments

5
$("a").click(function(event) {
  event.preventDefault();
});

If this method is called, the default action of the event will not be triggered.

Comments

4

If you are trying to block all interaction with the page you might want to look at the jQuery BlockUI Plugin

Comments

4

You never really specified how you wanted them disabled, or what would cause the disabling.

First, you want to figure out how to set the value to disabled, for that you would use JQuery's Attribute Functions, and have that function happen on an event, like a click, or the loading of the document.

Comments

1

For situations where you must put text or html content within an anchor tag, but you simply don't want any action to be taken at all when that element is clicked (like when you want a paginator link to be in the disabled state because it's the current page), simply cut out the href. ;)

<a>3 (current page, I'm totally disabled!)</a>

The answer by @michael-meadows tipped me off to this, but his was still addressing scenarios where you still have to / are working with jQuery/JS. In this case, if you have control over writing the html itself, simply x-ing the href tag is all you need to do, so the solution is a pure HTML one!

Other solutions without jQuery finagling which keep the href require you to put a # in the href, but that causes the page to bounce to the top, and you just want it to be plain old disabled. Or leaving it empty, but depending on browser, that still does stuff like jump to the top, and, it is invalid HTML according to the IDEs. But apparently an a tag is totally valid HTML without an HREF.

Lastly, you might say: Okay, why not just dump the a tag altogether than? Because often you can't, the a tag is used for styling purposes in the CSS framework or control you're using, like Bootstrap's paginator:

http://twitter.github.io/bootstrap/components.html#pagination

Comments

1

So with a combination of the responses above, I came up with this.

a.disabled { color: #555555; cursor: default; text-decoration: none; }

$(".yourClass").addClass("disabled").click(function(e){ e.preventDefault(); 

Comments

0

If you don't need it to behave as an anchor tag then I would prefer to replace it at all. For example if your anchor tag is like

<a class="MyLink" href="http://www.google.com"><span>My</span> <strong>Link</strong></a>

then using jquery you can do this when you need to display text instead of a link.

var content = $(".MyLink").text(); // or .html()
$(".MyLink").replaceWith("<div>" + content + "</div>")

So this way, we can simply replace anchor tag with a div tag. This is much easier (just 2 lines) and semantically correct as well (because we don't need a link now therefore should not have a link)

Comments

0

Disable or Enable any element with the disabled property.

// Disable 
$("#myAnchor").prop( "disabled", true );

// Enable
$( "#myAnchor" ).prop( "disabled", false );

2 Comments

Why is this answer down voted? It answers the question "How to enable or disable an anchor using jQuery?"
I believe it is because links still get opened when clicked on the anchor.

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.