next.js - GTM 不会在页面导航上重置 dataLayer
问题描述
我正在尝试将 GTM 集成到我的单页 NextJS 应用程序中。我按照建议将我的脚本注入到 _document.js 中:
export default class MyDocument extends Document {
render() {
return (
<Html>
<Head>
<script
dangerouslySetInnerHTML={{
__html: `window.dataLayer = window.dataLayer || [];`
}} />
<script
dangerouslySetInnerHTML={{
__html: `(function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start':
new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0],
j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=true;j.src=
' https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f);
})(window,document,'script','dataLayer','${getGtmTrackingId()}');`,
}} />
</Head>
<body>
<noscript
dangerouslySetInnerHTML={{
__html: `<iframe src="https://www.googletagmanager.com/ns.html?id=${getGtmTrackingId()}" height="0" width="0" style="display:none;visibility:hidden"></iframe>`,
}}
/>
<Main />
</body>
</Html>
我的问题是:每次我浏览页面时,我都会看到 dataLayer 仍然包含在前几页上触发的事件。我需要在每次 url 更改时重置我的 dataLayer 吗?如果我没有在 url 更改时重置我的 dataLayer 或者是否可以包含所有触发的事件,我是否会达到 GTM 的限制?
我尝试像这样重置 dataLayer,但如果我这样做,gtm 会停止发送事件。
在我的 _app.js 文件中:
useEffect(() => {
router.events.on('routeChangeStart',() => {window.dataLayer = []});
}, [router.events]);
谢谢。
解决方案
在推送页面查看事件之前尝试一下:
window.dataLayer.push(() => {
window.google_tag_manager["your_container_id"].dataLayer.reset()
})
推荐阅读
- java - 为什么套接字 connect() 方法超时?netcat (nc) 工作正常
- python - 使用 SMTP 发送邮件时,它会破坏 utf-8 字符
- javascript - 带有对象属性的 Vue 计算设置器
- amazon-web-services - 在 AWS Landing zone seup 中设置个人开发者账户
- python - 比较两张电子名片
- javascript - 我的完整日历只列出了我在 for 循环中拥有的 3 个事件中的 1 个?
- twitter - 如何将另一个人添加到 twitter api?
- javascript - 在自己的代码块中调用外部函数的说明
- javascript - 即使在 api 调用中使用 Promise 也未定义
- docker - Docker 上的 Worker Tiemout Upstream Gunicorn (Bad Gateway 502)