Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/apache/8.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/cassandra/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Angular6 角度6输入范围验证_Angular6 - Fatal编程技术网

Angular6 角度6输入范围验证

Angular6 角度6输入范围验证,angular6,Angular6,我必须验证表单中的一个输入元素 如何在提交表单时验证范围 例如,用户应输入1000美元到2000美元之间的价格 请给出继续进行的建议 谢谢你试试这个 <form [formGroup]="myForm"> <label for="priceRange">Price Range: </label> <input type="number" id="priceRange" formControlName="priceRange"> <div *

我必须验证表单中的一个输入元素

如何在提交表单时验证范围 例如,用户应输入1000美元到2000美元之间的价格

请给出继续进行的建议

谢谢你试试这个

<form [formGroup]="myForm">
<label for="priceRange">Price Range: </label>
 <input type="number" id="priceRange" formControlName="priceRange">
<div *ngIf="f.priceRange.errors">
 Invalid Price Range
</div>
试试这个有效的例子

import { FormBuilder, FormGroup, Validators, ReactiveFormsModule } from '@angular/forms';

   myForm = new FormGroup({});

   get f() { 
      return this.myForm.controls; 
    }

  constructor(private formBuilder: FormBuilder){
      this.myForm = formBuilder.group({     
     priceRange: ['', [Validators.min(1000), Validators.max(2000)]]
       });
    }
<h3>Reactive Forms Validator Example</h3>
<br>

<label>We have created two validators using slightly different approaches that validate if the input is equal to "A" or not.</label>
<br><br>

<label>Doesn't work because the method is not executed which will return the custom validator function.</label><br>
<input type="text" [formControl]="wrongOnlyA"> 
<br><br>

<label>Works because the method is executed.</label><br>
<input type="text" [formControl]="correctOnlyA"> 
<br><br>

<label>Works because the validator function is directly exported.</label><br>
<input type="text" [formControl]="onlyB"> 
import { Component, OnInit } from '@angular/core';
import { FormGroup } from "@angular/forms"

import { RxFormBuilder } from '@rxweb/reactive-form-validators';
import { FormBuilderConfiguration  } from '@rxweb/reactive-form-validators';

import { EmployeeInfo } from '../employee-info.model';

@Component({
    selector: 'app-employee-info-add',
    templateUrl: './employee-info-add.component.html'
})
export class EmployeeInfoAddComponent implements OnInit {

    employeeInfoFormGroup: FormGroup

    constructor(
        private formBuilder: RxFormBuilder
    ) { }

    ngOnInit() {
        let employeeInfo = new EmployeeInfo();
        let formBuilderConfiguration = new FormBuilderConfiguration();
        formBuilderConfiguration.validations = {
            age : {
                range :  {minimumNumber:18,maximumNumber:60,} 
            },
            experience : {
                range :  {minimumNumber:2,maximumNumber:20,conditionalExpression:'x => x.age >=25',} 
            },
            salary : {
                range :  {minimumNumber:1000,maximumNumber:200000,message:'Your Salary should be between 10000 to 200000.',} 
            },
        };
        this.employeeInfoFormGroup = this.formBuilder.formGroup(employeeInfo,formBuilderConfiguration);
    }
}