Google Tag Manager Module for Nuxt.js

Google Tag Manager Module for Nuxt.js

@nuxtjs/gtm . Google Tag Manager Module for Nuxt.js


Google Tag Manager Module for Nuxt.js

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


  1. Add @nuxtjs/gtm dependency to your project
yarn add @nuxtjs/gtm # or npm install @nuxtjs/gtm
  1. Add @nuxtjs/gtm to the modules section of nuxt.config.js
export default {
  modules: [
  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: [

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

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



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

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

    pageTracking: false,
    pageViewEventName: 'nuxtRoute',

    autoInit: true,
    respectDoNotTrack: true,

    scriptId: 'gtm-script',
    scriptDefer: false,
    scriptURL: '',
    crossOrigin: false,

    noscript: true,
    noscriptId: 'gtm-noscript',
    noscriptURL: ''


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


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


export default {
 modules: [
 plugins: [


export default function({ $gtm, route }) {
  • 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.


Pushing events

You can push events into the configured layer:

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


  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.

Download Details:

Author: nuxt-community

Source Code:

nuxt nuxtjs javascript vue vuejs

Bootstrap 5 Complete Course with Examples

Bootstrap 5 Tutorial - Bootstrap 5 Crash Course for Beginners

Nest.JS Tutorial for Beginners

Hello Vue 3: A First Look at Vue 3 and the Composition API

Building a simple Applications with Vue 3

Deno Crash Course: Explore Deno and Create a full REST API with Deno

How to Build a Real-time Chat App with Deno and WebSockets

Convert HTML to Markdown Online

HTML entity encoder decoder Online

8 Popular Websites That Use The Vue.JS Framework

In this article, we are going to list out the most popular websites using Vue JS as their frontend framework. Vue JS is one of those elite progressive JavaScript frameworks that has huge demand in the web development industry. Many popular websites are developed using Vue in their frontend development because of its imperative features.

How to add Authentication to Nuxt.JS and Vue.JS

This Vue.JS Tutorial shows how to add Authentication and Authorization to your NuxtJS App and make it work with SSR

Snippets And Boiler Plates Built With Nuxtjs And Nuxt/content

Documentation with snippets and boiler plates, built with NuxtJS and nuxt/content. Markdown ❤️ for ever.

How to build enterprise Vue.js applications with Nuxt?

Learn How to build enterprise Vue.js applications with Nuxt: Nuxt is a progressive framework based on Vue.js to create modern web applications. It is based on Vue.js official libraries (vue, vue-router and vuex) and powerful development tools (webpack, Babel and PostCSS). Nuxt goal is to make web development powerful and performant with a great developer experience in mind.

Modern JavaScript date utility library - date-fns for Nuxt.js

date-fns-module Modern JavaScript date utility library - date-fns for Nuxt.js