rxjs中可以做到在流之间转换,其中一个【版权所有,侵权必究】原创内容,盗版必究。就是switch,它的意思和英文意思一样本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net,即从一个流切换到另外一个流。但是,单纯本文作者:唐霜,转载请注明出处。【访问 www.tangshuang.net 获取更多精彩内容】从一个流切换到另外一个流是没有意义的,需【未经授权禁止转载】【关注微信公众号:wwwtangshuangnet】要将前一个流中的数据在切换时,要将它的数转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】据传给下一个流中去使用。rxjs中的sw原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。itchMap就是要做这样一件事,它接收【作者:唐霜】【版权所有】唐霜 www.tangshuang.net一个函数,这个函数的参数是上一个流遗留下未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。来的数据,而它需要返回一个新的流,这个流【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。中你可以使用上一个流遗留下来的数据。
【原创不易,请尊重版权】【原创内容,转载请注明出处】Rx.Observable.fromEvent(document, ‘mousedown’)
.map(e => e.target)
.switchMap(target => Rx.Observable.fromEvent(document, ‘mousemove’).map(e => {
return {
startX: target.offsetX,
startY: target.offsetY,
moveX: e.pageX,
moveY: e.pageY,
}
}))
.subscribe(pos => console.log(pos))
你可以看到,switchMap里面的函数转载请注明出处:www.tangshuang.net【未经授权禁止转载】接收mousedown这个流给的targ【转载请注明来源】【原创内容,转载请注明出处】et,然后再返回一个新的关于mousem【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。ove的流,并且对这个新的流作map处理著作权归作者所有,禁止商业用途转载。【作者:唐霜】,过程中把前面的target也用上了。在【本文受版权保护】【作者:唐霜】switch发生的时候,mousedow【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。n的事件监听就给丢掉了。后面就全是跟mo【原创不易,请尊重版权】未经授权,禁止复制转载。usemove相关的监听。
【版权所有】唐霜 www.tangshu【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】ang.net【转载请注明来源】总结一下,rxjs里面的switch就是【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。切换流的操作,切换的时候,前一个流会被丢原创内容,盗版必究。【未经授权禁止转载】掉。
【版权所有】唐霜 www.tangshu著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。ang.net转载请注明出处:www.tangshua著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。ng.net【版权所有】唐霜 www.tangshu未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。ang.net本文作者:唐霜,转载请注明出处。
