Use Supabase with Nuxt
Learn how to create a Supabase project, add some sample data to your database, and query the data from a Nuxt app.
Create a Supabase project
Go to database.new and create a new Supabase project.
When your project is up and running, go to the Table Editor, create a new table and insert some data.
Alternatively, you can run the following snippet in your project's SQL Editor. This will create a instruments
table with some sample data.
12345678910111213-- Create the tablecreate table instruments ( id bigint primary key generated always as identity, name text not null);-- Insert some sample data into the tableinsert into instruments (name)values ('violin'), ('viola'), ('cello');alter table instruments enable row level security;
Make the data in your table publicly readable by adding an RLS policy:
1234create policy "public can read instruments"on public.instrumentsfor select to anonusing (true);
Create a Nuxt app
Create a Nuxt app using the npx nuxi
command.
1npx nuxi@latest init my-app
Install the Supabase client library
The fastest way to get started is to use the supabase-js
client library which provides a convenient interface for working with Supabase from a Nuxt app.
Navigate to the Nuxt app and install supabase-js
.
1cd my-app && npm install @supabase/supabase-js
Query data from the app
In app.vue
, create a Supabase client using your project URL and public API (anon) key:
Project URL
To get your Project URL, log in.
Anon key
To get your Anon key, log in.
Replace the existing content in your app.vue
file with the following code.
1234567891011121314151617181920<script setup>import { createClient } from '@supabase/supabase-js'const supabase = createClient('https://<project>.supabase.co', '<your-anon-key>')const instruments = ref([])async function getInstruments() { const { data } = await supabase.from('instruments').select() instruments.value = data}onMounted(() => { getInstruments()})</script><template> <ul> <li v-for="instrument in instruments" :key="instrument.id">{{ instrument.name }}</li> </ul></template>
Start the app
Start the app, navigate to http://localhost:3000 in the browser, open the browser console, and you should see the list of instruments.
1npm run dev
The community-maintained @nuxtjs/supabase module provides an alternate DX for working with Supabase in Nuxt.