38 lines
		
	
	
		
			975 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			38 lines
		
	
	
		
			975 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
|  | /** | ||
|  |  * @license | ||
|  |  * Copyright Google Inc. All Rights Reserved. | ||
|  |  * | ||
|  |  * Use of this source code is governed by an MIT-style license that can be | ||
|  |  * found in the LICENSE file at https://angular.io/license
 | ||
|  |  */ | ||
|  | 
 | ||
|  | // #docregion Component
 | ||
|  | import {Component} from '@angular/core'; | ||
|  | 
 | ||
|  | @Component({ | ||
|  |   selector: 'example-app', | ||
|  |   template: `
 | ||
|  |     <form #f="ngForm"> | ||
|  |       <select name="state" ngModel> | ||
|  |         <option value="" disabled>Choose a state</option> | ||
|  |         <option *ngFor="let state of states" [ngValue]="state"> | ||
|  |           {{ state.abbrev }} | ||
|  |         </option> | ||
|  |       </select> | ||
|  |     </form> | ||
|  |      | ||
|  |      <p>Form value: {{ f.value | json }}</p> | ||
|  |      <!-- example value: {state: {name: 'New York', abbrev: 'NY'} } --> | ||
|  |   `,
 | ||
|  | }) | ||
|  | export class SelectControlComp { | ||
|  |   states = [ | ||
|  |     {name: 'Arizona', abbrev: 'AZ'}, | ||
|  |     {name: 'California', abbrev: 'CA'}, | ||
|  |     {name: 'Colorado', abbrev: 'CO'}, | ||
|  |     {name: 'New York', abbrev: 'NY'}, | ||
|  |     {name: 'Pennsylvania', abbrev: 'PA'}, | ||
|  |   ]; | ||
|  | } | ||
|  | // #enddocregion
 |