Evolve your development workflow
data:image/s3,"s3://crabby-images/335bc/335bc815b6b5c0cf5d116d750aee82cbcb7bf72b" alt=""
data:image/s3,"s3://crabby-images/38990/38990ff10e60005cd81e96da06d87d18b53dbde8" alt=""
Guillaume Chau
Vue.js Core Team
We need better tools to build great apps
Why?
data:image/s3,"s3://crabby-images/ccfab/ccfab99f3ebbb2b979a850ab750d61697bc12906" alt=""
data:image/s3,"s3://crabby-images/bcad1/bcad1f6077fc8ee19c10ecb291508f1875650e62" alt=""
Mobile World
Latency
Bandwidth
Processing power
Realtime data
Today's apps are complex
MongoDB
MySQL
Oracle
ERP
CRM
Vue
Angular
React
Micro-services
Redis
Android
iOS
Legacy custom apps
AWS
JavaScript
Java
C#
Team Communication needs
Frontend Team
Backend Team
DataBase Team
Other Service Team
Mobile World
Today's apps are complex
Team Communication needs
Why?
GraphQL solves problems
Apollo adds value
Vue makes it approachable
1
2
3
GraphQL solves problems
1
What is GraphQL?
Schema definition language
Query language
Community of tools
data:image/s3,"s3://crabby-images/51f34/51f346ff661a9317438bce7d4ddb7f62fbda663b" alt=""
Strong typing
type Message {
id: ID!
content: String
user: User
date: Int
}
type User {
id: ID!
name: String
email: String
avatarUrl: String
}
type Query {
messages: [Message]
}
Strong typing
Help prevent errors
Improve the debugging experience
More explicit API (auto Docs)
Query only the data you need
{
messages {
id
content
user {
id
name
}
}
}
{
"data": {
"messages": [
{
"id": "0",
"content": "Are you enjoying the conference?",
"user": {
"id": "0",
"name": "Anne"
}
},
{
"id": "1",
"content": "Absolutely!",
"user": {
"id": "1",
"name": "Yoan"
}
}
]
}
}
Query only the data you need
Reduce transfer size
No waterfall requests
Get predictable data shape
Clear and simple structure
data:image/s3,"s3://crabby-images/f4397/f4397e316113dd7690ff65570160b6a33dc414b2" alt=""
Version-less
Add new fields
Deprecate old ones
data:image/s3,"s3://crabby-images/cad40/cad408aa5e73f28e64bc66b504a6fe8a26d6e502" alt=""
Strong typing
Query language
Simpler architecture
Version-less
GraphQL
Apollo adds value
2
What is Apollo?
Server tools
Feature-rich client
Strong community
data:image/s3,"s3://crabby-images/d4d95/d4d952168f79f83feb35e5cdf028157b369c3799" alt=""
Principles
By the community, for the community
Simplicity
Performance
Apollo Client
Query
Mutation
Subscription (Web socket)
.gql
Observable
query
data:image/s3,"s3://crabby-images/e0350/e03501461c2b97241b28c1a639dd07da8d948467" alt=""
Normalized Cache
Apollo Devtools
data:image/s3,"s3://crabby-images/b27e0/b27e0a90f25b27abf8135bb775935be8cbd4f746" alt=""
Apollo Server
data:image/s3,"s3://crabby-images/b1ca0/b1ca0a208930849a4e51a9891a9af075c0fd7201" alt=""
Apollo Launchpad
Like JSFiddle but for a GraphQL API
Prototype a GraphQL schema in minutes
Schema Stitching
data:image/s3,"s3://crabby-images/8d9b6/8d9b689c1193f07d0a0986cffeb71cde56ac4dd4" alt=""
Apollo Server
Apollo Client
Even more tools
Apollo
Vue makes it approachable
3
vue-apollo
data:image/s3,"s3://crabby-images/acd65/acd65d602835446b63ecb6d500e46e47130e6014" alt=""
Quick onboarding
import Vue from 'vue'
import VueApollo from 'vue-apollo'
Vue.use(VueApollo)
const provider = new VueApollo({
defaultClient: apolloClient
})
new Vue({
provide: provider.provide(),
// ...
})
Developer Experience
Automatic creation & teardown
Reactive parameters
Automatic updates
Simpler code
Colocate Data & Components
query {
user (id: $id) {
id
name
email
avatar
}
}
query {
user (id: $id) {
id
name
email
avatar
}
}
Apollo Components
<ApolloQuery
:query="require('../graphql/HelloWorld.gql')"
:variables="{ name }"
>
<template slot-scope="{ result: { loading, error, data } }">
<!-- Loading -->
<div v-if="loading" class="loading apollo">Loading...</div>
<!-- Error -->
<div v-else-if="error" class="error apollo">An error occured</div>
<!-- Result -->
<div v-else-if="data" class="result apollo">{{ data.hello }}</div>
<!-- No result -->
<div v-else class="no-result apollo">No result :(</div>
</template>
</ApolloQuery>
Apollo Components
<ApolloMutation
:mutation="require('@/graphql/userLogin.gql')"
:variables="{
email,
password,
}"
@done="onDone"
>
<template slot-scope="{ mutate, loading, error }">
<!-- Form -->
<input v-model="email" type="email">
<input v-model="password" type="password">
<button :disabled="loading" @click="mutate()">Click me</button>
<!-- Error -->
<p v-if="error">An error occured: {{ error }}</p>
</template>
</ApolloMutation>
vue-cli-plugin-apollo
data:image/s3,"s3://crabby-images/acd65/acd65d602835446b63ecb6d500e46e47130e6014" alt=""
Quicker onboarding
$ vue add apollo
Developer Experience
Included GraphQL Server
Automatic integration
Examples
Upgradable
DEMO
data:image/s3,"s3://crabby-images/88792/88792f56aa4220f5d6be50e25a9e773979a5ed79" alt=""
Quick onboarding
Developer Experience
Colocate Data & Components
Apollo Components
Vue-Apollo
Bonus
Apollo Engine
Apollo Engine
Monitoring with history
Performance tracing
Errors tracking
Schema inspect
Caching
Automatic persisted queries
1M requests per month free
data:image/s3,"s3://crabby-images/4a475/4a475483f123a8f8e5e7f3fabe1949d568b120ca" alt=""
Automatic Persisted Queries
data:image/s3,"s3://crabby-images/c29f1/c29f13996ec0445207c5de2379700a290df0ef13" alt=""
Automatic Persisted Queries
data:image/s3,"s3://crabby-images/63329/63329a73f2c0dbc00720ebb77bdca619b050b095" alt=""
DEMO
data:image/s3,"s3://crabby-images/88792/88792f56aa4220f5d6be50e25a9e773979a5ed79" alt=""
Who is using GraphQL?
data:image/s3,"s3://crabby-images/e0183/e0183cfd832049521eb823627dbaa6d55dcd5c4f" alt=""
data:image/s3,"s3://crabby-images/acd65/acd65d602835446b63ecb6d500e46e47130e6014" alt=""
data:image/s3,"s3://crabby-images/ce535/ce535521309e0840036ae0d5189d6ca810e88f62" alt=""
data:image/s3,"s3://crabby-images/74009/74009076fc7a9ab249ae7b5353919da521fae3cc" alt=""
data:image/s3,"s3://crabby-images/df60b/df60b5fac882bceb5e45b4fc9f9a559cafd29975" alt=""
You?
Case studies
data:image/s3,"s3://crabby-images/60648/606482ac9ece137e350b414b5d96d3308d57331c" alt=""
data:image/s3,"s3://crabby-images/9ecd8/9ecd88ce3d05d959967213dc17089456139f67c4" alt=""
data:image/s3,"s3://crabby-images/0c3ad/0c3ada9cfe9638ec3d63e8c45b6850665b767c78" alt=""
data:image/s3,"s3://crabby-images/45ced/45ced09982752801c14c342b34242f921ff0225c" alt=""
data:image/s3,"s3://crabby-images/cdd88/cdd8843e29fde9adc102f2d95b8cc415fecda303" alt=""
data:image/s3,"s3://crabby-images/38990/38990ff10e60005cd81e96da06d87d18b53dbde8" alt=""
Guillaume Chau
data:image/s3,"s3://crabby-images/df60b/df60b5fac882bceb5e45b4fc9f9a559cafd29975" alt=""
@Akryum
data:image/s3,"s3://crabby-images/acd65/acd65d602835446b63ecb6d500e46e47130e6014" alt=""
github.com/Akryum
Thank you!
How Vue and GraphQL can evolve your development workflow
By Guillaume Chau
How Vue and GraphQL can evolve your development workflow
Vue + Apollo + GraphQL: why it's the Ultimate Stack to build great apps
- 10,612