admin管理员组

文章数量:1312718

I'd like to use the js method .click() as follows:

document.getElementById(id).click();

But since it is essential that it works, I was wondering of what browsers support the .click() method has.

I'd like to use the js method .click() as follows:

document.getElementById(id).click();

But since it is essential that it works, I was wondering of what browsers support the .click() method has.

Share Improve this question asked Oct 30, 2012 at 14:46 dondon 4,54214 gold badges48 silver badges73 bronze badges 4
  • 2 If you are really worried about cross-browser patability, then I'd suggest using a JS library like jQuery. – gen_Eric Commented Oct 30, 2012 at 14:52
  • Do you know what could replace the .click() method in jQuery? – don Commented Oct 30, 2012 at 14:58
  • 2 The .click method :-) – gen_Eric Commented Oct 30, 2012 at 15:02
  • Are you talking about .onclick()? This is native javascript to bind a click event and is supported in all major browsers. – Andrew Klatzke Commented Jan 22, 2013 at 20:55
Add a ment  | 

3 Answers 3

Reset to default 4

The only browser I have encountered that does not support .click() is Safari. Safari supports .click() on buttons (e.g. <input type="button" />) but not on other elements such as anchor elements (e.g. <a href="#">Click Me</a>).

For Safari, you have to use a workaround:

function click_by_id(your_id)
{
    var element = document.getElementById(your_id);
    if(element.click)
        element.click();
    else if(document.createEvent)
    {
        var eventObj = document.createEvent('MouseEvents');
        eventObj.initEvent('click',true,true);
        element.dispatchEvent(eventObj);
    }
}

Using the above function, you can support 90%+ of browsers.

Tested in IE7-10, Firefox, Chrome, Safari.

According to MDN, HTMLElement.click() is supported by Chrome 20+, Firefox 5+ and Safari 6+. But that might be inaccurate.

I had this problem and used it instead of $('#selector').click(function(){}); , used (document).on('click','#selector',function(){});

本文标签: javascriptclick() methodbrowser supportStack Overflow