码迷,mamicode.com
首页 > Web开发 > 详细

[RxJS] Creation operator: create()

时间:2016-04-17 17:45:42      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:

We have been using Observable.create() a lot in previous lessons, so let‘s take a closer look how does it work.

 

The create function:

var foo = Rx.Observable.create( function(observer){
  observer.next(42);
  observer.next(100);
  observer.next(200);
  observer.complete();
})  ;

foo.subscribe( 
  (x)=>{console.log(next  + x);},
  (err)=>{console.log(err  + err);},
  ()=>{console.log(done);},
)

 

In deep, create() function equal to new Rx.Observable():

var foo = new Rx.Observable( function(observer){
  observer.next(42);
  observer.next(100);
  observer.next(200);
  observer.complete();
})  ;

And this also equal to:

function subscribe(observer){
  observer.next(42);
  observer.next(100);
  observer.next(200);
  observer.complete();
}
  
var foo = new Rx.Observable( subscribe );

 

So, if we get rid of RxJS, then we can create the create() function like:

function subscribe(observer){
  observer.next(42);
  observer.next(100);
  observer.next(200);
  observer.complete();
}

var observer = {
  next: (x)=>{console.log(next  + x);},
  error: (err)=>{console.log(err  + err);},
  complete: ()=>{console.log(done);}
}


subscribe(observer);

Of course, it‘s useful to have the observable type because then it has all those nice operators that we saw and that we are also seeing new operators coming next. If you paid attention, then you‘re going to remember that in the subscribe, we had previously three functions here as argument. Instead of an object, as we have now, we had just these three functions.

Also, the observable type, it converts these three functions into an observer object. Before it calls this, it will actually take these three functions and put labels in front of them like that, to create the observer object. It‘s normalizing it.

[RxJS] Creation operator: create()

标签:

原文地址:http://www.cnblogs.com/Answer1215/p/5401422.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!