gpt4 book ai didi

javascript - angular 和 google analytics 集成 => ga 不是函数

转载 作者:数据小太阳 更新时间:2023-10-29 05:05:10 25 4
gpt4 key购买 nike

我正在做一个 angular(4) 应用程序,但我在集成谷歌分析时遇到了问题。我目前要将谷歌分析添加到我的单页网络应用程序中。但是当我尝试检索 ga 函数以发送新 url 时,它似乎找不到该函数。

这是我得到的代码:

索引.hbs

<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');

ga('create', 'My-key', 'auto');
</script>

应用程序组件.ts

import { Component, OnInit } from '@angular/core';
import {NavigationEnd, Router} from "@angular/router";
import {WindowRef} from "./social/windowRef";
@Component({
selector: 'my-app',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css'],
})
export class AppComponent {
user: User;
private currentRoute: string;

constructor(private misc: MiscService, public router: Router) {
this.router.events.subscribe(event => {
if (event instanceof NavigationEnd) {
console.log(event.urlAfterRedirects);
WindowRef.get().ga('set', 'page', event.urlAfterRedirects);
WindowRef.get().ga('send', 'pageview');
}
});
}
}

windowRef.ts

export class WindowRef{
public static get(): any{
console.log(window);
return window;
}
}

我得到了这个错误:ERROR TypeError: windowRef_1.WindowRef.get(...).ga is not a function

当我执行 console.log(WindowRef.get()); 时,我可以在窗口中看到 ga 函数,但当我尝试使用它时它仍然显示之前的错误。 herehere

我不太明白我用这个方法来检索 strip 功能,而且效果很好。

祝你有美好的一天:)

最佳答案

我在尝试将 Google Analytics 集成到我的 Angular 4 应用程序时遇到了类似的问题。

我的诀窍是将 Google 分析代码从 AppComponent 的构造函数移动到 ngAfterViewInit()生命周期 Hook 以确保首先完全初始化 View 。

这是我得到的代码:

index.html(和你一样):

<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject'] = r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');

ga('create', 'some code', 'auto');
</script>

app.component.ts:

import {AfterViewInit, Component, Inject, PLATFORM_ID} from '@angular/core';
import {isPlatformBrowser} from '@angular/common';
import {NavigationEnd, Router} from '@angular/router';

// declare google analytics
declare const ga: any;

@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent implements AfterViewInit {

constructor(@Inject(PLATFORM_ID) private platformId: Object,
private router: Router) {}


ngAfterViewInit(): void {
this.router.events.subscribe(event => {
// I check for isPlatformBrowser here because I'm using Angular Universal, you may not need it
if (event instanceof NavigationEnd && isPlatformBrowser(this.platformId)) {
console.log(ga); // Just to make sure it's actually the ga function
ga('set', 'page', event.urlAfterRedirects);
ga('send', 'pageview');
}
});
}
}

让我知道这是否也适用于您。祝你今天过得愉快! :)

关于javascript - angular 和 google analytics 集成 => ga 不是函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45241131/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com