É tipo assim...
data:image/s3,"s3://crabby-images/af5fe/af5fe606b828fdcb68d93a8e3d20f0f39899b272" alt=""
data:image/s3,"s3://crabby-images/d484d/d484d426db52b654f3294d7cd502764e0dd28e8b" alt=""
data:image/s3,"s3://crabby-images/8b120/8b120a9ffca80023b1ebfc4dc6116fbef641add5" alt=""
Heitor Ramon
- "Programador" de HTML
- *.IE6{_content:"Hacker";}
- Sobrevivente da era das Tabelas
- Ex Publicitário
- UX
- Frontend Developer
- Apaixonado por Hypes
data:image/s3,"s3://crabby-images/ccc1f/ccc1fc52eeeea570982f7783b6d1e231556dd41f" alt=""
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
Agenda
data:image/s3,"s3://crabby-images/00964/00964665a039a4257e15f98cd617b2e98726d29e" alt=""
: AgendaRosa
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
JS?
SFC?
TS?
data:image/s3,"s3://crabby-images/4dc5b/4dc5bf7f675304c3bc325dd50ae8b9d2e95560e4" alt=""
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
Por que usar o TS?
data:image/s3,"s3://crabby-images/cb0f2/cb0f271b70030f8090305b8e717d2061d7669310" alt=""
- Mantenabilidade Futura de Código
- Simples Refatoração
- Facilidade de leitura e entendimento do código
- @types and .d.ts
- Tipagem e Interfaces
- É Azul
- É igual ao Dollynho, seu amiguinho e te avisa dos seu erros cometidos no desenvolvimento
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
Ja posso usar no Vue 2?
SIIIIMMM!!!
O Vue 2.x já é todo tipado e pronto para iniciar o desenvolvimento com TS com ajuda de plugins considerados oficiais.
Com o lançamento do Vue 3, ele será todo re-escrito em TypeScript e o suporte será infinitamente superior, porem nada impede você de ja sair usando agora!
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
data:image/s3,"s3://crabby-images/fa346/fa34626d2a155af9fa79b677a29a33983445caa6" alt=""
Quais são estes plugins?
- vue-class-component (https://github.com/vuejs/vue-class-component)
- vue-property-decorator (https://github.com/kaorun343/vue-property-decorator)
- vuex-class (https://github.com/ktsn/vuex-class/)
- composition-api (https://github.com/vuejs/composition-api)
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
data:image/s3,"s3://crabby-images/ab4c8/ab4c8f05306d56db20b7c8ce5f04e623add4425c" alt=""
Mas posso usar em SFC?
Lógico que.... Sim! Você tem várias possibilidades de implementar ele no seu Single-File-Component, você pode usar como classe... Como um decorator de uma classe... Exportando uma classe...
A partir do Vue 3 vai ser possível o uso nativo do composition API também, sem a necessidade do plugin.
Você pode usar como objeto base também, porém não tem todos os ganhos do TS.
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
Exemplo de Vue + TS (Objeto)
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
<script lang="ts">
import Vue, { PropType } from 'vue';
import { Meta } from './models';
export default Vue.extend({
name: 'ObjectComponent',
props: {
title: {
type: String,
required: true
},
meta: {
type: (Object as unknown) as PropType<Meta>,
required: true
},
},
data(): { clickCount: number } {
return {
clickCount: 0
};
},
methods: {
increment(): void {
this.clickCount++;
},
},
});
</script>
Exemplo de Vue + TS (Class)
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
<script>
import Vue from 'vue'
import Component from 'vue-class-component'
@Component({
props: {
propMessage: String
}
})
export default class App extends Vue {
private title: string = 'Vue + TS é tipo isso...';
protected mounted (): void {
this.welcome();
}
private get computedMsg (): string {
return `Olá ${this.personName}, você está vendo, ${this.title}`;
}
public welcome: void () {
alert(this.computedMsg);
}
};
</script>
Exemplo de Vue + TS (Class & Decorator)
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
<script lang="ts">
import { Vue, Component, Prop } from 'vue-property-decorator';
import { Todo } from './models';
@Component
export default class CompositionComponent extends Vue {
@Prop({ type: String, required: true }) readonly title!: string;
@Prop(Boolean) readonly active!: boolean;
private toDos: Todo[] = [];
public addNewTodo(task) {
this.toDos.push({
task,
date: new Date().toLocaleDateString(),
})
}
protected get todoCount() {
return this.todos.length;
}
protected prettyTodo(todo: Todo) {
return `${todo.date} - ${todo.task}`;
}
}
</script>
Exemplo de Vue + TS (Composition API)
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
<script lang="ts">
import { createComponent, PropType, computed, ref } from '@vue/composition-api';
import { Meta } from './models';
function clickFeatures(): { clickCount: number; increment: () => number; } {
const clickCount: number = ref(0);
function increment(): number => clickCount.value += 1;
return { clickCount, increment };
}
export default createComponent({
name: 'CompositionComponent',
props: {
title: {
type: String,
required: true
},
meta: {
type: (Object as unknown) as PropType<Meta>,
required: true
},
},
setup({ todos }) => { ...clickFeatures() };
});
</script>
Vuex?
Vue-Router?
Vue-PluginXYZ?
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
data:image/s3,"s3://crabby-images/e8f1a/e8f1a9f43e39c0d9eb6664c92620111f085aac6d" alt=""
Posso usar TS nos plugins do Vue?
Sim, hoje todos os plugins do eco-sistema interno do Vue, como o Vuex, Vue-Router, Vue-Apollo ou Vue-i18n são 100% tipados e preparados para o uso com o TS.
E uma grande parte dos plugins e libs de terceiros já tem seus tipos definidos na própia lib, ou pelo @types, quando ela não foi escrita em TS.
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
data:image/s3,"s3://crabby-images/88390/8839027bac4a99998c03ad89411c99b1e227cb79" alt=""
E
O
Build?
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
data:image/s3,"s3://crabby-images/48dbb/48dbbd4a938a3c499992af3cc0e795a40fad0368" alt=""
Eu uso Vue-CLI, como eu faço?
Simples, você só precisa executar um comando no terminal para instalar o TS e ativar o build do seu projeto com TypeScript.
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
$ vue add typescript
data:image/s3,"s3://crabby-images/89a9e/89a9eb2100d05e0cc200c82b5c4d0ab2c499baf9" alt=""
Eu uso Quasar, como eu faço?
Simples, você só precisa executar um comando no terminal para instalar o TS e ativar o build do seu projeto com TypeScript.
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
$ quasar ext add @quasar/typescript
data:image/s3,"s3://crabby-images/44f81/44f81a6ba03dcb6e0c6ad107797a754de422262b" alt=""
Eu sou Roots, escrevi o WebPack na mão!
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
data:image/s3,"s3://crabby-images/ca1f5/ca1f5cab620ec14541de414d5dcc973e16256857" alt=""
Tá
Mas o
TypeScript?
data:image/s3,"s3://crabby-images/5c33b/5c33b39ec304c70146661818425da1bf28962955" alt=""
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
Segue em anexo...
data:image/s3,"s3://crabby-images/98a81/98a81fd56104b113abb66e71c219f1d4f60b8c7b" alt=""
data:image/s3,"s3://crabby-images/65c91/65c917ba701c4760f9bd663a947eee7af1b07acb" alt=""
data:image/s3,"s3://crabby-images/716d6/716d623915bb3d270d86005abe935f2c74553726" alt=""
@bloo_df
/bloodf
/heitorramon
data:image/s3,"s3://crabby-images/fff30/fff303724c46d0db400d876c0396659560b165c8" alt=""
data:image/s3,"s3://crabby-images/a343a/a343a4489a74a4d48d298474974b6e9491b49b3f" alt=""
Vue + TS é tipo assim...
By Heitor Ramon Ribeiro
Vue + TS é tipo assim...
Uma simples demonstração de como utilizar o Vue com o TypeScript e porque você deve fazer esta mudança o mais rápido possível.
- 361