语义UI下拉菜单 - 无法按Enter进入下拉列表中的链接

时间:2017-07-12 19:40:50

标签: html css semantic-ui

我正在使用Semantic UI在键盘可访问的顶部导航栏上工作,但我无法使用Enter / Return键访问下拉菜单中的链接,即使焦点位于链接上也是如此。我创建了一个空白JS Fiddle here来演示。我也使用Chrome Vox作为屏幕阅读器,以便我知道当前焦点在哪里。

以下是代码:

<div class="ui menu">
    <a class="item" href="https://www.google.com">Google 1</a>
    <div class="ui dropdown link item">
        <a href="#">
            <span>Google 2</span>
            <i class="dropdown icon"></i>
        </a>
        <div class="menu">
            <a class="item" href="https://www.google.com">Google 2.1</a>
            <a class="item" href="https://www.google.com">Google 2.2</a>
        </div>
    </div>
</div>

JavaScript设置:

$(document).ready(function() {
    $('.ui.dropdown').dropdown();
});

谢谢大家。

2 个答案:

答案 0 :(得分:0)

此类功能似乎不是语义UI的一部分。

这就像我得到的那样接近;对你有用吗?

&#13;
&#13;
$(document).ready(function() {
    $('.ui.dropdown').dropdown();
    $('div.item').keyup(function(e) {
        if (e.keyCode == 13) {
            document.location = $(this).find('a.item.selected').attr('href')
        }
    });
    var href = undefined;
    $('div.item a.item').hover(function() {
        href = $(this).attr('href');
    }, function() {
        href = undefined;
    });
    $(document).keyup(function(e) {
        if (e.keyCode == 13 && href) {
            document.location = href;
        }
    });
});
&#13;
&#13;
&#13;

答案 1 :(得分:0)

一种解决方案是通过函数处理onChange事件。 在您的函数中,您可以包括以下行来捕捉按键,包括回车键。

reader