KnockoutJS-계산 된 Observable
Computed Observable은 하나 이상의 Observable에 의존하고 기본 Observable (종속성)이 변경 될 때마다 자동으로 업데이트되는 함수입니다.
계산 된 Observable은 연결될 수 있습니다.
통사론
this.varName = ko.computed(function(){
...
... // function code
...
},this);
예
Computed Observable의 사용을 보여주는 다음 예제를 살펴 보겠습니다.
<!DOCTYPE html>
<head >
<title>KnockoutJS Computed Observables</title>
<script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.1.0.js"></script>
</head>
<body>
<p>Enter first number: <input data-bind = "value: a" /></p>
<p>Enter second number: <input data-bind = "value: b"/></p>
<p>Average := <span data-bind="text: totalAvg"></span></p>
<script>
function MyViewModel() {
this.a = ko.observable(10);
this.b = ko.observable(40);
this.totalAvg = ko.computed(function() {
if(typeof(this.a()) !== "number" || typeof(this.b()) !== "number") {
this.a(Number(this.a())); //convert string to Number
this.b(Number(this.b())); //convert string to Number
}
total = (this.a() + this.b())/2 ;
return total;
},this);
}
ko.applyBindings(new MyViewModel());
</script>
</body>
</html>
다음 줄에서 처음 두 개는 입력 값을 받기위한 것입니다. 세 번째 줄은이 두 숫자의 평균을 인쇄합니다.
<p>Enter first number: <input data-bind = "value: a" /></p>
<p>Enter second number: <input data-bind = "value: b"/></p>
<p>Average := <span data-bind = "text: totalAvg"></span></p>
다음 줄에서 Observable 유형 a 과 bViewModel 내에서 처음 초기화 될 때 숫자입니다. 그러나 KO에서 UI에서 허용되는 모든 입력은 기본적으로 문자열 형식입니다. 따라서 산술 연산을 수행하려면 숫자로 변환해야합니다.
this.totalAvg = ko.computed(function() {
if(typeof(this.a()) !== "number" || typeof(this.b()) !== "number") {
this.a(Number(this.a())); //convert string to Number
this.b(Number(this.b())); //convert string to Number
}
total = (this.a() + this.b())/2 ;
return total;
},this);
다음 줄에는 계산 된 평균이 UI에 표시됩니다. totalAvg의 데이터 바인딩 유형은 텍스트 일뿐입니다.
<p>Average := <span data-bind = "text: totalAvg"></span></p>
산출
위의 코드가 어떻게 작동하는지보기 위해 다음 단계를 수행해 보겠습니다.
위의 코드를 computed-observable.htm 파일.
브라우저에서이 HTML 파일을 엽니 다.
텍스트 상자에 숫자 2 개를 입력하고 평균이 계산되는지 확인합니다.
'This'관리
위의 예에서 두 번째 매개 변수는 다음과 같이 제공됩니다. this계산 된 함수에. Observable을 참조 할 수 없습니다.a() 과 b() 제공하지 않고 this.
이를 극복하기 위해 self 참조를 보유하는 변수가 사용됩니다. this. 이렇게하면 추적 할 필요가 없습니다.this코드 전반에 걸쳐. 대신self 사용할 수 있습니다.
위의 예제에서 self를 사용하여 다음 ViewModel 코드를 다시 작성합니다.
function MyViewModel(){
self = this;
self.a = ko.observable(10);
self.b = ko.observable(40);
this.totalAvg = ko.computed(function() {
if(typeof(self.a()) !== "number" || typeof(self.b()) !== "number") {
self.a(Number(self.a())); //convert string to Number
self.b(Number(self.b())); //convert string to Number
}
total = (self.a() + self.b())/2 ;
return total;
});
}
순수 계산 된 Observable
Computed Observable은 다음과 같이 선언되어야합니다. PureObservable이 단순히 값을 계산하고 반환하고 다른 객체 나 상태를 직접 수정하지 않는 경우 Computed Observable입니다. Pure Computed Observable은 Knockout이 재평가 및 메모리 사용을 효율적으로 관리하는 데 도움이됩니다.
구독자에게 명시 적으로 알림
Computed Observable이 원시 데이터 유형 값 (String, Boolean, Null 및 Number)을 반환하면 실제 값 변경이 발생하는 경우에만 구독자에게 알림이 전송됩니다. Observable이 이전 값과 동일한 값을 수신 한 경우 구독자에게 알림이 전송되지 않음을 의미합니다.
새 값이 이전 값과 동일하더라도 Computed Observable은 항상 옵저버에게 명시 적으로 알릴 수 있습니다. notify 구문은 다음과 같습니다.
myViewModel.property = ko.pureComputed(function() {
return ...; // code logic goes here
}).extend({ notify: 'always' });
변경 알림 제한
값 비싼 업데이트가 너무 많으면 성능 문제가 발생할 수 있습니다. 다음을 사용하여 Observable에서 수신 할 알림 수를 제한 할 수 있습니다.rateLimit 다음과 같이 속성.
// make sure there are updates no more than once per 100-millisecond period
myViewModel.property.extend({ rateLimit: 100 });
속성이 계산 된 관찰 가능한지 알아 내기
특정 상황에서는 속성이 Computed Observable인지 확인해야 할 수 있습니다. 다음 함수를 사용하여 Observable 유형을 식별 할 수 있습니다.
Sr. 아니. | 함수 |
---|---|
1 | ko.isComputed 보고 true 속성이 Computed Observable 인 경우. |
2 | ko.isObservable 보고 true 속성이 Observable, Observable 배열 또는 Computed Observable 인 경우. |
삼 | ko.isWritableObservable 보고 trueObservable, Observable 배열 또는 쓰기 가능한 Computed Observable 인 경우. (이것은 ko.isWriteableObservable이라고도합니다.) |
쓰기 가능한 계산 된 Observable
Computed Observable은 하나 또는 여러 다른 Observable에서 파생되므로 읽기 전용입니다. 그러나 Computed Observable을 쓰기 가능하게 만들 수 있습니다. 이를 위해 작성된 값에 대해 작동하는 콜백 함수를 제공해야합니다.
이러한 쓰기 가능한 Computed Observable은 일반 Observable처럼 작동합니다. 또한 읽기 및 쓰기 작업을 방해하기 위해 사용자 지정 논리를 구축해야합니다.
다음과 같이 연결 구문을 사용하여 많은 Observable 또는 Computed Observable 속성에 값을 할당 할 수 있습니다.
myViewModel.fullName('Tom Smith').age(45)
예
다음 예제는 Writable Computable Observable의 사용을 보여줍니다.
<!DOCTYPE html>
<head >
<title>KnockoutJS Writable Computed Observable</title>
<script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.3.0.js"></script>
</head>
<body>
<p>Enter your birth Date: <input type = "date" data-bind = "value: rawDate" ></p>
<p><span data-bind = "text: yourAge"></span></p>
<script>
function MyViewModel() {
this.yourAge = ko.observable();
today = new Date();
rawDate = ko.observable();
this.rawDate = ko.pureComputed ({
read: function() {
return this.yourAge;
},
write: function(value) {
var b = Date.parse(value); // convert birth date into milliseconds
var t = Date.parse(today); // convert todays date into milliseconds
diff = t - b; // take difference
var y = Math.floor(diff/31449600000); // difference is converted
// into years. 31449600000
//milliseconds form a year.
var m = Math.floor((diff % 31449600000)/604800000/4.3); // calculating
// months.
// 604800000
// milliseconds
// form a week.
this.yourAge("You are " + y + " year(s) " + m +" months old.");
},
owner: this
});
}
ko.applyBindings(new MyViewModel());
</script>
</body>
</html>
위의 코드에서 rawDate UI에서 허용되는 pureComputed 속성입니다. yourAge Observable은 다음에서 파생됩니다. rawDate.
JavaScript의 날짜는 밀리 초 단위로 조작됩니다. 따라서 두 날짜 (오늘 날짜와 생년월일)가 밀리 초로 변환 된 다음 그 차이가 연도와 월로 다시 변환됩니다.
산출
위의 코드가 어떻게 작동하는지보기 위해 다음 단계를 수행해 보겠습니다.
위의 코드를 writable_computed_observable.htm 파일.
브라우저에서이 HTML 파일을 엽니 다.
생년월일을 입력하고 나이가 계산되는지 확인합니다.