What does role=“button” mean?

前端 未结 3 440
粉色の甜心
粉色の甜心 2021-02-02 05:30

I found that in Google+ Project\'s page that buttons are all made from divs like:

I\'d like to

3条回答
  •  臣服心动
    2021-02-02 05:57

    It tells accessibility (and other) software what the purpose of the div is. More here in the draft role attribute specification.

    Yes, it's just semantic. Sending a click event to the button should work.


    An earlier version of this answer (back in 2011) said:

    ...but jQuery's click function doesn't do that; it triggers only the event handlers that have been hooked up to the element with jQuery, not handlers hooked up in other ways.

    ...and provided the sample code and output below.

    I cannot replicate the output now (two years later). Even if I go back to earlier versions of jQuery, they all trigger jQuery handlers, DOM0 handlers, and DOM2 handlers. The order isn't necessarily the same between a real click and jQuery's click function. I've tried jQuery versions 1.4, 1.4.1, 1.4.2, 1.4.3, 1.4.4, 1.5, 1.5.1, 1.5.2, 1.6, and more recent releases such as 1.7.1, 1.8.3, 1.9.1, and 1.11.3 (the current 1.x release as of this writing). I can only conclude that it was a browser thing, and I don't know what browser I was using. (Right now I'm using Chrome 26 and Firefox 20 to test.)

    Here's a test which shows that indeed, jQuery handlers, DOM0 handlers, and DOM2 handlers are all (as of this writing!) triggered by jQuery's click:

    jQuery(function($) {
      var div;
    
      $("

    ").text("jQuery v" + $.fn.jquery).appendTo(document.body); // Hook up a handler *not* using jQuery, in both the DOM0 and DOM2 ways div = document.getElementById("theDiv"); div.onclick = dom0Handler; if (div.addEventListener) { div.addEventListener('click', dom2Handler, false); } else if (div.attachEvent) { div.attachEvent('onclick', dom2Handler); } // Hook up a handler using jQuery $("#theDiv").click(jqueryHandler); // Trigger the click when our button is clicked $("#theButton").click(function() { display("Triggering click:"); $("#theDiv").click(); }); function dom0Handler() { display("DOM0 handler triggered"); } function dom2Handler() { display("DOM2 handler triggered"); } function jqueryHandler() { display("jQuery handler triggered"); } function display(msg) { $("

    ").html(msg).appendTo(document.body); } });

    
    
    Try clicking this div directly, and using the button to send a click via jQuery's click function.

提交回复
热议问题