Я думаю, что я неправильно понимаю что-то фундаментальное, потому что, на мой взгляд, это должен быть самый простой случай для наблюдаемого, но на всю жизнь я не могу понять, как это сделать из документации.
По сути, я хочу уметь это делать:
// create a dummy observable, which I would update manually
var eventObservable = rx.Observable.create(function(observer){});
var observer = eventObservable.subscribe(
function(x){
console.log('next: ' + x);
}
...
var my_function = function(){
eventObservable.push('foo');
//'push' adds an event to the datastream, the observer gets it and prints
// next: foo
}
Но мне так и не удалось найти способ вроде push
. Я использую это для обработчика кликов, и я знаю, что они есть Observable.fromEvent
для этого, но я пытаюсь использовать его с React, и я бы предпочел просто обновить поток данных в обратном вызове, вместо того, чтобы использовать совершенно другой система обработки событий. В общем, я хочу это:
$( "#target" ).click(function(e) {
eventObservable.push(e.target.text());
});
Самое близкое, что у меня было observer.onNext('foo')
, было использование , но это, похоже, на самом деле не сработало, и это вызвало наблюдателя, что кажется неправильным. Наблюдатель должен реагировать на поток данных, а не изменять его, верно?
Я просто не понимаю отношения наблюдатель / наблюдаемое?