保誠-保戶業務員媒合平台
HelenHuang
2022-06-09 9bdb95c9e34cef640534e5e5a1e2225a80442000
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/**
Get the element type of an `Iterable`/`AsyncIterable`. For example, an array or a generator.
 
This can be useful, for example, if you want to get the type that is yielded in a generator function. Often the return type of those functions are not specified.
 
This type works with both `Iterable`s and `AsyncIterable`s, so it can be use with synchronous and asynchronous generators.
 
Here is an example of `IterableElement` in action with a generator function:
 
@example
```
function * iAmGenerator() {
    yield 1;
    yield 2;
}
 
type MeNumber = IterableElement<ReturnType<typeof iAmGenerator>>
```
 
And here is an example with an async generator:
 
@example
```
async function * iAmGeneratorAsync() {
    yield 'hi';
    yield true;
}
 
type MeStringOrBoolean = IterableElement<ReturnType<typeof iAmGeneratorAsync>>
```
 
Many types in JavaScript/TypeScript are iterables. This type works on all types that implement those interfaces. For example, `Array`, `Set`, `Map`, `stream.Readable`, etc.
 
An example with an array of strings:
 
@example
```
type MeString = IterableElement<string[]>
```
*/
export type IterableElement<TargetIterable> =
    TargetIterable extends Iterable<infer ElementType> ?
    ElementType :
    TargetIterable extends AsyncIterable<infer ElementType> ?
    ElementType :
    never;