
Company News
Socket raises $60M Series C at a $1B valuation to secure software supply chains for AI-driven development
Socket is scaling to defend open source against supply chain attacks as AI accelerates software development.
nuxtjs-gtm-module
Advanced tools
Google Tag Manager Module for Nuxt.js
ℹ️ If coming from v1 (@nuxtjs/google-tag-manager) please read v2 release notes.
nuxtjs-gtm-module dependency to your projectyarn add nuxtjs-gtm-module # or npm install nuxtjs-gtm-module
nuxtjs-gtm-module to the modules section of nuxt.config.jsexport default {
modules: [
'nuxtjs-gtm-module',
],
gtm: {
id: 'GTM-XXXXXXX'
}
}
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
}
},
}
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'
}
}
enabledGTM 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
}
}
debugWhether $gtm API calls like init and push are logged to the console.
There are several use cases that you may need more control over initialization:
nuxt.config.js:
export default {
modules: [
'nuxtjs-gtm-module'
],
plugins: [
'~/plugins/gtm'
]
}
plugins/gtm.js:
export default function({ $gtm, route }) {
$gtm.init('GTM-XXXXXXX')
}
init() method getting called.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.
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
You can push events into the configured layer:
this.$gtm.push({ event: 'myEvent', ...someAttributes })
yarn install or npm installyarn dev or GTM_ID=<your gtm id> yarn dev if you want to provide custom GTM_ID.Tests require a valid GTM container ID to be set as an environment variable:
GTM_ID=<your gtm id> npm test
Copyright (c) Nuxt.js Community
FAQs
Google Tag Manager Module for Nuxt.js
We found that nuxtjs-gtm-module demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Company News
Socket is scaling to defend open source against supply chain attacks as AI accelerates software development.

Research
/Security News
A long-running Go typosquat impersonated the popular shopspring/decimal library and used DNS TXT records to execute commands.

Research
Active npm supply chain attack compromises @antv packages in a fast-moving malicious publish wave tied to Mini Shai-Hulud.