Google Tag Manager Module for Nuxt.js
  • JavaScript 99.1%
  • Vue 0.9%
Find a file
2025-08-26 20:31:35 +01:00
.github/workflows migrate from yarn to pnpm; bump dependencies, fix eslint and tests 2025-08-26 17:25:24 +01:00
example rename to nuxtjs-gtm-module 2025-08-26 19:50:19 +01:00
lib merge: mraichelson:feature/rogue-referral 2025-08-26 17:39:35 +01:00
test rename to nuxtjs-gtm-module 2025-08-26 19:50:19 +01:00
.editorconfig feat: initial commit for v2 2020-02-09 16:19:04 +01:00
.eslintignore migrate from yarn to pnpm; bump dependencies, fix eslint and tests 2025-08-26 17:25:24 +01:00
.eslintrc.js migrate from yarn to pnpm; bump dependencies, fix eslint and tests 2025-08-26 17:25:24 +01:00
.gitignore feat: initial commit for v2 2020-02-09 16:19:04 +01:00
.npmrc migrate from yarn to pnpm; bump dependencies, fix eslint and tests 2025-08-26 17:25:24 +01:00
babel.config.js feat: initial commit for v2 2020-02-09 16:19:04 +01:00
CHANGELOG.md merge: mraichelson:feature/rogue-referral 2025-08-26 17:39:35 +01:00
jest.config.js migrate from yarn to pnpm; bump dependencies, fix eslint and tests 2025-08-26 17:25:24 +01:00
jest.setup.js migrate from yarn to pnpm; bump dependencies, fix eslint and tests 2025-08-26 17:25:24 +01:00
LICENSE feat: initial commit for v2 2020-02-09 16:19:04 +01:00
package.json rename to nuxtjs-gtm-module 2025-08-26 19:50:19 +01:00
pnpm-lock.yaml migrate from yarn to pnpm; bump dependencies, fix eslint and tests 2025-08-26 17:25:24 +01:00
README.md update readme to refer to the new name 2025-08-26 20:31:35 +01:00
renovate.json feat: initial commit for v2 2020-02-09 16:19:04 +01:00

nuxtjs-gtm-module

npm version npm downloads Checks Codecov License

Google Tag Manager Module for Nuxt.js

📖 Release Notes

If coming from v1 (@nuxtjs/google-tag-manager) please read v2 release notes.

Setup

  1. Add nuxtjs-gtm-module dependency to your project
yarn add nuxtjs-gtm-module # or npm install nuxtjs-gtm-module
  1. Add nuxtjs-gtm-module to the modules section of nuxt.config.js
export default {
  modules: [
    'nuxtjs-gtm-module',
  ],
  gtm: {
    id: 'GTM-XXXXXXX'
  }
}

Runtime Config

You can use runtime config if need to use dynamic environment variables in production. Otherwise, the options will be hardcoded during the build and won't be read from nuxt.config anymore.

export default {
  modules: [
    'nuxtjs-gtm-module'
  ],

  gtm: {
    id: 'GTM-XXXXXXX', // Used as fallback if no runtime config is provided
  },

  publicRuntimeConfig: {
    gtm: {
      id: process.env.GOOGLE_TAG_MANAGER_ID
    }
  },
}

Options

Defaults:

export default {
  gtm: {
    enabled: undefined, /* see below */
    debug: false,

    id: undefined,
    layer: 'dataLayer',
    variables: {},

    pageTracking: false,
    pageViewEventName: 'nuxtRoute',
    pushOriginalLocation: false,

    autoInit: true,
    respectDoNotTrack: true,

    scriptId: 'gtm-script',
    scriptDefer: false,
    scriptURL: 'https://www.googletagmanager.com/gtm.js',
    crossOrigin: false,

    noscript: true,
    noscriptId: 'gtm-noscript',
    noscriptURL: 'https://www.googletagmanager.com/ns.html'
  }
}

enabled

GTM module uses a debug-only version of $gtm during development (nuxt dev).

You can explicitly enable or disable it using enabled option:

export default {
  gtm: {
    // Always send real GTM events (also when using `nuxt dev`)
    enabled: true
  }
}

debug

Whether $gtm API calls like init and push are logged to the console.

Manual GTM Initialization

There are several use cases that you may need more control over initialization:

  • Block Google Tag Manager before user directly allows (GDPR realisation or other)
  • Dynamic ID based on request path or domain
  • Initialize with multi containers
  • Enable GTM on page level

nuxt.config.js:

export default {
 modules: [
  'nuxtjs-gtm-module'
 ],
 plugins: [
  '~/plugins/gtm'
 ]
}

plugins/gtm.js:

export default function({ $gtm, route }) {
  $gtm.init('GTM-XXXXXXX')
}
  • Note: All events will be still buffered in data layer but won't send until init() method getting called.
  • Note: Please consult with Google Tag Manager Docs for more information caveats using multiple containers.

Router Integration

You can optionally set pageTracking option to true to track page views.

Note: This is disabled by default to prevent double events when using alongside with Google Analytics so take care before enabling this option.

The default event name for page views is nuxtRoute, you can change it by setting the pageViewEventName option.

Original Location Tracking

You can optionally set pushOriginalLocation option to true to include the original page location (referrer) in page tracking events. This can help address "Rogue Referral" issues when tracking paid traffic.

export default {
  gtm: {
    pageTracking: true,
    pushOriginalLocation: true
  }
}

When enabled, page view events will include an originalLocation field containing document.referrer (when available).

Source feat: Add option to address "Rogue Referral" issue when tracking paid traffic via GTM+GA

Usage

Pushing events

You can push events into the configured layer:

this.$gtm.push({ event: 'myEvent', ...someAttributes })

Development

  1. Clone this repository
  2. Install dependencies using yarn install or npm install
  3. Start development server using yarn dev or GTM_ID=<your gtm id> yarn dev if you want to provide custom GTM_ID.

Testing

Tests require a valid GTM container ID to be set as an environment variable:

GTM_ID=<your gtm id> npm test

License

MIT License

Copyright (c) Nuxt.js Community