this.counter$ = store.select(fro
2021-02-09 本文已影响0人
华山令狐冲
this.counter$ = store.select(fromExample.getCounterCounter);
上述调用返回一个Observable<number>:
data:image/s3,"s3://crabby-images/594ba/594ba9c1402611505a9366dc6523c70a3f6d7541" alt=""
data:image/s3,"s3://crabby-images/0c283/0c283745ca7a669ad71a94bc24543170b4e425ea" alt=""
传入select方法的fromExample.getCounterCounter是一个createSelector返回的值:
data:image/s3,"s3://crabby-images/6bb5b/6bb5bdaa77df64e19be441a20b0b4e89f6cc2249" alt=""
执行select操作:
data:image/s3,"s3://crabby-images/8bd38/8bd387d82255755bcb62d906aefd32846dd3eccc" alt=""
data:image/s3,"s3://crabby-images/81195/811953ffcef156fd14edae4b5c33624c9222e41d" alt=""
pathOrMapFn就是fromExample.getCounterCounter指向的值:
注意,Store是Observable的子类,这个select是Store的重新实现:
data:image/s3,"s3://crabby-images/66ea4/66ea4025cc99bcbde6a183c7997dda402bb2cb5e" alt=""
data:image/s3,"s3://crabby-images/8cbc8/8cbc841328aa53cc8ace8a191cdd85e254a9bc21" alt=""
data:image/s3,"s3://crabby-images/d47c0/d47c0e6c08c80c481df7e89421e61a55b7c7bbe4" alt=""
这个source$就是store.select(fromExample.getCounterCounter);里的store:
data:image/s3,"s3://crabby-images/6511f/6511f22e70b625701b1a7bdc96bcc54ed6fb1b6a" alt=""
最后返回的是一个施加了MapOperator的新Store(新Observable):
data:image/s3,"s3://crabby-images/0dbc8/0dbc83f4b68b622b03454cb56888a0fe040788d5" alt=""
而我们应用程序传入selector的fromExample.getCounterCounter,体现在这个新store的什么地方?
source就是我们应用代码里构造函数注入的store,父类是Observable.
data:image/s3,"s3://crabby-images/06e71/06e71ca052739d980f85c749ddbef536b1fd0b8f" alt=""
对于source store,执行map里指定的箭头函数,即我们应用程序传入store.select里的函数:
data:image/s3,"s3://crabby-images/37733/3773337ecfe8f54f1b27508ee75c1c6273e25941" alt=""
位于第976行:
data:image/s3,"s3://crabby-images/2acfa/2acfabdd3fad34211ef7d43ccb50155979e9b502" alt=""
data:image/s3,"s3://crabby-images/8e285/8e2850581ad6441dbe0d46b045bfa9562202ea4b" alt=""
我们传入的getCounter(第1061行的projector)被一个memoize函数修饰:
data:image/s3,"s3://crabby-images/65e98/65e988ed471f652d9e70f1dc6536982ccca2c264" alt=""
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/5c245/5c2451227ab390a16b5fe9bdbec5d83178d7661c" alt=""