请问前辈,angular如果要引入rxjs相关api的话,到底正确姿势是怎样的?

各位前辈好,是这样的,我最近在看一个angular教学视频,对视频里的rxjs的api引入很混乱,不知道到底正确的引入是怎样的,比如

图片描述

请问这两种方式到底有什么不同,我测试了一下,发现上面两种方式引入都可以正常编写啊,

但是下面这种的话,为什么第一个引入会报错???第二个引入才可以,那请问是不是如果我要使用其他api,比如switchMap,filter,from,take之类的,全部都要这样
{xxx,xxx,xxx} from "rxjs/add/operator/xxx" 引入才行啊??????

图片描述

打扰了,望各位前辈指教!!

阅读 3.1k
1 个回答

rxjs github上有一句话做了说明,引入ObservableSubjectSubscription最好的方式就是

To import only what you need by patching (this is useful for size-sensitive bundling):
import { Observable } from 'rxjs/Observable';

也就是说,需要什么,就去对应的准备包下引用。
尤其是当你的应用很大时,希望尽量压缩打包的bundle的大小,这个时候import的路径就尤为重要了。
如果使用这种方式 import { Observable } from 'rxjs', 打包的时候会把rxjs下的内容都打到bundle里面,这显然是没有必要的。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题