diff options
author | Jörn Zaefferer <joern.zaefferer@gmail.com> | 2013-10-18 15:39:20 +0200 |
---|---|---|
committer | Jörn Zaefferer <joern.zaefferer@gmail.com> | 2013-10-19 00:27:51 +0200 |
commit | 7b9c810b9ac450d826b6fa0c3d35377178b7e3b3 (patch) | |
tree | 9daf1282e4142efcb94fb94415839cb1e2851cb5 | |
parent | b99f8258bf5e8c427cb7c0046fa5ceaa68871eef (diff) | |
download | jquery-ui-7b9c810b9ac450d826b6fa0c3d35377178b7e3b3.tar.gz jquery-ui-7b9c810b9ac450d826b6fa0c3d35377178b7e3b3.zip |
Autocomplete: Append liveRegion to body to support detached init. Fixes #9590 - Dynamically adding input field breaks auto-complete's accessibility for screen readers
-rw-r--r-- | tests/unit/autocomplete/autocomplete_core.js | 9 | ||||
-rw-r--r-- | ui/jquery.ui.autocomplete.js | 2 |
2 files changed, 10 insertions, 1 deletions
diff --git a/tests/unit/autocomplete/autocomplete_core.js b/tests/unit/autocomplete/autocomplete_core.js index a8b0a7330..58e96755a 100644 --- a/tests/unit/autocomplete/autocomplete_core.js +++ b/tests/unit/autocomplete/autocomplete_core.js @@ -257,6 +257,15 @@ test( "ARIA", function() { "Live region for multiple values" ); }); +test( "ARIA, init on detached input", function() { + expect( 1 ); + var element = $( "<input>" ).autocomplete({ + source: [ "java", "javascript" ] + }), + liveRegion = element.autocomplete( "instance" ).liveRegion; + equal( liveRegion.parent().length, 1, "liveRegion must have a parent" ); +}); + test( ".replaceWith() (#9172)", function() { expect( 1 ); diff --git a/ui/jquery.ui.autocomplete.js b/ui/jquery.ui.autocomplete.js index d1a3c252d..2b803b62f 100644 --- a/ui/jquery.ui.autocomplete.js +++ b/ui/jquery.ui.autocomplete.js @@ -294,7 +294,7 @@ $.widget( "ui.autocomplete", { "aria-live": "polite" }) .addClass( "ui-helper-hidden-accessible" ) - .insertBefore( this.element ); + .appendTo( this.document[ 0 ].body ); // turning off autocomplete prevents the browser from remembering the // value when navigating through history, so we re-enable autocomplete |