Nuxt module that provides seamless integration with multiple API endpoints. It generates type-safe composables for each API endpoint you configure, offering a familiar developer experience similar to Nuxt's useFetch and $fetch while keeping your API credentials secure and eliminating CORS issues through a server proxy.
- ๐ช Auto-generated composables for each API endpoint
- ๐ Protected API credentials with Nuxt proxy route
- ๐ No CORS issues
- ๐ฑ Familiar developer experience to
useFetchand$fetch - ๐ง Connect all your APIs
- ๐ฆพ Fully typed API clients from OpenAPI specifications
- ๐ Smart caching & hydration
npx nuxt module add api-partyAdd the Nuxt API Party to your Nuxt config and prepare your first API connection by setting an endpoint object with the following properties for the apiParty module option:
// `nuxt.config.ts`
export default defineNuxtConfig({
modules: ['nuxt-api-party'],
apiParty: {
endpoints: {
jsonPlaceholder: {
url: process.env.JSON_PLACEHOLDER_API_BASE_URL!,
// Global headers sent with each request
headers: {
Authorization: `Bearer ${process.env.JSON_PLACEHOLDER_API_TOKEN}`
}
}
}
}
})If you were to call your API jsonPlaceholder, the generated composables are:
$jsonPlaceholderโ Returns the response data, similar to$fetchuseJsonPlaceholderDataโ Returns multiple values similar touseFetch
Use these composables in your templates or components:
<script setup lang="ts">
const { data, refresh, error, status, clear } = await useJsonPlaceholderData('posts/1')
</script>
<template>
<h1>{{ data?.title }}</h1>
<pre>{{ JSON.stringify(data, undefined, 2) }}</pre>
</template>Tip
You can connect as many APIs as you want, just add them to the endpoints object.
- Clone this repository
- Enable Corepack using
corepack enable - Install dependencies using
pnpm install - Run
pnpm run dev:prepare - Start development server using
pnpm run dev
- Dennis Baum for sponsoring the initial version of this package.
- Konkon for his logo pixel art.
MIT License ยฉ 2022-PRESENT Johann Schopplich
MIT License ยฉ 2025-PRESENT Matthew Messinger
