How to Add Google Analytics to Next.js?

12 minutes read

To add Google Analytics to a Next.js application, you need to follow these steps:

  1. Set up a Google Analytics account: Go to the Google Analytics website, sign in with your Google account, and set up a new property for your Next.js application. Note down the tracking ID that Google provides.
  2. Install the required packages: In your Next.js project, open the terminal and run the following command to install two necessary packages: npm install react-ga next-ga
  3. Create a utility file: In your Next.js project, create a new file (e.g., utils/analytics.js) and add the following code: import ReactGA from 'react-ga'; export const initGA = () => { ReactGA.initialize('YOUR_TRACKING_ID'); }; export const logPageView = () => { ReactGA.set({ page: window.location.pathname }); ReactGA.pageview(window.location.pathname); }; Replace 'YOUR_TRACKING_ID' with the tracking ID you obtained from Google Analytics.
  4. Import and use the utility in the _app.js file: Open the _app.js file in your Next.js project and add the following code: import { useEffect } from 'react'; import { initGA, logPageView } from '../utils/analytics'; const MyApp = ({ Component, pageProps }) => { useEffect(() => { initGA(); logPageView(); }, []); return ; }; export default MyApp;
  5. Configure Next.js to load the utility on every page: In your Next.js project, create a new file next.config.js (if not already present) and add the following code: module.exports = { webpack: (config, { isServer }) => { if (!isServer) { config.node = { fs: 'empty', }; } return config; }, }; This ensures that the utility can be properly used on the client-side.
  6. Implement event tracking (optional): To track events like button clicks, form submissions, or other user interactions, modify the utils/analytics.js file to include appropriate functions (e.g., logEvent). Then, call those functions wherever you want to track such events in your Next.js components.


That's it! By following these steps, you can add Google Analytics tracking to your Next.js application and gather valuable insights about your users' activities.

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
A Car Dealer’s Guide to Google Analytics 4 - Second Edition: Learn how to setup, build events, conversions and reports in Google Analytics 4

Rating is 4.9 out of 5

A Car Dealer’s Guide to Google Analytics 4 - Second Edition: Learn how to setup, build events, conversions and reports in Google Analytics 4

3
Google Analytics Breakthrough: From Zero to Business Impact

Rating is 4.8 out of 5

Google Analytics Breakthrough: From Zero to Business Impact

4
Practical Google Analytics and Google Tag Manager for Developers

Rating is 4.7 out of 5

Practical Google Analytics and Google Tag Manager for Developers

5
Google Analytics Demystified (4th Edition)

Rating is 4.6 out of 5

Google Analytics Demystified (4th Edition)

6
Google Analytics: Understanding Visitor Behavior

Rating is 4.5 out of 5

Google Analytics: Understanding Visitor Behavior

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

Rating is 4.4 out of 5

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


Is it difficult to add Google Analytics to Next.js?

Adding Google Analytics to Next.js can be relatively easy. Next.js provides a way to have dynamic imports of external JavaScript libraries in its Head component. This can be used to load the Google Analytics script dynamically and add the necessary tracking code to your Next.js application.


Below is an example of how to add Google Analytics to a Next.js application:

  1. Install react-ga package by running the following command:
1
npm install react-ga


  1. Create a new file called analytics.js in the lib directory (you may need to create this directory):
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
// lib/analytics.js

import ReactGA from 'react-ga';

export const initGA = () => {
  ReactGA.initialize('UA-XXXXXXXX-X'); // Replace with your own tracking ID
};

export const logPageView = () => {
  ReactGA.set({ page: window.location.pathname });
  ReactGA.pageview(window.location.pathname);
};


  1. Modify the _document.js file in your Next.js application's pages directory:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
// pages/_document.js

import Document, { Html, Head, Main, NextScript } from 'next/document';
import { initGA, logPageView } from '../lib/analytics';

class MyDocument extends Document {
  componentDidMount() {
    initGA();
    logPageView();
  }

  render() {
    return (
      <Html>
        <Head>
          {/* Add your own Head contents here */}
          <script
            async
            src="https://www.google-analytics.com/analytics.js"
          />
        </Head>
        <body>
          <Main />
          <NextScript />
        </body>
      </Html>
    );
  }
}

export default MyDocument;


  1. The setup is now complete. Google Analytics will now track page views on your Next.js application.


Note: Remember to replace 'UA-XXXXXXXX-X' with your own Google Analytics tracking ID.


Adding additional tracking events or customizing Google Analytics can be done by importing and using the ReactGA object from the analytics.js file in your components as needed.


Overall, integrating Google Analytics into Next.js is not difficult and can be achieved by following the steps above.


How can I verify if Google Analytics is properly added to my Next.js website?

To verify if Google Analytics is properly added to your Next.js website, you can follow these steps:

  1. Go to your website in a web browser and open the developer tools. You can do this by right-clicking anywhere on the page and selecting "Inspect" or "Inspect Element".
  2. In the developer tools panel, navigate to the "Network" tab.
  3. Refresh the page to trigger any network requests.
  4. Look for a request with the name "collect" or "analytics.js" or "ga.js". These requests indicate that Google Analytics is sending data to the Google servers.
  5. If you find any of these requests, it means that Google Analytics is properly added and tracking data from your website.


Alternatively, you can also check the source code of your website to verify if the Google Analytics tracking code is present.

  1. Open the source code of your website. You can do this by right-clicking anywhere on the page and selecting "View Page Source" or by using the developer tools.
  2. Search for "UA-" followed by a string of numbers. This is the tracking ID used by Google Analytics.
  3. If you find this tracking ID in the source code, it means that Google Analytics is properly added to your Next.js website.


By following these steps, you can verify if Google Analytics is successfully integrated into your Next.js website.


Can I use Google Analytics to track user engagement on specific components in Next.js?

Yes, you can use Google Analytics to track user engagement on specific components in Next.js.


To implement this, you would typically use custom events or virtual pageviews to track user interactions on specific components.


For example, if you have a component for a button, you can use the Google Analytics event tracking feature to track when users click on that button. You would need to add a tracking event code to the button's onClick handler.


Here's an example code snippet to give you an idea:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import { useEffect } from 'react';
import { useRouter } from 'next/router';

const MyButtonComponent = () => {
  const router = useRouter();

  const handleButtonClick = () => {
    // Track the button click event
    window.gtag('event', 'button_click', {
      event_category: 'engagement',
      event_label: 'My Button Component',
    });

    // Redirect to another page
    router.push('/another-page');
  };

  useEffect(() => {
    // Load the Google Analytics script
    window.dataLayer = window.dataLayer || [];
    function gtag() {
      dataLayer.push(arguments);
    }
    gtag('js', new Date());
    gtag('config', 'YOUR_ANALYTICS_TRACKING_ID');
  }, []);

  return (
    <button onClick={handleButtonClick}>
      My Button
    </button>
  );
};

export default MyButtonComponent;


Remember to replace 'YOUR_ANALYTICS_TRACKING_ID' with your actual Google Analytics tracking ID.


With this implementation, you will be able to track the user engagement on the specific component and view these events in your Google Analytics dashboard.


How can I troubleshoot common issues when adding Google Analytics to Next.js?

When troubleshooting common issues when adding Google Analytics to Next.js, you can follow these steps:

  1. Verify the tracking code: Double-check if you have added the correct tracking code provided by Google Analytics. Ensure that it is placed inside the component in your Next.js project.
  2. Check for proper installation: Ensure that you have correctly installed the necessary packages for Google Analytics integration in your Next.js project. Typically, this involves installing packages like "react-ga" or "@react-google-analytics/ga".
  3. Review Next.js lifecycle events: Next.js follows a specific lifecycle, and you need to set up the Google Analytics tracking correctly to account for all these events. Make sure you have implemented the tracking code accordingly within the appropriate Next.js lifecycle methods, such as componentDidMount or useEffect hooks.
  4. Debug your code and console output: Utilize the browser's Developer Tools and the console to check for any errors or warnings related to the integration. Look for any specific error messages or unexpected behavior that might help identify the issue.
  5. Test in a development environment: If you are encountering issues, try running your Next.js project in a development environment and see if Google Analytics is functioning as expected. You can use the "debug" mode of Google Analytics to view the events being sent.
  6. Monitor Network requests: Check the Network tab in the browser's Developer Tools to see if the Google Analytics request is being sent correctly. Look for any potential errors or issues related to those requests.
  7. Explore community resources: Next.js has a large and active community. Search for similar issues faced by others and explore community forums, GitHub repositories, or Stack Overflow threads to find potential solutions.
  8. Consult official documentation and examples: Review the official documentation of the Google Analytics integration package you are using. Look for examples or guides specifically catering to Next.js to ensure you are following the correct implementation steps.
  9. Reach out for help: If all else fails, don't hesitate to seek help from the developer community. You can post your question on relevant forums, ask in specific online groups, or reach out to experienced developers who might have encountered similar issues before.


By following these troubleshooting steps, you should be able to identify and resolve common issues when adding Google Analytics to your Next.js application.


Are there any Next.js-specific plugins available for Google Analytics integration?

Yes, there are Next.js-specific plugins available for Google Analytics integration. One popular plugin is "next-optimized-google-analytics," which provides a simple integration with Google Analytics in Next.js applications. Other plugins like "nextjs-google-analytics" and "next-ga" also provide similar functionality and can be easily integrated into a Next.js project for Google Analytics tracking.

Facebook Twitter LinkedIn Whatsapp Pocket

Related Posts:

To integrate Google Analytics with an Electron app, you will first need to create a Google Analytics account and obtain a tracking ID. You can then use the &#39;electron-google-analytics&#39; npm package to implement Google Analytics tracking in your Electron ...
Google Analytics is a powerful tool that allows website owners to track and analyze various aspects of their website&#39;s traffic. Here is an overview of how to use Google Analytics to track website traffic:Sign up for Google Analytics: Start by creating an a...
To track a button click in Google Analytics, you need to set up an event tracking. Here is a step-by-step guide to do it:Set up Google Analytics: First, ensure that you have set up a Google Analytics account for your website. Go to the Google Analytics website...
To connect Google Tag Manager to Google Analytics 4, you need to first create a Google Analytics 4 property in your Google Analytics account. Once you have created the property, you will need to obtain the Measurement ID for that property.Next, in your Google ...
Tracking redirects in Google Analytics allows you to monitor how visitors are navigating through your website. Here&#39;s how you can track redirects using Google Analytics:Set up Google Analytics: First, create a Google Analytics account if you haven&#39;t al...
To include Google Analytics in a Preact application, you can use the react-ga library to easily integrate Google Analytics tracking. First, install the react-ga library by running npm install react-ga in your project directory. Next, create a new file for your...