PostHog makes it easy to get data about usage of your Vue.js app. Integrating PostHog into your app enables analytics about user behavior, custom events capture, session replays, feature flags, and more.
This guide walks you through integrating PostHog into your app for both Vue.js major versions 2 and 3. We'll use the JavaScript SDK. 
For integrating PostHog into a Nuxt.js app, see our Nuxt guide.
Prerequisites
To follow this guide along, you need:
- a PostHog account (either Cloud or self-hosted)
- a running Vue.js application
Setting up PostHog
- Install posthog-js using your package manager:
Initializing PostHog
We will cover three different methods for initializing PostHog:
Choose what is best for you, considering your Vue version and your codebase’s stylistic choices.
Method 1: Create a Plugin
Note: For both Vue 3.x and Vue 2.x users
First, create a new file posthog.js in your plugins directory.
Next, create a plugin and assign PostHog to Vue’s global properties. The code will differ depending on your version of Vue.
Vue 3.x:
Vue 2.x:
Finally, activate your plugin in the file where you initialize your app. For Vue 3.x, it will likely be your index.js file. For Vue 2.x, it will be your main.js file.
Vue 3.x:
Vue 2.x:
You can now use PostHog throughout your Vue app using this.$posthog. For example:
Method 2: Use provide / inject
Note: For Vue 3.x users only
With Vue 3.x, developers can use provide() and inject() to pipe global values into any component without prop drilling. And if you don’t know what prop drilling is, good for you.
While this method is more declarative — as you need to inject PostHog into every component — it avoids “polluting” globals (like method 1 does). Some engineers prefer this approach, while others include PostHog in globals since it doesn’t need to be reactive and will be called throughout your application.
Step 1: Initialize Vue
Prior to mounting the app, you must:
- Import PostHog
- Initialize it
- Provide it to your app.
This must be done before you mount my app. If I provide PostHog after mounting it, PostHog will not be predictably available.
Step 2: Inject into any Vue file
Method 3: Use Vue.prototype
Note: For Vue 2.x users only
While Vue 3.x dramatically clamped down on global variables, in Vue 2.x, you can initialize PostHog by using Object.defineProperty and Vue.prototype. 
Anywhere, declare:
Then, access PostHog by calling this.$posthog. 
Method 4: Use the Composition API
Create a new folder composables in your project. In that folder, create a new file usePosthog.js with the following initialization code:
In App.vue, call usePostHogProvider() to initialize PostHog.
You can then use usePostHog() to access PostHog in any component.
Capturing pageviews
You might notice that moving between pages only captures a single pageview event. This is because PostHog only captures pageview events when a page load is fired. Since Vue creates a single-page app, this only happens once, and the Vue router handles subsequent page changes.
If we want to capture every route change, we must write code to capture pageviews that integrates with the router.
First, make sure to set capture_pageview in the PostHog initialization config to false. This turns off autocaptured pageviews and ensures you won’t double-capture pageviews on the first load.
Vue 3.x:
In main.js, set up PostHog to capture pageviews in the router.afterEach function. Additionally, you can use nextTick so that the capture event fires only after the page is mounted.
Vue 2.x:
Capturing pageleaves
Similar to pageviews, you need to manually capture pageleaves in a Vue single-page app.
This starts by setting capture_pageleave to false in the PostHog initialization config to ensure you don’t double-capture pageleaves. 
Vue 3.x:
You can then use the same router.afterEach hook to capture pageleaves. The difference is that you need to manually set the $current_url and path properties using the from object.
Capturing events
Here’s a simple example of using PostHog to capture a barebones login button.
You can the access the project used in this tutorial on GitHub.
Next steps
For any technical questions for how to integrate specific PostHog features into Vue (such as analytics, feature flags, A/B testing, surveys, etc.), have a look at our JavaScript Web SDK docs.
Alternatively, the following tutorials can help you get started: