여러 $ scope 속성보기
다음을 사용하여 여러 객체의 이벤트를 구독하는 방법이 있습니까? $watch
예 :
$scope.$watch('item1, item2', function () { });
AngularJS 1.3부터는 $watchGroup
표현식 세트를 관찰하는 새로운 메소드가 있습니다.
$scope.foo = 'foo';
$scope.bar = 'bar';
$scope.$watchGroup(['foo', 'bar'], function(newValues, oldValues, scope) {
// newValues array contains the current values of the watch expressions
// with the indexes matching those of the watchExpression array
// i.e.
// newValues[0] -> $scope.foo
// and
// newValues[1] -> $scope.bar
});
AngularJS 1.1.4부터 다음을 사용할 수 있습니다 $watchCollection
.
$scope.$watchCollection('[item1, item2]', function(newValues, oldValues){
// do stuff here
// newValues and oldValues contain the new and respectively old value
// of the observed collection array
});
Plunker 예 여기
여기에 문서
$watch
첫 번째 매개 변수는 함수일 수도 있습니다.
$scope.$watch(function watchBothItems() {
return itemsCombinedValue();
}, function whenItemsChange() {
//stuff
});
결합 된 두 값이 단순하면 첫 번째 매개 변수는 일반적으로 각도 표현식입니다. 예를 들어 firstName과 lastName은 다음과 같습니다.
$scope.$watch('firstName + lastName', function() {
//stuff
});
다음은 실제로 작동하는 원래 의사 코드와 매우 유사한 솔루션입니다.
$scope.$watch('[item1, item2] | json', function () { });
편집 : 좋아, 나는 이것이 더 낫다고 생각한다.
$scope.$watch('[item1, item2]', function () { }, true);
기본적으로 우리는 멍청한 것처럼 보이는 json 단계를 건너 뛰지 만 그것이 없으면 작동하지 않았습니다. 이 키는 종종 생략되는 3 번째 매개 변수로, 참조 평등과 반대로 객체 평등을 켭니다. 그런 다음 생성 된 배열 객체 간의 비교가 실제로 올바르게 작동합니다.
$ watchGroup의 함수를 사용하여 범위 내 객체의 필드를 선택할 수 있습니다.
$scope.$watchGroup(
[function () { return _this.$scope.ViewModel.Monitor1Scale; },
function () { return _this.$scope.ViewModel.Monitor2Scale; }],
function (newVal, oldVal, scope)
{
if (newVal != oldVal) {
_this.updateMonitorScales();
}
});
왜 그것을 단순히 포장하지 forEach
않습니까?
angular.forEach(['a', 'b', 'c'], function (key) {
scope.$watch(key, function (v) {
changed();
});
});
실제로 값 구성에 대해 걱정할 필요없이 결합 된 값에 대한 기능을 제공하는 것과 거의 동일한 오버 헤드 입니다.
값을 결합하는 약간 더 안전한 솔루션은 다음을 $watch
함수 로 사용하는 것입니다.
function() { return angular.toJson([item1, item2]) }
또는
$scope.$watch(
function() {
return angular.toJson([item1, item2]);
},
function() {
// Stuff to do after either value changes
});
$ watch first 매개 변수는 각도 표현식 또는 함수일 수 있습니다 . $ scope. $ watch 문서를 참조하십시오 . 여기에는 $ watch 메소드 작동 방식에 대한 유용한 정보가 많이 포함되어 있습니다. watchExpression이 호출 될 때, 각도가 결과를 비교하는 방법 등
어때요?
scope.$watch(function() {
return {
a: thing-one,
b: thing-two,
c: red-fish,
d: blue-fish
};
}, listener...);
$scope.$watch('age + name', function () {
//called when name or age changed
});
여기서 나이와 이름 값이 모두 변경되면 함수가 호출됩니다.
$watchGroup
버전 1.3에 도입 된 Angular는 여러 변수를 감시 할 수있는 단일 $watchGroup
블록을 사용하여 감시 할 $watchGroup
모든 변수를 포함 할 수있는 첫 번째 매개 변수로 배열을 사용합니다.
$scope.$watchGroup(['var1','var2'],function(newVals,oldVals){
console.log("new value of var1 = " newVals[0]);
console.log("new value of var2 = " newVals[1]);
console.log("old value of var1 = " oldVals[0]);
console.log("old value of var2 = " oldVals[1]);
});
참고 URL : https://stackoverflow.com/questions/11952579/watch-multiple-scope-attributes
'Programing' 카테고리의 다른 글
C # nullable int를 int로 변환하는 방법 (0) | 2020.02.18 |
---|---|
안드로이드 ADB 도구를 사용하여 응용 프로그램을 시작하는 방법은 무엇입니까? (0) | 2020.02.18 |
CSS를 사용하여 오른쪽에서 배경 이미지 오프셋 (0) | 2020.02.18 |
List에서 요소를 제거하려고 할 때 UnsupportedOperationException이 발생하는 이유는 무엇입니까? (0) | 2020.02.18 |
앵커 링크를 클릭 할 때 부드러운 스크롤 (0) | 2020.02.18 |