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 유형 abViewModel 내에서 처음 초기화 될 때 숫자입니다. 그러나 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 파일을 엽니 다.

  • 생년월일을 입력하고 나이가 계산되는지 확인합니다.