Ga4とGTMでバナーのABテストを行う方法

なるべくサイトにあるコードを直接触らない方法です。
最終的には以下のようなレポートが出来上がります。

Webサイト上には以下のコードが出力されます。

<div id="sideBannerAB">
	//Aパターンの場合
  <a class="banner_liapoc" href="任意のURL" testBanner="任意の文字列">
  <img src="AパターンのバナーURL">
  </a>
</div>
目次

バナーABテストに必要なこと

どこにバナーを出すか指示する、HTMLをサイトに実装

任意のIDをHTMLで実装します。

GA4では以下の2つを作成・設定

  1. イベントパラメーター(GTM上でGA4設定を行います)
    • イベントパラメーターとは、イベントに紐付けることのできる2次情報のことです。
  2. カスタムディメンション(GA4の管理画面で行います)
    • イベントパラメータで取得した値を格納・非表示するために必要です。

GTMでは以下の4つを作成

  1. カスタムHTMLタグ
    • バナーを2種類ランダムで表示するためのJavascriptをカスタムHTMLで作成します。
  2. バナーのHTMLに含まれる要素を取得して変数として持てるカスタムJavaScript
    • 1で生成されたコードのtestBanner要素を取得するJavaScript
  3. バナー表示を取得するトリガーとGA4へイベントを送るタグ
    • トリガー
      • GTMのユーザー定義変数の要素の視認性を利用
    • タグ
      • GA4のGoogle アナリティクス: GA4 イベントを利用
      • このタグで、GA4のパラメータを入力します
  4. バナークリックを計測するトリガーとタグ
    • トリガー
      • GTMの組み込み変数のClick classを利用
    • タグ
      • GA4のGoogle アナリティクス: GA4 イベントを利用
      • このタグで、GA4のパラメータを入力します

GA4でレポート作成

計測したデータを表示させるレポートを作成します。

GA4での作業  バナーABテストのGA4

カスタムディメンションの作成

GA4の左下のギアをクリックし、カスタム定義をクリックします。

カスタムディメンションを選択し、ディメンション名はbanner_idを入力します。

イベントパラメータ名もbanner_idを入力します。

保存を押して完了です。

ディメンション名、イベントパラメータ名同じにする必要はありませんが合わせておくと、管理が楽です。ここで入力したイベントパラメータ名をGTM側でも使用します。

GTMでの作業 バナーABテストのGA4

HTMLをサイトへ追加

今回はサイドバナーのABテストを行いたいと思います。

サイドバナーを出したいところへ以下のHTMLを追加します。どこにバナーを出すか指示するものと考えてください。

<div id="sideBannerAB"></div>

すでに出したい箇所に、同様のHTMLがあればそちらを使用していただいても大丈夫です。

GTMのカスタムHTMLでバナー作成

GTM > タグ >カスタムHTMLを選択します。

ページ上でsideBannerABのIDがある場合、に発火します。

トリガーは全てのページを選択します。

<script>
(function() {
  if (document.querySelector("#sideBannerAB")) {
    var sideBanner = document.querySelector("#sideBannerAB");

    var banners = [
      {
        //Aパターンのリンク先
        href: "http://example.com/a",
        //Aパターンの識別用
        testId: "testA",
        //AパターンバナーURL
        imgUrl: "http://example.com/a.png"
      },
      {
        //Bパターンのリンク先
        href: "http://example.com/b",
        //Bパターンの識別用
        testId: "testB",
        //BパターンバナーURL
        imgUrl: "http://example.com/b.png"
      }
    ];

    var randomNumber = Math.floor(Math.random() * 2);

    var bannerHtml = '<a class="banner_liapoc" href="' + banners[randomNumber].href + '" testBanner="' + banners[randomNumber].testId + '"><img src="' + banners[randomNumber].imgUrl + '"></a>';

    // バナーAまたはバナーBのHTMLを挿入
    sideBanner.insertAdjacentHTML('afterbegin', bannerHtml);
  }
})();

</script>

GTMのカスタムJavaScriptでバナー要素(testBanner)の値を取得

GTM > 変数 > ユーザー定義変数 > カスタムJavaScriptを選択

名称は、Banner_AB とします。ここで指定した名称が変数として利用できます。

function getTestBannerValue() {
  var sideBanner = document.getElementById("sideBannerAB");
  var aElement = sideBanner.querySelector("a");
  var testBannerValue = aElement.getAttribute("testBanner");
  return testBannerValue;
}

GTM > トリガー > ユーザーエンゲージメントの要素の表示を選択

名称は、テストバナー表示としています。

選択方法はIDを選択し、要素IDにはsideBannerABを入力します。

GTMでバナーが表示されたことをGA4 へ送るタグの作成

GTM > タグ > Google アナリティクス: GA4 イベントを選択

イベント名は、BannerShowにします。ここで入力したイベント名がGA4へイベントとして送られます。

パラメータは、banner_idを入力します。ここで入力したパラメーター名が、BannerShowイベントの2次情報としてGA4へ送られます。

値は、先程作成したBanner_ABを選択します。

トリガーは先程作成した、テストバナー表示を選択します。

GTM > トリガー > クリック リンクのみを選択

名称はバナークリックにしています(何でも構いません)。

Click Classesを選択し、banner_liapocを入力

Click Classesが表示されない場合は、変数 > 組み込み変数 > 設定から表示されるようになります。

GTMでバナーがクリックされたことをGA4 へ送るタグの作成

GTM > タグ > Google アナリティクス: GA4 イベントを選択

イベント名は、BannerClickにします。ここで入力したイベント名がGA4へイベントとして送られます。

パラメータは、banner_idを入力します。ここで入力したパラメーター名が、BannerShowイベントの2次情報としてGA4へ送られます。値は、先程作成したBanner_ABを選択します。

トリガーは先程作成した、バナークリックを選択します。

GA4でレポート作成

計測したデータをGA4で表示させます(実装した翌日以降から可能です)。

探索 > 空白を選択

セグメントの新規作成 > イベントセグメント

名称は、バナーABテスト

条件は、BannerShow または BannerClick 

ディメンションは、カスタム > banner_id と、イベント名を選択

指標はイベント数を選択 右のようなBannerShowとBannerClickが計測されているのが確認できます。

設定周りで悩んだら、お気軽にご相談ください。
問合せの際は「web担当者を見た」とお伝えください。

この記事を書いた人

デジタルマーケティングに16年間従事しているMITSUIです。Google AnalyticsとGoogle Tag Managerが大好きで、これらのツールを活用した情報提供を行っています。ブログではデジタルマーケティングに関する情報や最新のトレンド、ベストプラクティスを紹介しています。

質問などあればお気軽に!

コメントする

CAPTCHA


目次