Skip to content

Introduction

openapi-vue-query is a type-safe tiny wrapper (1 kb) around @tanstack/vue-query to work with OpenAPI schema.

It works by using openapi-fetch and openapi-typescript so you get all the following features:

  • ✅ No typos in URLs or params.
  • ✅ All parameters, request bodies, and responses are type-checked and 100% match your schema
  • ✅ No manual typing of your API
  • ✅ Eliminates any types that hide bugs
  • ✅ Also eliminates as type overrides that can also hide bugs
vue
<script setup lang="ts">
import createFetchClient from "openapi-fetch";
import createClient from "openapi-vue-query";
import type { paths } from "./my-openapi-3-schema.d.ts"; // generated by openapi-typescript

const fetchClient = createFetchClient<paths>({
  baseUrl: "https://myapi.dev/v1/",
});
const $api = createClient(fetchClient);

const { data, error, isLoading } = $api.useQuery(
  "get",
  "/blogposts/{post_id}",
  {
    params: {
      path: { post_id: 5 },
    },
  }
)
</script>

<template>
  <div>
    <template v-if="isLoading || !data">
      Loading...
    </template>
    <template v-else-if="error">
      An error occurred: {{ error.message }}
    </template>
    <template v-else>
      {{ data.title }}
    </template>
  </div>
</template>

Setup

Install this library along with openapi-fetch and openapi-typescript:

bash
npm i openapi-vue-query openapi-fetch
npm i -D openapi-typescript typescript

Highly recommended

Enable noUncheckedIndexedAccess in your tsconfig.json (docs

bash
# Generate types from the sample schema
npx openapi-typescript ./my-openapi-3-schema.yaml -o ./my-openapi-3-schema.d.ts

# Or from your own schema
npx openapi-typescript ./path/to/your/api.yaml -o ./src/lib/api/v1.d.ts

Basic usage

Next, you need an OpenAPI schema to work with. For this tutorial, download our sample blog API schema:

📁 Download sample schema: my-openapi-3-schema.yaml

Then generate TypeScript types from the schema using openapi-typescript:

Once your types have been generated from your schema, you can create a fetch client, a vue-query client and start querying your API.

vue
<script setup lang="ts">
import createFetchClient from "openapi-fetch";
import createClient from "openapi-vue-query";
import type { paths } from "./my-openapi-3-schema"; // generated by openapi-typescript

const fetchClient = createFetchClient<paths>({
  baseUrl: "https://myapi.dev/v1/",
});
const $api = createClient(fetchClient);

const { data, error, isLoading } = $api.useQuery(
  "get",
  "/blogposts/{post_id}",
  {
    params: {
      path: { post_id: 5 },
    },
  }
)
</script>

<template>
  <div>
    <template v-if="isLoading || !data">
      Loading...
    </template>
    <template v-else-if="error">
      An error occurred: {{ error.message }}
    </template>
    <template v-else>
      {{ data.title }}
    </template>
  </div>
</template>

TIP

You can find more information about createFetchClient on the openapi-fetch documentation.