質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Google Analytics

Google AnalyticsはGoogleが開発した無料のウェブ分析のソリューションです。複数のクライアント側のAPIとデータをエクスポートし管理するREST APIも格納されています。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Google Analytics API

Google Analytics APIは、アクセス解析機能が行える API(Application Programming Interface)です。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

2287閲覧

Googleアナリティクスが反映されない

dwayne_johnson

総合スコア86

Google Analytics

Google AnalyticsはGoogleが開発した無料のウェブ分析のソリューションです。複数のクライアント側のAPIとデータをエクスポートし管理するREST APIも格納されています。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Google Analytics API

Google Analytics APIは、アクセス解析機能が行える API(Application Programming Interface)です。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2018/09/02 06:40

なぜか、Googleアナリティクスが反映されません。

ReactでSPAのサイトを構築しています。

SPAのため、ルーティング変更の際に毎回、gtagのconfigを書き換え送る必要があることは認識しており、componentDidUpdate内でそれらをハンドリングしております。

index.html

1<head> 2 <!-- Global site tag (gtag.js) - Google Analytics --> 3 <script async src="https://www.googletagmanager.com/gtag/js?id=GA_TRACKING_ID"></script> 4 <script> 5 window.dataLayer = window.dataLayer || []; 6 function gtag(){dataLayer.push(arguments);} 7 gtag('js', new Date()); 8 9 gtag('config', 'GA_TRACKING_ID'); 10 </script>

App.jsx

1componentDidUpdate(prevProps) { 2 const gtag = window.gtag 3 4 if (prevProps.location.pathname === this.props.location.pathname) { 5 return; 6 } 7 8 if (prevProps.history.action === 'PUSH' && typeof (gtag) === 'function') { 9 console.log('in func') 10 gtag('config', 'GA_TRACKING_ID', { 11 'page_location': window.location.href, 12 'page_path': this.props.location.pathname, 13 }); 14 } 15}

上記の"GA_TRACKING_ID"に関しては、すべて自分のトラッキングIDを記入しています。かなり確認しましたので、間違いないです。
また、"App.jsx"で記しているconsole.log("in func")は、ページ遷移のタイミングでコンソールから確認できております。
this.props.location.pathnameに関しましても、正しく現在のページのURLが読み込まれていることを確認しております。(例えば、"/React/react-router-usecase"など)

chromeのdevツールのNetworkを確認したところ、

以上3つの、ga関連のものと通信はあることがわかりました。

一番不思議なのは、SPAであっても、少なくとも1回は、index.htmlが読み込まれるはずであり、そのタイミングでカウントは走ると思っていました。しかし現実には、GAのコンソール画面のリアルタイムには現れず、ステータスには「過去 48 時間に受信したデータはありません。」と現れる始末です。

GAとの通信が失敗している理由として、他にどのようなことが考えられるでしょうか?
お助け願います。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

なんか、登録から3日ほど経ったら、問題なく表示されるようになりました。
お騒がせしました。

おれの、3日の苦悩は。。。

投稿2018/09/03 00:59

dwayne_johnson

総合スコア86

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問