I'm trying to create an auto-complete list that appears as you type, but disappears when you click elsewhere on the document. How do I detect that a form input is focused using Angular 2. Angular 1 has ng-focus, but I don't think Angular 2 supports that anymore.
<input id="search-box" type="search" class="form-control [(ngModel)]=query (keyup)=filter()>
<div id="search-autocomplete" *ngIf="filteredList.length > 0">
<ul *ngFor="#item of filteredList" >
<li > <a (click)="select(item)">{{item}}</a> </li>
</ul>
</div>
By the way, I used this tutorial as guidance.
For those using
@angular/material
, you can get a reference to theMatInput
instance which implementsMatFormFieldControl
interface exposing a nicefocused
property.There are
focus
andblur
events:You can use the ngControl directive to track change-state and validity of form fields.
The NgControl directive updates the control with three classes that reflect the state.
State: Control has been visited
State: Control's value has changed
State: Control's value is valid