This course is no longer maintained and may be out-of-date. While it remains available for reference, its content may not reflect the latest updates, best practices, or supported features.
Query Variables
What is a variable in GraphQL context?
GraphQL has a first-class way to factor dynamic values out of the query, and pass them as a separate dictionary. These values are called variables. In our case, we are defining the object to be inserted as a mutation.
So let's define the graphql mutation to be used with variables.
Open src/components/TodoInput.vue
and add the following code:
<script setup lang="ts">import { ref } from "vue"+ import { useMutation } from "@vue/apollo-composable"+ import { INSERT_TODOS_ONE } from "../graphql-operations"const { type } = defineProps({ type: String })const newTodoTitle = ref("")+ const insertTodoMutation = useMutation(INSERT_TODOS_ONE)async function addTodo({ todoTitle, type }: { todoTitle: string; type: string }) {// Code to add todo here}</script>
What does this mutation do?
The mutation inserts into todos
table with the todo_insert_input
variable being passed.
Awesome! We have defined our first graphql mutation.
Build apps and APIs 10x faster
Built-in authorization and caching
8x more performant than hand-rolled APIs
data:image/s3,"s3://crabby-images/5de8f/5de8f46ccc38d91be67c56d052a39e63bb0bfc6e" alt="Promo"
data:image/s3,"s3://crabby-images/868ff/868ffb1210a1adc758a09817d07c9681a5c10cc9" alt="footer illustration"