An open API service indexing awesome lists of open source software.

https://github.com/luisvonmuller/typescript-para-brasileiros

Um guia não oficial do Typescript para Brasileiros. Boas Práticas, guia de estilos, exemplos e clarificações. O nosso handbook 🇧🇷
https://github.com/luisvonmuller/typescript-para-brasileiros

brasil handbook pt-br styleguide traducao-ingles-para-portugues typescript

Last synced: 7 months ago
JSON representation

Um guia não oficial do Typescript para Brasileiros. Boas Práticas, guia de estilos, exemplos e clarificações. O nosso handbook 🇧🇷

Awesome Lists containing this project

README

          

# 🇧🇷 Guia de Estilos 🎨

🔥 Este é um **Guia não oficial** e você pode opinar através do repositório de GitHub para juntos chegarmos a melhor definição do Ideal! **Vamos colaborar? 💪**

## 👉 Navegação por tópico facilitada!

* [⭐️ Variáveis & Funções](./#variaveis-e-funcoes)
* [📦 Classes](./#class)
* [🔌 Interfaces](./#interfaces)
* [🌟 Tipos](./#tipos)
* [😳 Namespaces](./#namespaces)
* [🔢 Enum](./#enum)
* [📭 null vs 😱 undefined](./#null-vs-undefined)
* [📑 Formatação](./#formatacao)
* [🤔 Aspas simples vs Aspas Duplas](./#sobre-aspas...)
* [⚙️ Uso de ponto e vírgula ao final de linhas **" ; "**](./#ponto-and-virgula)****
* [📂 Uma sugestão para uma boa nomeação de Arquivos](./#sugestao-para-boa-nomeacao-de-arquivos.)
* [🤨 Tipo vs Interface](./#tipo-ou-interface)
* [👯‍♀️ Anotação de Tipos para Array](./#anotacao-do-tipo-array)
* [⚠️ Comparadores, "==" vs "==="](./#comparadores-e)

## ⭐️​ Variáveis e Funções:

{% hint style="success" %}
Use _**camelCase**_ para nomear variáveis e funções
{% endhint %}

#### Má nomenclatura 🚫

```typescript
let FulanoVariavel: string = 'Aqui está errado.. ( ఠ ͟ʖ ఠ )';
function CiclanoFuncao(){}
```

#### Boa nomenclatura ✅​

```typescript
let fulanoVariavel: string = 'Aqui está daora! (✿◠‿◠)';
function ciclanoFuncao(){}
```

## 📦 Class

{% hint style="success" %}
Use _**PascalCase**_ para nomear suas classes! (Ou use programação funcional 👀)
{% endhint %}

#### Má nomenclatura 🚫

```typescript
class fulano {}
```

#### Boa nomenclatura ✅​

```typescript
class Fulano {}
```

{% hint style="success" %}
Use _**camelCase**_ para as propriedades e métodos de suas classes! 🔥
{% endhint %}

#### Má nomenclatura 🚫

```typescript
class fulano {
DeTal: string;
Ciclano( ){ }
}
```

#### Boa nomenclatura ✅​

```typescript
class Fulano {
deTal: string;
ciclano( ){ }
}
```

## 🔌​ Interfaces:

{% hint style="success" %}
Use _**PascalCase**_ para nomear a Interface ⚙️

* Use _**camelCase**_ para nomear seus membros 🥰
{% endhint %}

{% hint style="danger" %}
Não use o Prefixo "I", exemplo: IfuncaoFulano... 😡
{% endhint %}

#### Má nomenclatura 🚫

```typescript
interface IFulano {
DeTal: string;
}
```

#### Boa nomenclatura ✅​

```typescript
interface Fulano {
deTal: string;
}
```

## 🌟 Tipos

{% hint style="success" %}
Use _**PascalCase**_ para nomear o seu Tipo ⚙️

* Use _**camelCase**_ para nomear as propriedades do seu tipo! 🥰
{% endhint %}

#### Má nomenclatura 🚫

```typescript
type fulano = {
DeTal: string;
}
```

#### Boa nomenclatura ✅​

```typescript
type Fulano = {
deTal: string;
}
```

## 😳 Namespaces

{% hint style="success" %}
Use**`PascalCase `**`para nomear os "Namespaces" - ⭐️ Padrão do time do TS.`
{% endhint %}

#### Má nomenclatura 🚫

```typescript
namespace fulanoDeTal {
}
```

#### Boa nomenclatura ✅​

```typescript
namespace FulanoDeTal {
}
```

## 🔢 Enum

{% hint style="success" %}
Use_**`PascalCase`**_`para nomear os Enums.`

* Use _**`PascalCase`**_`para nomear seus subtipos/valores.`
{% endhint %}

#### Má nomenclatura 🚫

```typescript
enum jogodoBicho {
avestruz,
borboleta,
cachorro
}
// Não há endosso do Jogo do Bicho. Apenas é algo contextual que todo Brasileiro entenderia.
```

#### Boa nomenclatura ✅​

```typescript
enum JogoDoBicho {
Avestruz,
Borboleta,
Cachorro
}
// Não há endosso do Jogo do Bicho. Apenas é algo contextual que todo Brasileiro entenderia.
```

## 😅 Null vs Undefined 👀

{% hint style="success" %}
Tente não usar nenhum deles para indisponibilidade explícita! ⭐️
{% endhint %}

#### Mal caso de uso 🚫

```typescript
let pontos : {x: number, y: number | null | undefined } = {x: 1, y: undefined }
```

#### Bom caso de uso ✅​

```typescript
let pontos: {x: number, y?: number } = { x: 777 } //
```

{% hint style="info" %}
Em suma: Precisa informar que uma propriedade é pode ser "indefinida"? Use o operador "?" antecedendo o seu tipo! 🥰
{% endhint %}

### 👉 Retorno de funções? 🤔

Mal caso de uso 🚫

```typescript
return null;
```

Bom caso de uso ✅​

```typescript
return undefined;
```

{% hint style="info" %}
Por quê? Sugiro você consultar a página Sobre False, True, Truthy & Falsy. 🥰

\- Talvez ela ainda não esteja disponível ainda, foi mal gurizada hahaha! 😅
{% endhint %}

### 🤨​ Callbacks?

{% hint style="warning" %}
Use _**null**_ quando for parte da API ou de sua convenção usar.

É quase em um consenso em Node.js, por exemplo: **`error`** é **`null`**`em chamadas do` _**NodeBack.**_
{% endhint %}

Mal caso de uso 🚫

```typescript
callbackDeAlgo(undefined);
```

Bom caso de uso ✅​

```typescript
callbackDeAlgo(null);
```

### E como verificar isso aí? 😅

{% hint style="success" %}
Cheque por "Truthy" em objetos sendo **null** ou **undefined**.
{% endhint %}

Mal caso de uso 🚫

```typescript
if (error === null) // e se for undefined?
```

Bom caso de uso ✅​

```typescript
if (error) // é Válido tanto para undefined quanto para o null
```

### 👉 Um exemplo um pouco mais completo sobre verificação 🔥

{% hint style="success" %}
Use "==" null ou "!=" null. Não use "===" ou "!==" para checar por null ou undefined quando querendo verificar tipos primitivos porque funciona apenas nos tipos primitivos supracitados e não para valores "Falseáveis", como por exemplo: 0, false, etc.
{% endhint %}

Mal caso de uso 🚫

```typescript
if (error !== null) // Não garante que seja apenas nullo. Pode ser um valor Falseável.
```

Bom caso de uso ✅​

```typescript
if (error != null) // Garante que é um valor de tipo primitivo (ou seja, null ou undefined mas não falsy).
```

## 📑 Formatação

{% hint style="info" %}
O Compilador do _**TypeScript**_ já fornece um bom serviço de formatação estrutural, o que já é bom o suficiente para diminuir o esforço mental do desenvolvedor (ou do time). Todavia, você também pode usar o **tsfmt** no terminal (linha de comando para formatar seu código) - e também está disponível como plugin para várias **IDES (vscode, etc).**
{% endhint %}

👉 Só um exemplo que eu acho pertinente, ou melhor, uma boa prática:

```typescript
let fulano: string = 'Ciclano';
```

{% hint style="success" %}
No caso, usamos um espaço depois da definição do tipo...

* let variavel:(espaço)tipo(espaço)=(espaço)valor(ponto e virgula)
{% endhint %}

## 💬 Sobre Aspas...

{% hint style="success" %}
Prefira usar aspas simples (single quotes) ao invés de aspas duplas.

* Times grandes que usam JS/TS o fazem. É uma convenção quasae que de mercado, também é o sugerido pelo time do "Prettier".
{% endhint %}

```typescript
let nomeDoSujeito: string = 'Luís Von Müller';
```

Todavia, muita vezes em inglês precisamos usar o a single quote para conjugar um verbo: "I'm"

{% hint style="danger" %}
Se a aspas simples não lhe cabe. Use então "\`"

* Faça o uso do string template do JS ao invés de concatenar variáveis strings através var + "..." + var2.
{% endhint %}

```typescript
let nomeDoSujeito: string = 'Luís Von Müller';
console.log(`Quem escreveu? ${nomeDoSujeito}`)
```

{% hint style="warning" %}
Sobre outras coisas como usar "tabs" ou espaço. O sugerido para JS é 2 espaços (e muitas companias como Facebook, Airbnb, google seguem esse padrão. Mas o time do TS usa 4 e o do VScode também 😅. Isso é variável e de gosto muito mais pessoal ou convenção própria e do teu time 🥰
{% endhint %}

_(Mas eu uso tabs configuradas como 4 espaços)_ 🤗

## ⚙️​ Ponto & Vírgula;

{% hint style="success" %}
Use o ponto e vírgula, por quê?

* Pontos e vírgulas explícitos ajudam os identadores (tsfmt/prettier) a identificar e "estruturar" seu código.
* A falta de ponto e vírgula pode ser incômodo para novos desenvolvedores em TS. Já que a maioria das linguagens o implementa. (Houve um debate sobre como isso pode ser "incomodo" para novos desenvolvedores e outros. [https://github.com/tc39/ecma262/pull/1062](https://github.com/tc39/ecma262/pull/1062))
* Empresas grandes usam em suas implementações, ex: Google/Angular - Facebook/React - Microsoft/VScode...
{% endhint %}

## 🗂 Sugestão para boa nomeação de arquivos.

Essa aqui é uma baita de uma discussão, depende muito do que ambiente você está e se você está seguindo o padrão de nomeação de um framework, ex: React para Componentes. Mas no geral o que a maioria dos times usa é o seguinte:

{% hint style="success" %}
Use _**camelCase para nomear seus arquivos, exemplo:**_

* utils.ts
* helpersDaora.ts
* mapeamentoEndPointsDaApi.ts
{% endhint %}

## 🤨​ Tipo ou Interface?

Tipos devem ser usados para definir, adivinha? Tipos. Ou seja, se você tem uma função, ela retorna um valor. E esse valor possui um tipo. Mas essa função, também recebe algo. E esse algo, também são valores, ou seja, também podem ser tipos. Mas a "meta" ideia é que interface forneça uma interface 😅. Eu acho que esse exemplo clarifica...

{% hint style="success" %}
Quando usar qual?

* Tipos: Precisa de União ou Interseção de tipos (e provavelmente você vai preferir Tipos também se quiser implementar alguns tipos de mapeamentos Genéricos de objetos).
* Interfaces: quando você precisa dizer que algo "implements" ou "extends", como por exemplo uma classe, para receber argumentos em uma função, ou até mesmo para quando você tá querendo criar alguma função extremamente composta bem maneira 👏.

😅 Ou do jeito que você se sentir mais confortável e seguro para a implementação que está fazendo! 👀
{% endhint %}

Aqui em baixo, eu poderia definir a função de outra maneira, optei por essa.

```typescript
/** Definimos a interface (ou contrato) de uso da função */
interface DizerOi {
nome: string;
sobrenome?: string;
}

/** Definimos que o tipo de retorno da função como uma Array de Strings */
type DisseOi = string[];

/** Vamos dizer oi 10x! e retornar um array! */
const dizerOi = ({nome, sobrenome}: DizerOi): DisseOi => {
return [...Array(10).keys()].map((key) => {
return `Olá ${nome} ${sobrenome ?? ''}`;
})
}

console.log(dizerOi({nome: 'Luís'}));
```

## 👯‍♀️ Anotação do tipo Array 👯‍♂️

{% hint style="success" %}
Use tipo\[] ao invés de Array\
{% endhint %}

Mal caso de uso 🚫

```typescript
let variosNumeros: Array = [1,2,3,4,5,6,7];
```

#### Bom caso de uso ✅​

```typescript
let variosNumeros: number[] = [1,2,3,4,5,6,7];
```

## ⚠️​ Comparadores "===" e "=="

#### 😴​ Relaxa amigo! Você tá usando TypeScript. Pode usar "===" tranquilamente!

### 🥰 Obrigado por ler até aqui!