如何停止 508 大白鲨咏叹调警报队列



我当前的代码库使用以下函数创建警报,以通知盲人用户发生了某些事情,例如"Bob 已成功分配到蓝队"。

var create508Message = function (message, type) {
    var $messageElement,
        templateOptions = {
            message: message
        };
    // create the $messageElement
    switch (type){
        case 'alert':
            templateOptions.isAlert = true;
            $messageElement = $(HBS['common/accessibilityUtil'](templateOptions));
            break;
        case 'status':
            templateOptions.isStatus = true;
            $messageElement = $(HBS['common/accessibilityUtil'](templateOptions));
            break;
        default:
            return;
    }
    // trigger the message
    $('body').append($messageElement);
    // clean up automatically after 5 secs
    setTimeout(function (){
        $messageElement.remove();
    }, 5000);
},

大多数可重用的组件会让盲人用户知道当前状态。我遇到了一些问题,例如,刷新表格时,读取页数,然后应用过滤器,页码更改,因为过滤列表中的项目数已更改。这会导致 Jaws 向盲人用户读取许多冲突状态,因为它会读取整个警报队列。

我希望有一种方法可以防止它读取队列,例如:

killAriaLive: function () {
    $('div[aria-live]').map( function () {
            $(this).removeAttr('aria-live');
            $(this).removeAttr('role');
            $(this).attr('hidden', 'true');
            $(this).attr('aria-hidden', 'true');
    });
},

但这也没有用,它仍然读取整个消息队列。

您可以尝试使用 aria-live="assertive"(见 https://developer.paciellogroup.com/blog/2014/03/screen-reader-support-aria-live-regions/(创建/更新带有空格的元素(我还没有尝试过这个(,但是,您可以开始抑制用户合法需要听到的语音。

相关内容

  • 没有找到相关文章

最新更新