Toggle menu

Autocomplete

Autocompletes are text inputs that display lists of suggested terms below as users type, allowing them to select from relevant options.

Autocomplete inputs help users quickly find what they need by displaying relevant suggestions as they type. You can include additional details for each suggestion to provide more context.

When to use Autocomplete

The Autocomplete component consists of only the input element and the suggestions displayed while you type (ie it doesn't include other elements associated with an entire form like the label and submit button).

It is likely Autocomplete won't be used in isolation, since it is utilised by the SiteSearch component which should be considered instead.

 

Examples in GOSS products

  • In all SiteSearch components with the autocomplete option switched on (enabled by default)
  • The Event Search template

 

Accessibility considerations

The suggestions use ARIA attributes to define the listbox role and to associate it with the same label as the input. The input is marked with aria-owns to indicate ownership of the listbox. Since only the HTML input element is output, a separate label element with the format {componentId}_label must be provided.

General notes

Consider using SiteSearch instead, or building a new component that wraps this as an internal feature. Direct use of this component is discouraged.

Basic Autocomplete

An autocomplete input with the subsite's search article set as the data URL, with the label provided separately.

The data URL will provide suggestions while typing into the input based on the current subsite's configured default Search article.

    HTML Java .NET
    <label for="autocomplete_basic" id="autocomplete_basic_label">Mandatory label for autocomplete </label>
    <div class="search-suggestion-wrapper">
    	<div aria-expanded="false" aria-haspopup="listbox" aria-controls="autocomplete_basic_suggestions" aria-autocomplete="list" id="autocomplete_basic_container" role="combobox">
    		<input autocomplete="off" class="searchform__inputtxt" data-dataurl="https://docs.gossinteractive.com/article/5655/Search" id="autocomplete_basic" name="q" type="text" aria-labelledby="autocomplete_basic_label"/>
    	</div>
    	<ul class="search-suggestion" id="autocomplete_basic_suggestions" role="listbox"></ul>
    </div>
    
    <script>
    	var autocomplete = new SearchSuggestion({
    		element: 'input[id="autocomplete_basic"]',
    		modifier: ''
    	});
    </script>
    <label for="autocomplete_basic" id="autocomplete_basic_label">Mandatory label for autocomplete</label>
    <comp:autocomplete dataurl="#{subsite.searchArticle.articleAbsoluteURL}" id="autocomplete_basic" />
    @{
    	AutoCompleteSettings settings = new AutoCompleteSettings()
    			{
    				Id = "autocomplete_basic_label",
    				DataUrl = Html.Link(Model.Model.SearchArticle)
    			};
    }
    
    @{
    	<label for="autocomplete_basic" id="autocomplete_basic_label">Mandatory label for autocomplete</label>
    	Html.AutoComplete(settings);
    }

    Share this page

    Facebook icon Twitter icon email icon

    Print

    print icon