Question

Javscript:

  var asdasd = {
    test: ko.observableArray([0, 50])
  };

  alert(asdasd.test()); //0,50

  asdasd.test.subscribe(function() {
    return alert("I was changed!!");
  });

  ko.bindingHandlers.rangeslider = {
    init: function(element, valueAccessor, allBindingsAccessor, viewModel) {
      var length;

      length = valueAccessor().length; //0 =(
      return alert("Why valueAccessor().length is " + length + " when it wasn't changed? =((");
    }
  };

  ko.applyBindings(asdasd);

HTML:

<div data-bind="rangeslider: test"></div>

Problem is that valueAccessor() inside init is empty, but alert stays that it has values. It works fine if I am passing rangeslider: test() (unwraping observable), but I need change value of that observable from init.

So where this value lost without notifying about it change?

http://jsfiddle.net/86sAP/3/ - live example.

Was it helpful?

Solution

You have to unwrap valueAccessor to get observable's value:

length = ko.utils.unwrapObservable(valueAccessor()).length; 

Here is updated fiddle: http://jsfiddle.net/86sAP/4/

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top