How to Add Google Analytics to the Next.js App?

14 minutes read

To add Google Analytics to your Next.js app, you can follow these steps:

  1. Sign up for a Google Analytics account: Go to the Google Analytics website (www.google.com/analytics) and sign up using your Google account. Create a new property for your Next.js app.
  2. Obtain the tracking ID: Once your property is created, you will be provided with a tracking ID. It looks like "UA-XXXXXXXX-X". Keep this ID handy, as you will need it in the following steps.
  3. Install the required package: In your Next.js project directory, open a terminal and run the following command to install the react-ga package: npm install react-ga
  4. Create a separate file for the Google Analytics setup: Inside your Next.js project, create a new file (e.g., ga.js) in the lib directory. This file will contain the code to set up Google Analytics.
  5. Import and configure react-ga: In the ga.js file, import the react-ga package and configure it by adding the following code: import ReactGA from 'react-ga'; export const initGA = () => { ReactGA.initialize('UA-XXXXXXXX-X'); // Replace with your tracking ID }; export const logPageView = () => { ReactGA.set({ page: window.location.pathname }); ReactGA.pageview(window.location.pathname); };
  6. Initialize Google Analytics: In your Next.js app, open the main file (usually pages/_app.js) and add the following code to initialize Google Analytics: import { useEffect } from 'react'; import { initGA, logPageView } from '../lib/ga'; const MyApp = ({ Component, pageProps }) => { useEffect(() => { if (!window.GA_INITIALIZED) { initGA(); window.GA_INITIALIZED = true; } logPageView(); }, []); return ; }; export default MyApp;
  7. Verify the implementation: Now, when you run your Next.js app, Google Analytics should be tracking page views and sending data to your Analytics account. You can verify this by visiting the Google Analytics website and checking the real-time reports or waiting for some time to see the collected data.


Remember to replace the UA-XXXXXXXX-X with your actual tracking ID obtained from Google Analytics.

Best Google Analytics Books to Read in 2025

1
Learning Google Analytics: Creating Business Impact and Driving Insights

Rating is 5 out of 5

Learning Google Analytics: Creating Business Impact and Driving Insights

2
Google Analytics Demystified (4th Edition)

Rating is 4.9 out of 5

Google Analytics Demystified (4th Edition)

3
Google Analytics: Understanding Visitor Behavior

Rating is 4.8 out of 5

Google Analytics: Understanding Visitor Behavior

4
Google Analytics Uncovered: How to Set Up and Maximize Ecommerce Data in Google Analytics

Rating is 4.7 out of 5

Google Analytics Uncovered: How to Set Up and Maximize Ecommerce Data in Google Analytics

5
Google Analytics Alternatives: A Guide to Navigating the World of Options Beyond Google

Rating is 4.6 out of 5

Google Analytics Alternatives: A Guide to Navigating the World of Options Beyond Google

6
Data Engineering with Google Cloud Platform: A practical guide to operationalizing scalable data analytics systems on GCP

Rating is 4.5 out of 5

Data Engineering with Google Cloud Platform: A practical guide to operationalizing scalable data analytics systems on GCP

7
The Google Analytics 4 and Google Tag Manager Cookbook: A Simple Step by Step Pictorial Guide to Implementing Google Analytics and Google Tag Manager for your Websites.

Rating is 4.4 out of 5

The Google Analytics 4 and Google Tag Manager Cookbook: A Simple Step by Step Pictorial Guide to Implementing Google Analytics and Google Tag Manager for your Websites.

8
Google Analytics Breakthrough: From Zero to Business Impact

Rating is 4.3 out of 5

Google Analytics Breakthrough: From Zero to Business Impact


How to track file downloads with Google Analytics in Next.js?

To track file downloads with Google Analytics in Next.js, you can follow these steps:

  1. Install the 'react-ga' package by running the following command in your Next.js project directory: npm install react-ga
  2. In your Next.js project, create a new file called 'analytics.js' in the 'utils' folder (if not already created).
  3. In the 'analytics.js' file, import the 'react-ga' module and configure it with your Google Analytics tracking ID. Replace 'UA-XXXXXXXXX-X' with your actual tracking ID. import ReactGA from 'react-ga'; export const initGA = () => { ReactGA.initialize('UA-XXXXXXXXX-X'); }; export const logPageView = () => { ReactGA.set({ page: window.location.pathname }); ReactGA.pageview(window.location.pathname); };
  4. In your Next.js project, open the '_app.js' file located in the 'pages' folder.
  5. Import the 'useEffect' hook and the 'initGA' and 'logPageView' functions from the 'analytics.js' file. Add the following code at the top of the '_app.js' file: import { useEffect } from 'react'; import { initGA, logPageView } from '../utils/analytics'; const MyApp = ({ Component, pageProps }) => { useEffect(() => { if (!window.GA_INITIALIZED) { initGA(); window.GA_INITIALIZED = true; } logPageView(); }, []); return ; }; export default MyApp;
  6. In the component where you want to track file downloads, import the 'react-ga' module. Add an onClick event handler to the file download link, and call the 'event' function from 'react-ga' with the appropriate category, action, and file name. import ReactGA from 'react-ga'; const TrackFileDownload = () => { const handleDownload = (filename) => { ReactGA.event({ category: 'File Download', action: 'Download', label: filename, }); }; return ( handleDownload('file.pdf')}> Download File ); }; export default TrackFileDownload;


By implementing these steps, you will be able to track file downloads with Google Analytics in your Next.js application.


What is the purpose of adding Google Analytics to a Next.js app?

The purpose of adding Google Analytics to a Next.js app is to collect and analyze data about user behavior and interactions. It helps you gain insights into how users are finding and using your app, which pages are the most popular, how long users stay on a particular page, and other key metrics. This data can be utilized to make informed decisions for improving user experience, optimizing marketing strategies, and identifying areas of improvement in the app. Overall, Google Analytics provides valuable information to aid in the growth and success of your Next.js app.


How to set up funnel visualization in Google Analytics for a Next.js app?

To set up funnel visualization in Google Analytics for a Next.js app, you need to follow these steps:

  1. Sign in to your Google Analytics account and create a new property for your Next.js app.
  2. Install the react-ga package in your Next.js app. This package allows you to integrate Google Analytics with your app. npm install react-ga
  3. Import and initialize react-ga in your Next.js app. You can do this in your _app.js file, which acts as the entry point for your app. import ReactGA from 'react-ga'; const trackingId = 'YOUR_TRACKING_ID'; // Replace with your Google Analytics tracking ID ReactGA.initialize(trackingId);
  4. Create a custom function to track page views in your app. Next.js provides the router object that allows you to track page changes. import { useEffect } from 'react'; import { useRouter } from 'next/router'; import ReactGA from 'react-ga'; function usePageViews() { const router = useRouter(); useEffect(() => { const handleRouteChange = (url) => { ReactGA.set({ page: url }); ReactGA.pageview(url); }; router.events.on('routeChangeComplete', handleRouteChange); return () => { router.events.off('routeChangeComplete', handleRouteChange); }; }, [router.events]); } export default function App({ Component, pageProps }) { usePageViews(); return ; }
  5. Next, you can set up the funnel visualization in Google Analytics. Go to your Google Analytics property and navigate to the "Admin" tab.
  6. In the "View" column, click on "Goals".
  7. Click on the "+ New Goal" button to create a new goal.
  8. Choose "Custom" and click on "Continue".
  9. Fill in the name and choose the destination option.
  10. Enter the funnel steps by providing the required information, such as the page URL or title for each step.
  11. Once you've set up your funnel, you can navigate to the "Conversions" > "Goals" > "Funnel Visualization" section in Google Analytics to view the funnel visualization for your Next.js app.


Remember to replace YOUR_TRACKING_ID with your actual Google Analytics tracking ID in step 3.


Note: Funnel visualization may take some time to populate, so make sure you have some user data before expecting results.


How to set up custom dimensions in Google Analytics for a Next.js app?

To set up custom dimensions in Google Analytics for a Next.js app, you can follow these steps:

  1. Sign in to your Google Analytics account and select the property for your Next.js app.
  2. Click on the "Admin" tab in the bottom left corner.
  3. Under the "Property" column, click on "Custom Definitions" and then select "Custom Dimensions".
  4. Click on the "+ New Custom Dimension" button.
  5. Provide a name for your custom dimension and select the scope (i.e., Hit, Session, or User) based on your requirements. Hit scope applies to a single pageview, session scope applies to the entire user session, and user scope applies to the lifetime of the user.
  6. Save your changes.
  7. In your Next.js app, install the "react-ga" package using npm or yarn:
1
npm install react-ga


or

1
yarn add react-ga


  1. Import the "react-ga" package and initialize it with your Google Analytics tracking ID in the "_app.js" file of your Next.js app:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
// _app.js
import ReactGA from 'react-ga';

function MyApp({ Component, pageProps }) {
  // Initialize Google Analytics
  ReactGA.initialize('YOUR_TRACKING_ID');

  return <Component {...pageProps} />;
}

export default MyApp;


Replace 'YOUR_TRACKING_ID' with your actual Google Analytics tracking ID.

  1. To send custom dimension data to Google Analytics, import the "react-ga" package and use the set method with the custom dimension index and value in the desired component or page of your Next.js app:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
import ReactGA from 'react-ga';

function MyComponent() {
  // Set custom dimension value
  ReactGA.set({
    dimension1: 'CUSTOM_VALUE'
  });

  // Rest of the component code

  return (
    // JSX for the component
  );
}

export default MyComponent;


Replace 'CUSTOM_VALUE' with the actual value you want to send for the custom dimension.

  1. Save your changes and deploy your Next.js app.


The custom dimension data will now be sent to Google Analytics, where you can view and analyze it in the "Custom Dimensions" report.


How to exclude certain pages from being tracked by Google Analytics in Next.js?

To exclude certain pages from being tracked by Google Analytics in Next.js, you can follow these steps:

  1. Install the react-ga library by running the following command in your terminal: npm install react-ga
  2. Create a new file (e.g., analytics.js) in the utils directory of your Next.js project.
  3. In analytics.js, import the react-ga library: import ReactGA from 'react-ga';
  4. Initialize Google Analytics using your tracking ID in analytics.js. This should be the same tracking ID used in the _document.js file or wherever you have implemented Google Analytics tracking: export const initGA = () => { ReactGA.initialize('YOUR_TRACKING_ID'); };
  5. Create a function to track page views in analytics.js: export const logPageView = () => { ReactGA.set({ page: window.location.pathname }); ReactGA.pageview(window.location.pathname); };
  6. Create a function to include or exclude specific page paths from being tracked. For example, if you want to exclude "/path/to/exclude" from being tracked, you can modify the logPageView function: export const logPageView = () => { // Exclude specific page path if (window.location.pathname !== '/path/to/exclude') { ReactGA.set({ page: window.location.pathname }); ReactGA.pageview(window.location.pathname); } };
  7. In your pages/_app.js file, import the analytics.js file and use useEffect to initialize Google Analytics and track page views: import { useEffect } from 'react'; import { initGA, logPageView } from '../utils/analytics'; const MyApp = ({ Component, pageProps }) => { useEffect(() => { // Initialize Google Analytics initGA(); // Track page views logPageView(); }, []); return ; }; export default MyApp;


That's it! With these steps, you can exclude certain pages from being tracked by Google Analytics in your Next.js application.


How to obtain a Google Analytics tracking ID?

To obtain a Google Analytics tracking ID, follow these steps:

  1. Visit the Google Analytics website at https://analytics.google.com/.
  2. Sign in to your Google account or create a new one if you don't have one already.
  3. Click on "Start measuring" to create a new Google Analytics account.
  4. Fill in the relevant information such as account name, website name, website URL, industry category, and time zone.
  5. Under the "Data sharing settings" section, choose your preferences and enable or disable data sharing options as desired.
  6. Read and accept the terms of service by checking the box.
  7. Click on the "Create" button.


Once you have created your Google Analytics account, you will be redirected to a page that contains your tracking ID. The tracking ID starts with "UA-". Make note of this tracking ID as you will need it to implement Google Analytics tracking on your website.

Facebook Twitter LinkedIn Telegram Pocket

Related Posts:

Google Analytics is a powerful tool that allows you to track and measure the performance of your Facebook Ads campaigns. By integrating Google Analytics with your Facebook Ads account, you can get valuable insights into the behavior of your audience and make d...
To use Google Analytics for Instagram, you need to follow a few steps. Firstly, create a Google Analytics account and set up a new property for your Instagram account. Obtain the tracking ID provided by Google Analytics.Next, go to your Instagram account and n...
To track user journeys in Google Analytics, you can follow these steps:Set up Google Analytics on your website: First, you need to have Google Analytics set up on your website. Sign in to your Google Analytics account, create a new property, and get the tracki...