AngularJS 학습용 노트의 양식 검증 기능 인스턴스 상세 정보
1. 기본적인 폼 검증을 실행한다
angular.module('exampleApp',[])
.controller('defaultCtrl',function($scope){
$scope.addUser=function(userDetails){
$scope.message=userDetails.name+"("+userDetails.email+")("+userDetails.agreed+")"
}
$scope.message='Ready';
});
상기 예에서 이 HTML 문서가 브라우저에 불러올 때의 초기 상태는 세 개의 input 요소와 비활성화되고 클릭할 수 없는 ok 단추가 있습니다. 텍스트 상자에 값을 입력하고 체크 상자를 선택하면 단추를 사용할 수 있게 되어 사용자가 폼을 제출할 수 있도록 합니다.
1. 양식 요소 추가
(1) 우선 form에name 속성을 설정해야 합니다. (2) 폼에 novalidate 속성을 추가해야 합니다. 이 속성은 브라우저에 폼을 스스로 검사하지 말라고 알려 줍니다. 이로써 AngularJS가 방해받지 않는 작업을 허용합니다. (3)ng-submit 명령은 폼 제출 이벤트에 대해 사용자 정의 응답 행위를 지정하고 사용자가 폼을 제출할 때 터치합니다
2. 검증 속성 사용
(1) 검증하고 싶은 각 요소에name 속성을 추가합니다. 그러면 Angularjs가 제공하는 각종 특수한 변수에 접근할 수 있습니다. (2) type 속성을 설정합니다. 이 속성은 input 요소가 수신할 데이터 형식을 지정합니다. 이 형식들은angularjs가 어떤 검사를 필요로 하는지 알려줍니다. (3) required 속성을 지정합니다.이 속성은 사용자가 검사를 기다리는 폼에 입력 값을 제공해야 한다는 것을 지정합니다. (4) 이 예에서 input 요소는ng-model 명령을 사용하여 은밀하게 정의된 newUser 대상의 속성을 설정합니다.
3. 모니터링 양식의 유효성
AngularJS에서 표준 폼 요소를 대체하는 명령은 폼의 각 요소나 전체 폼의 유효성 상태를 검사하는 데 사용할 특수한 변수를 정의합니다.
$pristine: 사용자가 요소/폼과 상호작용을 하지 않으면true $dirty를 되돌려줍니다. 사용자가 요소/폼과 상호작용을 한 경우true $valid를 되돌려줍니다. 요소/폼 내용의 검사 결과가 유효할 때true $invalid를 되돌려줍니다. 요소/폼 내용의 검사 결과가 무효일 때true $error를 되돌려줍니다. 검사 오류에 대한 자세한 정보를 제공합니다.
2. 양식 검사 피드백 정보 제공
위의 예에서 보여준 효과는 비교적 간단합니다. ok 단추는 모든 input 요소가 사용할 수 있을 때까지 사용되지 않습니다. 사용자가 잘못된 형식이나 채워지지 않은 데이터를 입력하지 못하게 합니다.다음은 AngularJS가 실시간 검증 정보를 보고하는 것을 보여 드리겠습니다.
1. css를 사용하여 검사 피드백 정보 제공
ng-pristine: 사용자가 상호작용을 하지 않은 요소가 이 클래스에 추가됨ng-dirty: 사용자가 상호작용을 한 요소가 이 클래스에 추가됨ng-valid: 검사 결과는 유효한 요소입니다. 이 클래스에서ng-invalid: 검사 결과는 무효한 요소입니다.
다음은 구체적인 사용법을 살펴보겠습니다.
angular.module('exampleApp',[])
.controller('defaultCtrl',function($scope){
$scope.addUser=function(userDetails){
$scope.message=userDetails.name+"("+userDetails.email+")("+userDetails.agreed+")"
}
$scope.message='Ready';
});
상술한 예에서 우리는 네 가지 스타일을 정의했다. 첫 번째 두 가지 스타일은ng-dirty류 구성원에 속하는 요소를 선택하는 데 사용되고 사용자와 상호작용을 한 후에 해당하는 요소에만 적용된다.내용이 유효한 요소는ng-valid류의 구성원으로 연두색 배경으로 렌더링되고, 내용이 유효하지 않은 요소는ng-invalid류의 구성원으로 연분홍색 배경으로 렌더링됩니다.
2. 특수 변수를 사용하여 피드백 정보를 제공한다
angular.module('exampleApp',[])
.controller('defaultCtrl',function($scope){
$scope.addUser=function(userDetails){
$scope.message=userDetails.name+"("+userDetails.email+")("+userDetails.agreed+")"
}
$scope.message='Ready';
});
이 예에서 새로운 div 요소를 추가하여 사용자에게 검사 알림 정보를 표시하는 데 사용합니다. 새로운 div 요소의 가시성은ng-show 명령에 의해 제어되고 input 요소에 값이 입력되며 입력 값이 검사를 통과하지 않을 때 이 요소를 표시합니다.이것은 form 요소의name 값과 input의name 값을 연합하여 input 요소에 접근하는 것입니다.이 예에서, 우리는 사용자 체험을 강화하기 위해 특수 검사 변수와 다른 명령을 연합하여 사용한다.그러나 이렇게 하면 페이지에 같은 불필요한 정보의 요소를 대량으로 증가시킬 수 있다. 다음에 우리는 간소화할 것이다
angular.module('exampleApp',[])
.controller('defaultCtrl',function($scope){
$scope.addUser=function(userDetails){
$scope.message=userDetails.name+"("+userDetails.email+")("+userDetails.agreed+")"
}
$scope.message='Ready';
$scope.getError=function(error){
if(angular.isDefined(error)){
if(error.required){
return 'please enter a value';
}else if(error.email){
return 'please enter a valid email address';
}
}
}
});
더 많은 AngularJS 관련 내용에 관심이 있는 독자들은 본 사이트의 주제를 볼 수 있습니다:, 및 AngularJS MVC 구조 요약
본 논문이 여러분의 AngularJS 프로그래밍에 도움이 되기를 바랍니다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.