你好遵守利弊!如何使我的網頁部分508和wcag 2.0兼容
我的任務是使我們的網絡應用程序符合第508條和wcag 2.0指導。對於大多數情況來說,這並不是太棘手,但我已經打了一些路障。
我在應用程序中使用qtip很多,這往往是大多數兼容b/c它使用wai-aria角色和描述的屬性。但是,我添加我的工具提示的方式使它不會在第一次鼠標懸停前放到文本上。這顯然不會發生在鍵盤導航,我不知道屏幕閱讀器將如何處理,或者!
我在這裏做了一個小提琴:http://jsfiddle.net/patriciavandermeer/xkhy6/2/ 這證明了我在說什麼。工具提示是最終用戶可以在別處設置的HTML,並且它們列出的項目可能有也可能沒有工具提示。
我正在考慮使工具提示被應用和顯示:焦點(並掩藏在失去焦點),但然後我需要給跨度tabindex,我不知道有多好的支持是的,所有的主要瀏覽器都可以處理嗎?
還是我應該咬一口子,讓工具提示在文檔中準備好了?我在一些繁忙的網頁上遇到了一些嚴重的性能問題,當我把它設置成這樣的時候。
編輯:這裏是一個將使用的html的樣本,以及jquery/javascript我用來將工具提示附加到跨度。
樣本HTML:
<li >
<span class="InteractiveToolTipMe">Administration</span>
<div class="InteractiveToolTip NoDisplay"><p>This is a description</p>
<p> </p>
<p>For administration.....</p></div>
</li>
<li >
Board and Committees
</li>
<li >
Community Outreach
</li>
<li >
<span class="InteractiveToolTipMe">Fundraising</span>
<div class="InteractiveToolTip NoDisplay"><p><strong>test</strong></p>
<p> </p>
<ul>
<li><strong>test</strong></li>
<li>test</li>
<li>test</li>
</ul>
</div>
</li>
<li style="padding:2px;">
Physics
</li>
<li style="padding:2px;">
Public Speaking
</li>
<li style="padding:2px;">
Special Events
</li>
</ul>
的Javascript用於連接提示:
$('span.InteractiveToolTipMe').live("mouseover", function() {
var $this = $(this);
if (!$this.data("toolTipAttached")) {
var content = $(this).parent().find('.InteractiveToolTip').html();
$this.qtip({
content: {
text: content
},
position: {
target: 'mouse',
adjust: {
mouse: false
},
viewport: $(window)
},
hide: {
fixed: true,
delay:350,
when: 'mouseout'
},
show: {
solo: true,
delay: 350,
ready: true
},
style: {
widget: true,
tip:false,
classes: "LegendTip"
}
});
$this.data("toolTipAttached", true);
//$this.trigger("mouseover");
}
});
小心標題:我似乎記得一些屏幕閱讀器讀出內容的標題*而不是*,而不是除了;但標題文本通常不是鍵盤可訪問的 - 除了屏幕閱讀器用戶之外,請務必記住只有注重鍵盤的用戶! – BrendanMcK
標題文本是_not_鍵盤可訪問的。 –
感謝Jonathan的回答!奇怪我的示例頁面崩潰了你的瀏覽器!我的工具提示與鏈接沒有任何關聯,在這種情況下,它只是一個事物清單,可能有或可能沒有很長的描述。說明位於頁面中,位於文本旁邊的隱藏div中。我將編輯我的問題以顯示小提琴中的標記。 – Patricia