Unobtrusive JavaScript in links

126 views Asked by At

I want a link to either execute a JavaScript function (if JavaScript is available) or enter the URL in the href attribute if it's not.

<a href="http://www.example.com" onclick="example(); return false;">

In this example, I'd want to execute example() and not enter the link if JavaScript is available or go to http://www.example.com if JavaScript is unavailable.

While this works in almost every browser I've tried it with, in IE 7, regardless of if JavaScript is active or not, it just follows the link. What can I do to prevent this?

4

There are 4 answers

0
Aeolun On BEST ANSWER

This may be what you are looking for

event.returnValue = false;

Retrieved from here: event.preventDefault() function not working in IE

0
Meisam Mulla On

Try this:

<a href="http://www.example.com" onclick="example(); event.returnValue=false; return false;">
0
Dmitry Pashkevich On

You have to use preventDefault() on the event object to prevent the default action (that is, navigating to the link's URL).

Because the implementation differes a little bit in browsers, you should write a separate function for doing this and call it in your event handler:

function preventDefault(event) {
        if (event.preventDefault) {
            event.preventDefault();
        } else {
            event.returnValue = false;
        }
}

Also, be sure to return false in your event handler.

If you're using any JavaScript library, then this functionality is very likely to already be present.

2
ValeriiVasin On

Separate your javascript from HTML :)

<a href="http://www.example.com" id='uniq-link'>
$(function () {
    $("#uniq-link").on("click", example);
});

If Javascript is unavailable - all will be ok :)