Nuxt Surveys installation

  1. Install the package

    Required

    Install the PostHog JavaScript library using your package manager:

    npm install posthog-js
    Nuxt version

    This guide is for Nuxt v3.0 and above. For Nuxt v2.16 and below, see our Nuxt docs.

  2. Add environment variables

    Required

    Add your PostHog project token and host to your nuxt.config.js file:

    nuxt.config.js
    export default defineNuxtConfig({
    runtimeConfig: {
    public: {
    posthogPublicKey: '<ph_project_token>',
    posthogHost: 'https://us.i.posthog.com',
    posthogDefaults: '2026-01-30'
    }
    }
    })
  3. Create a plugin

    Required

    Create a new plugin by creating a new file posthog.client.js in your plugins directory:

    plugins/posthog.client.js
    import { defineNuxtPlugin } from '#app'
    import posthog from 'posthog-js'
    export default defineNuxtPlugin(nuxtApp => {
    const runtimeConfig = useRuntimeConfig();
    const posthogClient = posthog.init(runtimeConfig.public.posthogPublicKey, {
    api_host: runtimeConfig.public.posthogHost,
    defaults: runtimeConfig.public.posthogDefaults,
    loaded: (posthog) => {
    if (import.meta.env.MODE === 'development') posthog.debug();
    }
    })
    return {
    provide: {
    posthog: () => posthogClient
    }
    }
    })
  4. Server-side setup

    Optional

    To capture events from server routes, install posthog-node and instantiate it directly. You can also use it to evaluate feature flags on the server:

    npm install posthog-node
    server/api/example.js
    import { PostHog } from 'posthog-node'
    export default defineEventHandler(async (event) => {
    const runtimeConfig = useRuntimeConfig()
    const posthog = new PostHog(
    runtimeConfig.public.posthogPublicKey,
    { host: runtimeConfig.public.posthogHost }
    )
    posthog.capture({
    distinctId: 'distinct_id_of_the_user',
    event: 'event_name'
    })
    await posthog.shutdown()
    })
  5. Send events

    Click around and view a couple pages to generate some events. PostHog automatically captures pageviews, clicks, and other interactions for you.

    If you'd like, you can also manually capture custom events:

    JavaScript
    posthog.capture('my_custom_event', { property: 'value' })
  6. Next steps

    Recommended

    After installing the PostHog SDK, you can create your first survey.

    ResourceDescription
    Creating surveysLearn how to build and customize your surveys
    Targeting surveysShow surveys to specific users based on properties, events, or feature flags
    How to create custom surveysBuild advanced survey experiences with custom code
    Framework guidesSetup guides for React, Next.js, Vue, and other frameworks
    More tutorialsOther real-world examples and use cases

    You should also identify users and capture events with PostHog to control who and when to show surveys to your users.

    Not all survey features are available on every SDK. See the SDK feature support matrix for a full comparison.

Community questions

Was this page useful?

Questions about this page? or post a community question.