本文整理匯總了TypeScript中rxjs.concat函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript concat函數的具體用法?TypeScript concat怎麽用?TypeScript concat使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了concat函數的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: ngAfterViewInit
ngAfterViewInit() {
const searchLessons$ = fromEvent<any>(this.input.nativeElement, 'keyup')
.pipe(
map(event => event.target.value),
debounceTime(400),
distinctUntilChanged(),
switchMap(search => this.loadLessons(search))
);
const initialLessons$ = this.loadLessons();
this.lessons$ = concat(initialLessons$, searchLessons$);
}
示例2: ngxsOnInit
ngxsOnInit({ getState, dispatch }: StateContext<AppStateModel>) {
this.router.events.pipe(
filter(evt => evt instanceof ActivationEnd)
).subscribe((event: ActivationEnd) => {
const state = {...getState()};
const newSiteName = event.snapshot.queryParams['site'] || '';
const newSectionName = !event.snapshot.queryParams['section'] ? null : event.snapshot.queryParams['section'];
// Set current site and section
if (state.site !== newSiteName || state.section !== newSectionName) {
dispatch(new UpdateAppStateAction({site: newSiteName, section: newSectionName}));
}
});
this.router.events.pipe(
filter(event => event instanceof NavigationEnd),
map((event: NavigationEnd) => event.url.split('?')[0]),
filter(url => url !== '/' && url !== '/login')
).subscribe((url: string) => {
dispatch(new UpdateAppStateAction({lastRoute: url}));
});
this.appStateService.getAppMetadata().pipe(take(1))
.subscribe({
next: (metadata) => {
dispatch(new UpdateAppStateAction(metadata));
},
error: (error) => console.error(error)
});
concat(
this.appStateService.getInitialState('').pipe(take(1)),
// After each subsequent successful login, initialize the state
this.actions$.pipe(
ofActionSuccessful(UserLoginAction),
switchMap(() => this.appStateService.getInitialState('').pipe(take(1)))
)
)
.subscribe({
next: (response) => {
dispatch(new InitAppStateAction({urls: response.urls}));
},
error: (error) => console.error(error)
});
}
示例3: SchematicsException
(tree: Tree, context: SchematicContext): Observable<Tree> => {
const packageJsonContent = tree.read('/package.json');
if (!packageJsonContent) {
throw new SchematicsException('Could not find package.json.');
}
const packageJson = JSON.parse(packageJsonContent.toString());
const packages: { [name: string]: string } = {};
for (const name of supportedPackages) {
packages[name] = version;
}
return concat(
_getRecursiveVersions(packageJson, packages, allVersions, context.logger, loose).pipe(
ignoreElements(),
),
observableOf(tree),
);
},
示例4: it
it('should use the scheduler even when one Observable is concat\'d', (done) => {
let e1Subscribed = false;
const e1 = defer(() => {
e1Subscribed = true;
return of('a');
});
concat(e1, asyncScheduler)
.subscribe({
error: done,
complete: () => {
expect(e1Subscribed).to.be.true;
done();
}
});
expect(e1Subscribed).to.be.false;
});
示例5: it
it('should accept closing selector that returns a resolved promise', (done: MochaDone) => {
const e1 = concat(of(1),
timer(10).pipe(mapTo(2)),
timer(10).pipe(mapTo(3)),
timer(100).pipe(mapTo(4))
);
const expected = [[1]];
e1.pipe(bufferToggle(of(10), () => new Promise((resolve: any) => { resolve(42); })))
.subscribe((x) => {
expect(x).to.deep.equal(expected.shift());
}, () => {
done(new Error('should not be called'));
}, () => {
expect(expected.length).to.be.equal(0);
done();
});
});
示例6: it
it('supports custom rules in the project (fail)', done => {
// This test is disabled on Windows Bazel runs because it relies on TSLint custom rule
// loading behavior, which doesn't work with runfile resolution.
if (isWindowsBazel) {
done();
return;
}
const testRunner = new SchematicTestRunner(
'@_/test',
path.join(__dirname, 'test/collection.json'),
);
const host = new TempScopedNodeJsSyncHost();
host.write(normalize('/file.ts'), virtualFs.stringToFileBuffer(`
console.log('hello world');
`)).subscribe();
const tree = new UnitTestTree(new HostTree(host));
const messages: string[] = [];
let error = false;
concat(
testRunner.runSchematicAsync('custom-rule', { shouldPass: false }, tree),
new Observable<void>(obs => {
process.chdir(getSystemPath(host.root));
testRunner.logger.subscribe(x => messages.push(x.message));
testRunner.engine.executePostTasks().subscribe(obs);
}).pipe(
catchError(() => {
error = true;
return [];
}),
),
new Observable<void>(obs => {
expect(messages.find(msg => /\bcustom-rule fail\b/.test(msg))).not.toBeUndefined();
expect(error).toBe(true);
obs.complete();
}),
).toPromise().then(done, done.fail);
});
示例7: concatMap
concatMap(fullUrl => {
let maybeRequest = npmPackageJsonCache.get(fullUrl);
if (maybeRequest) {
return maybeRequest;
}
return concat(
getNpmConfigOption('proxy'),
getNpmConfigOption('https-proxy'),
).pipe(
toArray(),
concatMap(options => {
const subject = new ReplaySubject<NpmRepositoryPackageJson>(1);
const client = new RegistryClient({
proxy: {
http: options[0],
https: options[1],
},
});
client.log.level = 'silent';
const params = {
timeout: 30000,
};
client.get(
fullUrl,
params,
(error: object, data: NpmRepositoryPackageJson) => {
if (error) {
subject.error(error);
}
subject.next(data);
subject.complete();
});
maybeRequest = subject.asObservable();
npmPackageJsonCache.set(fullUrl.toString(), maybeRequest);
return maybeRequest;
}),
);
}),
示例8: ngxsOnInit
ngxsOnInit({ dispatch }: StateContext<ShopSettingsModel>) {
return concat(
this.stateService.getInitialState('', 'settings').pipe(take(1)),
/* LOGIN: */
this.store$.select(UserState.isLoggedIn).pipe(
pairwise(),
filter(([wasLoggedIn, isLoggedIn]) => !wasLoggedIn && isLoggedIn),
switchMap(() => this.stateService.getInitialState('', 'settings').pipe(take(1)))
)
).subscribe((settings) => {
const newState: {[k: string]: any} = {};
for (const siteSlug in settings) {
newState[siteSlug] = this.initializeShopSettingsForSite(settings[siteSlug]);
}
dispatch(new InitShopSettingsAction(newState));
});
}
示例9: it
it('should auditTime events multiple times', () => {
const expected = ['1-2', '2-2'];
concat(
timer(0, 10, rxTestScheduler).pipe(
take(3),
map((x: number) => '1-' + x)
),
timer(80, 10, rxTestScheduler).pipe(
take(5),
map((x: number) => '2-' + x)
)
).pipe(
auditTime(50, rxTestScheduler)
).subscribe((x: string) => {
expect(x).to.equal(expected.shift());
});
rxTestScheduler.flush();
});
示例10: EncryptedMediaError
.pipe(mergeMap((keyStatusesEvent: Event) => {
log.debug("EME: keystatuseschange event", session, keyStatusesEvent);
// find out possible errors associated with this event
const warnings : IEMEWarningEvent[] = [];
(session.keyStatuses as any).forEach((keyStatus : string, keyId : string) => {
// Hack present because the order of the arguments has changed in spec
// and is not the same between some versions of Edge and Chrome.
if (keyStatus === KEY_STATUS_EXPIRED ||Â keyId === KEY_STATUS_EXPIRED) {
const { throwOnLicenseExpiration } = keySystem;
const error = new EncryptedMediaError("KEY_STATUS_CHANGE_ERROR",
"A decryption key expired", false);
if (throwOnLicenseExpiration !== false) {
throw error;
}
warnings.push({ type: "warning", value: error });
}
if (KEY_STATUS_ERRORS[keyId]) {
throw new EncryptedMediaError("KEY_STATUS_CHANGE_ERROR",
"An invalid key status has been encountered: " + keyId, true);
} else if (KEY_STATUS_ERRORS[keyStatus]) {
throw new EncryptedMediaError("KEY_STATUS_CHANGE_ERROR",
"An invalid key status has been encountered: " + keyStatus, true);
}
});
const warnings$ = warnings.length ? observableOf(...warnings) : EMPTY;
const handledKeyStatusesChange$ = tryCatch(() => {
return keySystem && keySystem.onKeyStatusesChange ?
castToObservable(
keySystem.onKeyStatusesChange(keyStatusesEvent, session)
) as Observable<TypedArray|ArrayBuffer|null> : EMPTY;
}, undefined).pipe() // TS or RxJS Bug?
.pipe(
catchError((error: Error) => {
throw new EncryptedMediaError(
"KEY_STATUS_CHANGE_ERROR", error.toString(), true);
}),
map((licenseObject) => ({
type: "key-status-change" as "key-status-change",
value : { license: licenseObject },
}))
);
return observableConcat(warnings$, handledKeyStatusesChange$);
}));