Overview
SearchBoxes provide an input field for searching through content, allowing users to locate specific items within the website or app.
Zero input state
When the user has clicked into the SearchBox, but has not entered any text, there is an opportunity to display "hint text" within the input field, explaining what a user can do next. This could prompt a user to search for specific type content, or explain the scope of the search. Examples include "type to search", "try searching for <x>", "search for a place" or "type to search in <x location>".
Autocomplete suggestions
As the user enters a query string, they are provided with a dropdown of autocomplete suggestions or disambiguation options. This will help them expedite the input process and formulate an effective query. Recent search history, trending searches, contextual search suggestions, hints and tips are all good candidates for autocomplete content. In general, autocomplete suggestions have the user's input highlighted in some way (generally bolded) to indicate why it's being displayed. As the user enters more keystrokes, the suggestions update continuously/in real time. To see autocomplete suggestions, the user does not need to hit enter (execute a full search), as it is a lightweight way to get quick suggestions or results. If there are mixed result types within the autocomplete suggestions, provide visual indicators or grouping to help organize the information, making it easier to parse.
As a general guideline, results should be displayed in context with the query that was typed, with immediate access to edit the query or enter a new one. One method to enable efficient access to both edit the previous query and enter a new query is to highlight the previous query when the field is reactivated. This way, any keystroke will replace the previous string, but the string is maintained so that the user can position a cursor to edit or append the previous string.
Search scopes
Although search entry points tend to be similarly visualized, they can provide access to results that range from broad to narrow. By effectively communicating the scope of a search, you can help to ensure that the user expectation will be met by the capabilities of the search you are performing, which will reduce the possibility of frustration. The search entry point should be juxtaposed with the content being searched.
Some common search scopes include:
- Global: Search across multiple sources of cloud and local content. Varied results include URLs, documents, media, actions, apps, and more.
- Web: Search a web index. Results include pages, entities, and answers.
- My stuff: Search across device(s), cloud, social graphs, and more. Results are varied, but are constrained by the connection to user account(s).
SearchBox with no parent container
Use a SearchBox without a parent container when it is not restricted to a certain width to accommodate other content. This search box will span the entire width of the space it's in.
Using this Component
-
Confirm that you have references to Fabric's CSS and JavaScript on your page:
<link rel="stylesheet" href="fabric.min.css" /> <link rel="stylesheet" href="fabric.components.min.css" /> <script src="fabric.min.js"></script>
-
Copy the HTML from one of the samples below into your page. For example:
<div class="ms-SearchBox"> <input class="ms-SearchBox-field" type="text" value=""> <label class="ms-SearchBox-label"> <i class="ms-SearchBox-icon ms-Icon ms-Icon--Search"></i> <span class="ms-SearchBox-text">Search</span> </label> <div class="ms-CommandButton ms-SearchBox-clear ms-CommandButton--noLabel"> <button class="ms-CommandButton-button"> <span class="ms-CommandButton-icon"><i class="ms-Icon ms-Icon--Clear"></i></span> <span class="ms-CommandButton-label"></span> </button> </div> </div>
-
Add the following
<script>
tag to your page, below the references to Fabric's JS, to instantiate all SearchBox components on the page:<script type="text/javascript"> var SearchBoxElements = document.querySelectorAll(".ms-SearchBox"); for (var i = 0; i < SearchBoxElements.length; i++) { new fabric['SearchBox'](SearchBoxElements[i]); } </script>
-
Replace the sample HTML content with your content.
Variants
<div class="ms-SearchBox">
<input class="ms-SearchBox-field" type="text" value="">
<label class="ms-SearchBox-label">
<i class="ms-SearchBox-icon ms-Icon ms-Icon--Search"></i>
<span class="ms-SearchBox-text">Search</span>
</label>
<div class="ms-CommandButton ms-SearchBox-clear ms-CommandButton--noLabel">
<button class="ms-CommandButton-button">
<span class="ms-CommandButton-icon"><i class="ms-Icon ms-Icon--Clear"></i></span>
<span class="ms-CommandButton-label"></span>
</button>
</div>
</div>
<script type="text/javascript">
var SearchBoxElements = document.querySelectorAll(".ms-SearchBox");
for (var i = 0; i < SearchBoxElements.length; i++) {
new fabric['SearchBox'](SearchBoxElements[i]);
}
</script>
<div class="ms-SearchBox ms-SearchBox--commandBar is-collapsed">
<input class="ms-SearchBox-field" type="text" value="">
<label class="ms-SearchBox-label">
<i class="ms-SearchBox-icon ms-Icon ms-Icon--Search"></i>
<span class="ms-SearchBox-text">Search</span>
</label>
<div class="ms-CommandButton ms-SearchBox-clear ms-CommandButton--noLabel">
<button class="ms-CommandButton-button">
<span class="ms-CommandButton-icon"><i class="ms-Icon ms-Icon--Clear"></i></span>
<span class="ms-CommandButton-label"></span>
</button>
</div>
<div class="ms-CommandButton ms-SearchBox-exit ms-CommandButton--noLabel">
<button class="ms-CommandButton-button">
<span class="ms-CommandButton-icon"><i class="ms-Icon ms-Icon--ChromeBack"></i></span>
<span class="ms-CommandButton-label"></span>
</button>
</div>
<div class="ms-CommandButton ms-SearchBox-filter ms-CommandButton--noLabel">
<button class="ms-CommandButton-button">
<span class="ms-CommandButton-icon"><i class="ms-Icon ms-Icon--Filter"></i></span>
<span class="ms-CommandButton-label"></span>
</button>
</div>
</div>
<script type="text/javascript">
var SearchBoxElements = document.querySelectorAll(".ms-SearchBox");
for (var i = 0; i < SearchBoxElements.length; i++) {
new fabric['SearchBox'](SearchBoxElements[i]);
}
</script>
<div class="ms-SearchBox ms-SearchBox--commandBar">
<input class="ms-SearchBox-field" type="text" value="">
<label class="ms-SearchBox-label">
<i class="ms-SearchBox-icon ms-Icon ms-Icon--Search"></i>
<span class="ms-SearchBox-text">Search</span>
</label>
<div class="ms-CommandButton ms-SearchBox-clear ms-CommandButton--noLabel">
<button class="ms-CommandButton-button">
<span class="ms-CommandButton-icon"><i class="ms-Icon ms-Icon--Clear"></i></span>
<span class="ms-CommandButton-label"></span>
</button>
</div>
<div class="ms-CommandButton ms-SearchBox-exit ms-CommandButton--noLabel">
<button class="ms-CommandButton-button">
<span class="ms-CommandButton-icon"><i class="ms-Icon ms-Icon--ChromeBack"></i></span>
<span class="ms-CommandButton-label"></span>
</button>
</div>
<div class="ms-CommandButton ms-SearchBox-filter ms-CommandButton--noLabel">
<button class="ms-CommandButton-button">
<span class="ms-CommandButton-icon"><i class="ms-Icon ms-Icon--Filter"></i></span>
<span class="ms-CommandButton-label"></span>
</button>
</div>
</div>
<script type="text/javascript">
var SearchBoxElements = document.querySelectorAll(".ms-SearchBox");
for (var i = 0; i < SearchBoxElements.length; i++) {
new fabric['SearchBox'](SearchBoxElements[i]);
}
</script>