웹 프론트엔드 JS 튜토리얼 AngularJs ng-change 이벤트/지시문 사용 정보

AngularJs ng-change 이벤트/지시문 사용 정보

May 10, 2018 pm 05:23 PM
angularjs javascript

이 글은 주로 AngularJ의 ng-change 이벤트/명령에 대한 요약을 소개합니다. 편집자가 꽤 좋다고 생각해서 이제 공유하고 참고용으로 제공하겠습니다. 편집자를 따라 살펴보겠습니다. 모두에게 도움이 되기를 바랍니다.

정의 및 사용법

ng-change 지시문은 HTML 요소의 값이 변경될 때 수행할 작업을 AngularJS에 알려주는 데 사용됩니다.

ng-change 지시어는 ng-model 지시어와 함께 사용해야 합니다.

AngularJS ng-change 지시문은 기본 onchange 이벤트를 재정의하지 않습니다. 이 이벤트가 트리거되면 ng-change 표현식과 기본 onchange 이벤트가 모두 실행됩니다.

ng-change 이벤트는 값이 변경될 때마다 트리거되며 수정 프로세스가 완료될 때까지 기다리거나 작업이 포커스를 잃을 때까지 기다릴 필요가 없습니다.

ng-change 이벤트는 JavaScript를 통한 수정이 아닌 입력 상자 값의 실제 수정만을 대상으로 합니다.

Syntax

<element ng-change="expression"></element>
로그인 후 복사
  1. <input>, <select> 및 <textarea> 요소가 지원됩니다.

  2. <radio>,<checkbox>

매개변수 값

설명
expression요소 값이 변경되면 표현식을 실행합니다.

입력 상자의 값이 변경될 때 실행 함수:

&lt;body ng-app=&quot;myApp&quot;&gt;

&lt;p ng-controller=&quot;myCtrl&quot;&gt;
 &lt;input type=&quot;text&quot; ng-change=&quot;myFunc()&quot; ng-model=&quot;myValue&quot; /&gt;
 &lt;p&gt;The input field has changed {{count}} times.&lt;/p&gt;
&lt;/p&gt;

&lt;script&gt;
angular.module(&#39;myApp&#39;, [])
.controller(&#39;myCtrl&#39;, [&#39;$scope&#39;, function($scope) {
 $scope.count = 0;
 $scope.myFunc = function() {
  $scope.count++;
 };
}]);
&lt;/script&gt;

&lt;/body&gt;
로그인 후 복사

예시 설명, 라디오 및 체크박스

참고: 체크박스 ng-model은 항상 true 또는 false이고 값이 아니며 다른 ng- 모델의 기본값은 값입니다.

HTML

&lt;h3&gt;Radio 控件测试&lt;/h3&gt; 
&lt;p&gt;&lt;label&gt; 
  &lt;input type=&quot;radio&quot; value=&quot;男&quot; name=&quot;sex&quot; ng-model=&quot;value1&quot; ng-change=&quot;radioChecked()&quot; /&gt; 
  男 
 &lt;/label&gt; 
 &lt;label&gt; 
  &lt;input type=&quot;radio&quot; value=&quot;女&quot; name=&quot;sex&quot; ng-model=&quot;value1&quot; ng-change=&quot;radioChecked()&quot; /&gt; 
  女 
 &lt;/label&gt;&lt;/p&gt; 
&lt;h3&gt;checked 控件测试&lt;/h3&gt; 
&lt;p&gt;&lt;p class=&quot;checkbox&quot;&gt; 
  &lt;label&gt; 
   &lt;input name=&quot;agree&quot; type=&quot;checkbox&quot; value=&quot;同意&quot; ng-model=&quot;value2&quot; ng-change=&quot;checkboxClick()&quot; /&gt; 
   同意协议 
  &lt;/label&gt; 
 &lt;/p&gt; 
 &lt;p class=&quot;checkbox&quot;&gt; 
  &lt;label&gt; 
   &lt;input name=&quot;agree&quot; type=&quot;checkbox&quot; value=&quot;同意2&quot; ng-model=&quot;value2&quot; ng-change=&quot;checkboxClick()&quot; /&gt; 
   同意协议2 
  &lt;/label&gt; 
 &lt;/p&gt;&lt;/p&gt;
로그인 후 복사

JS:

var app = angular.module(&#39;myApp&#39;, []); 
app.controller(&#39;validateCtrl&#39;, function ($scope) { 
 //randio ng-change事件和原始onchange相同 
 //radio ng-model 的值是value 
 $scope.radioChecked = function () { 
  console.info($scope.value1); 
 } 
 //checkbox ng-change事件和原始onchange相同 
 //checkbox ng-model总是是true或false 
 $scope.checkboxClick = function () { 
  console.info($scope.value2); 
 } 
});
로그인 후 복사

예제 설명, 텍스트, 선택

HTML

&lt;form class=&quot;form-horizontal&quot;&gt; 
 &lt;p class=&quot;form-group&quot;&gt; 
  &lt;label class=&quot;control-label&quot;&gt;姓名:&lt;/label&gt; 
  &lt;input type=&quot;text&quot; class=&quot;form-control&quot; ng-model=&quot;name&quot; ng-change=&quot;txtChange();&quot; /&gt; 
 &lt;/p&gt; 
 &lt;p class=&quot;form-group&quot;&gt; 
  &lt;label class=&quot;control-label&quot;&gt;选择年级:&lt;/label&gt; 
  &lt;select class=&quot;form-control&quot; ng-change=&quot;selectChange();&quot; ng-model=&quot;grade&quot;&gt; 
   &lt;option value=&quot;1&quot;&gt;一年级&lt;/option&gt; 
   &lt;option value=&quot;2&quot;&gt;二年级&lt;/option&gt; 
  &lt;/select&gt; 
 &lt;/p&gt; 
&lt;/form&gt;
로그인 후 복사

JS

var app = angular.module(&#39;myApp&#39;, []); 
app.controller(&#39;validateCtrl&#39;, function ($scope) { 
 //textbox 的ng-change事件和原始ng-change不相同,而是和$scope.$watch()监听相同 
 //textbox 的ng-model为当前输入框的内容,为value值 
 $scope.txtChange = function () { 
  console.info($scope.name); 
 } 
 //select 的ng-change事件和原始ng-change相同 
 //ng-model 的默认情况下ng-model的结果为value值 
 $scope.selectChange = function () { 
  console.info($scope.grade); 
 } 
});
로그인 후 복사

관련 권장 사항:

AngularJS의 컨트롤러 상속 방법에 대한 튜토리얼

AngularJs 최고의 쇼핑 카트 구현 방법

지시문을 사용한 Angularjs 렌더링의 별점 시스템 구현에 대해

위 내용은 AngularJs ng-change 이벤트/지시문 사용 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 Dec 17, 2023 pm 02:54 PM

WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법

WebSocket 및 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 WebSocket 및 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 Dec 17, 2023 pm 05:30 PM

WebSocket 및 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 Dec 17, 2023 am 09:39 AM

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 Dec 17, 2023 pm 12:09 PM

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법

간단한 JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법 간단한 JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법 Jan 05, 2024 pm 06:08 PM

간단한 JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법

JavaScript와 WebSocket: 효율적인 실시간 일기예보 시스템 구축 JavaScript와 WebSocket: 효율적인 실시간 일기예보 시스템 구축 Dec 17, 2023 pm 05:13 PM

JavaScript와 WebSocket: 효율적인 실시간 일기예보 시스템 구축

자바스크립트에서 insertBefore를 사용하는 방법 자바스크립트에서 insertBefore를 사용하는 방법 Nov 24, 2023 am 11:56 AM

자바스크립트에서 insertBefore를 사용하는 방법

JavaScript에서 HTTP 상태 코드를 쉽게 얻는 방법 JavaScript에서 HTTP 상태 코드를 쉽게 얻는 방법 Jan 05, 2024 pm 01:37 PM

JavaScript에서 HTTP 상태 코드를 쉽게 얻는 방법

See all articles