2013-02-28 23 views
6

Gözlemlenebilir bir değerin değiştirilmesini reddetme/iptal etme yolu var mı? Bunun gibi :Gözlemlenebilir değer değişimini reddetme

observable.subscribe (function (newvalue) { 
    if (newvalue < 0) { 

     // cancel changing 
    } 
    else{ 
     // proceed with change 
    } 

}, this) 

cevap

8

Düzenleme: Bir şey daha buldum

: Yazılabilir bilgisayarlı gözlenebilir.

function AppViewModel() { 
    this.field = ko.observable("initValue"); 
    this.computedField = ko.computed({ 
     read: function() { 
      return this.field(); 
     }, 
     write: function (value) { 
      if(value > 0) { 
       this.field(value); 
      } 
     }, 
     owner: this 
    }); 
} 

Öyleyse bilgisayarlı alanına bağlamak: Burada

bir örnektir.

/Düzenleme

Özel bir bağlayıcı ile gider. dokümantasyon burada http://learn.knockoutjs.com/#/?tutorial=custombindings

veya: Burada

özel bağlama için öğretici olduğunu http://knockoutjs.com/documentation/custom-bindings.html

aşağıdaki kullanılan yazma değerlerini reddetmek yardımcı olmak için
0

:

  • bir gözlemlenebilir gizli oluştur değeri depolar.
  • Gizli gözlenebilirlere dayalı olarak hesaplanabilir bir hesaplanabilir gözlemlenebilir.
  • Hesaplanan gözlemlenebilir bir şey yazıldığında, onu kabul etmeden önce doğrulayın.

Bu kod ile Knockout uzatıldı:

ko.conditionedObservable = function (initialValue, condition) { 
    var obi = ko.observable(initialValue); 
    var computer = ko.computed({ 
     read: function() { return obi(); }, 
     write: function (newValue) { 
      //unwrap value - just to be sure 
      var v = ko.unwrap(newValue); 
      //check condition 
      if (condition(v)) { 
       //set it to the observable 
       obi(v); 
      } 
      else { 
       //reset the value 
       computer.notifySubscribers(); 
      } 
     } 
    }); 
    return computer; 
}; 

böyle nesnesinde kullanın:

field = ko.conditionedObservable<number>(null, (v) => parseInt(v) > 0); 

daha açıklama için benim Conditioning Knockout Observables: reject values blog kontrol edin.

İlgili konular