在做上一期 未经授权,禁止复制转载。robust【访问 www.tangshuang.net 获取更多精彩内容】 的时候,受到【版权所有】唐霜 www.tangshuang.net这篇文章【本文受版权保护】的启示,重新理解了 rxjs 的事件流这【本文受版权保护】【关注微信公众号:wwwtangshuangnet】个概念。结合响应式编程范式的两个目标,对转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】 rxjs 的理解又有了新的认识。
【本文受版权保护】【原创不易,请尊重版权】【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】rxjs 是观察者模式、迭代器模式、函数【版权所有,侵权必究】【转载请注明来源】式编程的结合体。其中,我一直对迭代器模式本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】这个点不是很理解。在阅读上面那篇文章之后【本文受版权保护】未经授权,禁止复制转载。,我的思维豁然开朗了。在此之前,我只能强【版权所有】唐霜 www.tangshuang.net【本文受版权保护】迫性的理解,new本文作者:唐霜,转载请注明出处。 Observable 本质上是在决定什么本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】时候进行迭代动作,也就是调用 next。【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】但是,迭代器本身是怎么来的呢?我刚开始默本文作者:唐霜,转载请注明出处。【转载请注明来源】认认为,迭代器需要用户自己构造。但在读完【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。上面那篇文章之后,有了新的见解。rxjs著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。 将一个对象的某个事件(例如 DOM 节本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。点的 click 事件),在时间上的发生【作者:唐霜】【访问 www.tangshuang.net 获取更多精彩内容】,抽象为一个虚拟的数组,它的示意图:
【版权所有,侵权必究】转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】【原创内容,转载请注明出处】
这个虚拟数组,和普通数组不一样,它不是在著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。一开始就确定的,而是随着时间的流逝,不断本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。往数组中新加元素,知道该对象被销毁,该数【转载请注明来源】【转载请注明来源】组也自动被销毁。而往数组中新增元素的过程【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。,就是 next 被调用的时候。你可以想【原创内容,转载请注明出处】原创内容,盗版必究。象成,这是一个无限个数坑位的列表,一个 本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】click 发生,一个坑位就被填了,这个【版权所有,侵权必究】【访问 www.tangshuang.net 获取更多精彩内容】填坑位的过程,就是 next。而这个虚拟【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.net的数组,就是事件流的抽象表示。
【未经授权禁止转载】原创内容,盗版必究。未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net既然是一个数组,那么就可以调用迭代器方法【访问 www.tangshuang.net 获取更多精彩内容】【本文受版权保护】,rxjs 内置了非常多迭代器方法,比如本文版权归作者所有,未经授权不得转载。【本文受版权保护】常见的 map, filter, red未经授权,禁止复制转载。【作者:唐霜】uce。而 new【关注微信公众号:wwwtangshuangnet】 Observable 本质上就是在构造这【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.net个迭代器数组。叫 Observable 未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。很傻,还是叫 Stream 比较直观。
著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】
