vector-im-hydrogen-web/doc/TS-MIGRATION.md

14 lines
910 B
Markdown
Raw Normal View History

2021-11-30 14:17:51 +00:00
# Typescript style guide
2021-11-30 14:15:25 +00:00
## Use `type` rather than `interface` for named parameters and POJO return values.
2021-12-01 16:05:16 +05:30
`type` and `interface` can be used somewhat interchangeably, but let's use `type` to describe data and `interface` to describe (polymorphic) behaviour.
2021-11-30 14:15:25 +00:00
Good examples of data are option objects to have named parameters, and POJO (plain old javascript objects) without any methods, just fields.
Also see [this playground](https://www.typescriptlang.org/play?#code/C4TwDgpgBACghgJwgO2AeTMAlge2QZygF4oBvAKCiqmTgFsIAuKfYBLZAcwG5LqATCABs4IAPzNkAVzoAjCAl4BfcuVCQoAYQAWWIfwzY8hEvCSpDuAlABkZPlQDGOITgTNW7LstWOR+QjMUYHtqKGcCNilHYDcAChxMK3xmIIsk4wBKewcoFRVyPzgArV19KAgAD2AUfkDEYNDqCM9o2IQEjIJmHT0DLvxsijCw-ClIDsSjAkzeEebjEIYAuE5oEgADABJSKeSAOloGJSgsQh29433nVwQlDbnqfKA)
2021-12-01 16:05:16 +05:30
## Use `Record<string, any>` to describe a type that accepts any Javascript object.
Prefer this over index signature, `any` or `object`.