[UA → GA4] 將電子商務資料收集設定從通用Analytics (分析 ...
文章推薦指數: 80 %
已變更的事件:. ecommerce_purchase (Google Analytics for Firebase) -> purchase; ecommerce_refund (Google Analytics for Firebase) -> refund ...
跳至主內容[UA→GA4]將電子商務資料收集設定從通用Analytics(分析)遷移至GA4在GoogleAnalytics(分析)4資源中設定電子商務資料收集的最佳做法本文適用於想要同時在通用Analytics(分析)和GoogleAnalytics(分析)4資源中收集電子商務資料的網站擁有者。
對於使用GoogleAnalyticsforFirebase的行動應用程式擁有者,本文也提供相關的最佳做法資訊。
GoogleAnalytics(分析)4資源中有些電子商務事件和參數的名稱已變更。
使用正確的GA4名稱和參數,才能在GA4資源中取得最實用的電子商務報表和電子商務事件資料。
如要從通用Analytics(分析)遷移至GA4,建議採用以下做法:
讓通用Analytics(分析)的導入設定維持不變。
為GA4資源建立重複事件;使用GoogleAnalytics(分析)資源規定的新事件名稱和參數。
這樣一來,您會有兩組同時運作但彼此獨立的導入設定,各自的用途有些不同。
避免讓通用Analytics(分析)和GA4共用電子商務導入設定
如果您在GA4資源中使用現有的通用Analytics(分析)電子商務導入設定(即dataLayer事件和gtag.js程式碼),GA4的電子商務報表就無法提供完整資料。
gtag.js程式庫會自動將部分(而非全部)通用Analytics(分析)事件和參數,轉換為GA4需要的資料。
此外,您也不應直接改為GA4的事件和參數名稱。
對於無法辨識的事件,通用Analytics(分析)不會收集任何資料。
舉例來說,所有的GA4電子商務事件都使用item_id這個參數,而非id。
基於上述原因,我們建議的最佳做法是使用兩種導入設定:一種用於通用Analytics(分析)資源,一種則用於GA4資源。
這樣系統就會傳送兩個事件,但原本的設定只會傳送一個,因此您可以自行決定是否採用通用Analytics(分析)導入設定,然後只新增需要的額外事件/參數,以便將資料傳送至GA4資源。
不過,您必須對兩組不同的事件和參數有深入瞭解,才能採取這種做法。
如要保留通用Analytics(分析)的dataLayer結構和物件:
必須新增GA4事件/參數,才能使用GA4資源的完整報表功能
如有在GA4中已淘汰的通用Analytics(分析)事件,則應使用新版GA4名稱建立重複事件
基本知識:事件和參數
事件會指定系統如何解讀您傳送的產品、清單和/或促銷活動資料。
參數可為事件提供更詳細的資訊。
如果是GA4,參數會嵌入到items陣列中(瞭解詳情)。
請注意,這與通用Analytics(分析)的dataLayer不同。
在dataLayer中,您必須為個別事件指定額外的動作資訊。
電子商務標記應遵循GA4事件和參數限制。
每個事件可指定最多25個自訂參數(items陣列只會使用一個版位);每個專案可指定最多50個自訂維度和50個自訂指標(瞭解詳情)。
GA4電子商務的必要參數
(必要參數會以粗體標示)
如果您沒有為電子商務專用事件(例如items、item_id、item_name)加入必要參數,這些事件就不會顯示在GA4電子商務報表中,系統會將其視為自訂事件。
事件名稱
參數
view_item
currency、items、value
view_item_list
items、item_list_name、item_list_id
select_item
items、item_list_name、item_list_id
add_to_wishlist
currency、items、value
add_to_cart
currency、items、value
view_promotion
items、promotion_id、promotion_name、creative_name、creative_slot、location_id
select_promotion
items、promotion_id、promotion_name、creative_name、creative_slot、location_id
view_cart
currency、items、value
remove_from_cart
currency、items、value
begin_checkout
coupon、currency、items、value
add_payment_info
coupon、currency、items、payment_type、value
add_shipping_info
coupon、currency、items、shipping_tier、value
purchase
affiliation、coupon、currency、items、transaction_id、shipping、tax、value
refund
affiliation、coupon、currency、items、transaction_id、shipping、tax、value
參數(coupon、affiliation、item_list_name、item_list_id)可在事件或項目層級傳送。
如果事件和項目層級都有參數,則以項目層級優先。
事件參數
項目層級參數
項目(請見下方)
affiliation、coupon、currency、discount、index、item_id、item_brand、item_category、item_category2、item_category3、item_category4、item_category5、item_list_name、item_list_id、item_name、item_variant、price、quantity
下表說明系統可收集的個別項目陣列參數。
項目陣列參數名稱
說明
affiliation
與個別商品相關的聯盟(合作夥伴/供應商,如果有的話)名稱或代碼
coupon
與個別商品相關的優待券名稱/代碼(如果有的話)
discount
與個別商品相關的折扣(如果有的話)
item_brand
商品品牌
item_category
商品類別
item_category2
商品的第二個類別階層或其他分類
item_category3
商品的第三個類別階層或其他分類
item_category4
商品的第四個類別階層或其他分類
item_category5
商品的第五個類別階層或其他分類
item_id
商品ID(必填)
item_name
商品名稱(必填)
item_variant
其他商品詳細資料/選項,如商品子類、專屬代碼或說明
price
商品價格
quantity
有使用者互動的商品數量
通用Analytics(分析)和GA4對照
部分名稱已變更,例如:先前稱為「impression」或「product」的資料層參數,現已合併為items。
現已有一個items陣列。
在GA4資源中,電子商務和加強型電子商務之間沒有差異。
如何使用此表格:
比較事件的變更情形(A欄與C欄)
查看維度/參數要求和變更(B欄與D欄)。
請注意,下方另一表格將說明項目/產品的參數變更情形
如果您的應用程式使用Firebase,請特別注意事件名稱的變更,並根據GA4事件名稱(C欄)進行修改。
GA4資源中的所有新電子商務專用報表,都不會顯示在Firebase介面中。
此外,Firebase的詳細事件報表(例如ecommerce_purchase和purchase)可能不會更新。
已變更的事件:
ecommerce_purchase(GoogleAnalyticsforFirebase)->purchase
ecommerce_refund(GoogleAnalyticsforFirebase)->refund
select_content(GoogleAnalyticsforFirebase)->select_item
present_offer(GoogleAnalyticsforFirebase)->select_promotion
新增的事件
view_cart
A欄
通用Analytics(分析)事件名稱(參考資料)
B欄
通用Analytics(分析)維度(參考資料)
C欄
GA4事件名稱(參考資料)
D欄
GA4參數(參考資料)
purchase
refund
id[ID]
coupon
revenue
tax
shipping
currencyCode
**products(詳情請見下方)
purchase
refund
transaction_id
coupon
value
tax
shipping
currency
**items(詳情請見下方)
checkout_option
option
*add_payment_info
payment_type
checkout_option
revenue
currencyCode
option
*add_shipping_info
price
currency
shipping_tier
checkout
currencyCode
revenue
coupon
step(僅限analytics.js)
option(僅限analytics.js)
**products
*begin_checkout
currency
value
coupon
**items
addToCart
不適用
removeFromCart
不適用
currencyCode
revenue
**products
*add_to_cart
*add_to_wishlist
*remove_from_cart
*view_cart
currency
value
**items
pageview
currencyCode
**products
revenue
*View_item(資料檢視預設值)
currency
**items
value
pageview
productClick
list
無
**products
*View_item_list(推銷資料檢視)
*select_item
item_list_name
item_list_id
**items
pageview
promotionClick
id[ID]
name
creative
position
**products
*view_promotion
*select_promotion
promotion_id
promotion_name
creative_name
creative_slot
**items
*全新或由通用Analytics(分析)變更而來的事件名稱
詳細說明
GA4參數
對應的通用Analytics(分析)維度
**Items/Productsdetail
items
item_id
item_name
item_brand
item_category
item_category2
item_category3
item_category4
item_category5
item_variant
affiliation
discount
coupon
price
quantity
products
id[ID]
name
brand
category
無
無
無
無
variant
無
無
coupon
price
quantity
在GA4資源中,下列通用Analytics(分析)事件名稱會視為電子商務事件:
purchase
refund
begin_checkout
add_to_cart
remove_from_cart
view_cart
add_to_wishlist
view_item*
view_promotion
select_promotion
select_item*
view_item_list
add_payment_info
add_shipping_info
*這些事件僅支援單一項目。
透過gtag.jsAPI傳送上述任一事件至GA4資源時,GA4電子商務事件處理作業會在事件模型中尋找items鍵。
如果找到該鍵,系統會將該參數剖析為包含最多200個項目的陣列,其中每個項目都是含預先定義架構的物件。
GA4電子商務會針對每一個項目,根據預先定義清單傳送任何相符欄位的資料。
項目的初始預先定義欄位如下:
item_id
item_name
item_brand
item_category
item_category2
item_category3
item_category4
item_category5
item_variant
price
quantity
coupon
index
item_list_name
item_list_id
discount
affiliation
location_id
promotion_id(事件或項目層級;以項目層級優先)
promotion_name(事件或項目層級;以項目層級優先)
creative_name(事件或項目層級;以項目層級優先)
creative_slot(事件或項目層級;以項目層級優先)
如果您未更新通用Analytics(分析)中的事件設定,系統將因無法辨識舊的事件名稱,而不再於GA4電子商務報表中顯示下列事件。
請使用正確的名稱為GA4資源建立重複事件。
set_checkout_option(在GA4中已與begin_checkout合併)
checkout_progress(在GA4中已與begin_checkout合併)
select_content(不再是GA4電子商務事件,但仍是建議事件,不支援items陣列)
GA4資源推出了額外的項目層級參數,例如affiliation、currency和幾個item_category參數。
如未重新加入代碼,就無法享有這些參數的優點。
不過,這些參數並非必要,不採用也不會影響程式碼運作。
更新Google代碼管理工具的dataLayer
您必須在dataLayer中新增事件/參數,並在Google代碼管理工具中新增事件觸發條件,才能使用GA4資源的新事件。
您可以手動決定要將哪一個dataLayer鍵對應到特定的事件參數。
舉例來說,在通用Analytics(分析)中,您必須將dataLayer物件的id(來自購買事件)推送為「ecommerce.purchase.actionField.id」。
在GA4中,您則可指定讓dataLayer鍵對應至「transaction_id」事件參數。
如果您重複使用通用Analytics(分析)dataLayer物件,可以建立一個對應至「ecommerce.purchase.actionField.id」鍵的Google代碼管理工具dataLayer變數,並指派給GA4事件做為「transaction_id」。
或者將Google代碼管理工具的dataLayer變數對應至「ecommerce.purchase.transaction_id」鍵,再指派至事件參數「transaction_id」。
您可以選擇繼續參照現有的dataLayer物件
如果您採用通用Analytics(分析)導入設定中現有的dataLayer物件,就無法使用新版GA4事件名稱和參數(例如額外的item層級參數)。
不過,如果您在代碼管理工具中手動建立必要的變數,就能為現有事件製作部分電子商務報表。
在Google代碼管理工具中設定GA4事件代碼,以使用dataLayer傳送電子商務事件時,您必須手動輸入dataLayer變數做為事件參數,例如參數名稱:「items」和值{{ecommerce.purchase.products}}。
其中,{{ecommerce.purchase.products}}是代碼管理工具dataLayer變數,您必須建立這個變數才能讀取dataLayer中的產品陣列。
您需要為每個事件層級參數建立dataLayer變數,並指派給事件參數。
接著,請針對每個電子商務事件重複執行此程序。
詳情請參閱下例。
通用Analytics(分析)使用的Google代碼管理工具dataLayer推送程式碼(參考資料)
重複使用通用Analytics(分析)中現有dataLayer的GA4Google代碼管理工具導入設定
dataLayer.push({
'ecommerce':{
'purchase':{
'actionField':{
'id':'T12345', //交易ID。
購買與退款的必要資訊。
'affiliation':'OnlineStore',
'revenue':'35.43', //交易總金額(含稅金與運費)
'tax':'4.90',
'shipping':'5.99',
'coupon':'SUMMER_SALE'
},
'products':[{ //productFieldObjects清單。
'name':'TriblendAndroidT-Shirt', //必須提供名稱或ID。
'id':'12345',
'price':'15.25',
'brand':'Google',
'category':'Apparel',
'variant':'Gray',
'quantity':1,
'coupon':'' //選填欄位可以省略或設為空字串。
},
{
'name':'DonutFridayScentedT-Shirt',
'id':'67890',
'price':'33.75',
'brand':'Google',
'category':'Apparel',
'variant':'Black',
'quantity':1
}]
}
}
});
您必須為每個事件層級參數建立dataLayer變數,如下所示。
您必須為追蹤的每個電子商務事件重複執行此程序。
導入範例
設定購物程序
購物程序通常包含四個步驟:
查看產品
使用者查看項目或項目清單。
如要評估項目清單的瀏覽次數/曝光次數,請將項目清單推送到dataLayer中,然後與該資料一併收集事件。
gtag.js
事件:view_item_list或view_item
在通用Analytics(分析)中,對應的事件為「impressions」
參數:至少須包含item_id或item_name
在通用Analytics(分析)中,參數並沒有前置字串「item_」;「list_position」現已改為「index」
Google代碼管理工具
事件:view_item_list或view_item
在通用Analytics(分析)中,對應的事件為「impressions」
參數:項目是資料層變數「ecommerce.items」;參數為「items{}」,且至少須包含item_id或item_name
在通用Analytics(分析)中,參數並沒有前置字串「item_」;「position」現已改為「index」
加入購物車
使用者選取某個商品並加入購物車。
其他相似的動作可能包括:加入願望清單或索取更多資訊。
gtag.js
事件:add_to_cart
參數:至少須包含item_id或item_name
Google代碼管理工具
事件:add_to_cart
在通用Analytics(分析)中,對應的dataLayer事件為「addToCart」,而且必須有額外的「add」這個actionFieldObject。
GA4的dataLayer物件中已不再需要actionFieldObject。
參數:屬於「items」的一部分,至少須包含item_id或item_name
在通用Analytics(分析)中,必須使用專屬變數「products」來提供產品資訊
結帳
使用者前往查看購物車中的商品,然後開始結帳程序。
新增付款或運送資訊等其他步驟各有專屬的GA4事件。
如果您的結帳流程包含這些額外步驟,請務必傳送適用的特定事件,以便在購物程序中加入這些步驟。
gtag.js
事件:begin_checkout
通用Analytics(分析)中還提供「checkout_progress」和「set_checkout_option」事件,這些在GA4資源中無法使用;請先參閱add_to_cart、add_shipping_info和add_payment_info等特定事件。
參數:至少須包含item_id或item_name
Google代碼管理工具
事件:begin_checkout
在通用Analytics(分析)中,對應的dataLayer事件為「checkout」,而且必須有額外的「checkout」這個actionFieldObject;GA4中不再需要這個actionField,但不建議您變更現有的導入設定,否則通用Analytics(分析)中的電子商務架構可能無法繼續運作。
參數:屬於「items」的一部分,至少須包含item_id或item_name
在通用Analytics(分析)中,必須使用專屬變數「products」來提供產品資訊
購買
使用者進行購物
在GA4資源中,您將此事件加入程式碼後,系統會自動將這個事件標示為轉換
gtag.js
事件:purchase
通用Analytics(分析)中還提供「checkout_progress」和「set_checkout_option」事件,這些事件在GA4資源中無法使用
參數:至少須包含transaction_id
通用Analytics(分析)-analytics.js
參考資料
通用Analytics(分析)-gtag.js
參考資料
GA4資源-gtag.js
參考資料
ga('ec:addProduct',{
'id':'P12345',
'name':'AndroidWarholT-Shirt',
“Otheroptionalvalues”
});
ga('ec:setAction','purchase',{
'id':'T12345',
“Otheroptionalvalues” });
gtag('event','purchase',{
"transaction_id":"123",
“Otheroptionalvalues”
"items":[
{
"id":"P12345",
"name":"AndroidWarholT-Shirt",
“Otheroptionalvalues”
},
{
"id":"P67890",
"name":"FlamechallengeTShirt",
“Otheroptionalvalues”
}
]
});
gtag('event','purchase',{
"transaction_id":"123",
“Otheroptionalvalues”
"items":[
{
"item_id":"P12345",
"item_name":"AndroidWarholT-Shirt",
“Otheroptionalvalues”
},
{
"item_id":"P67890",
"item_name":"FlamechallengeTShirt",
“Otheroptionalvalues”
}
]
});
analytics.js會使用加強型電子商務來設定productFieldObject(用於指定產品詳細資料)和actionFieldObject(用於指定發生的動作)。
遷移至gtag.js則是截然不同的做法。
只有一個事件且會自動記錄為電子商務;可同時納入交易和產品資訊;產品資訊可以陣列的形式傳送(不需要使用額外事件)。
傳送購買事件,內含交易的項目。
必要值的名稱不同,例如「id」改為「item_id」,「name」則改為「item_name」。
另外請注意,選用值也有差異。
傳送購買事件,內含交易的項目
Google代碼管理工具
事件:purchase
在通用Analytics(分析)中,對應的事件資料層事件為「purchase」;必須提供完整交易的動作欄位
參數:屬於「items」的一部分,至少須包含item_id或item_name
在通用Analytics(分析)中,必須使用專屬變數「products」來提供產品資訊
通用Analytics(分析)-代碼管理工具
參考資料
GA4資源-gtag.js
參考資料
dataLayer.push({
'ecommerce':{
'purchase':{
'actionField':{
'id':'T12345',
‘Otheroptionalvalues’
},
'products':[{
'name':'TriblendAndroidT-Shirt',
'id':'12345',
‘Otheroptionalvalues’
},
{
'name':'DonutFridayScentedT-Shirt',
'id':'67890',
‘Otheroptionalvalues’
}]
}
}
});
dataLayer.push({
'event':'purchase',
'ecommerce':{
'items':[{
'item_name':'TriblendAndroidT-Shirt',
'item_id':'12345',
‘Otheroptionalvalues’
},
{
'item_name':'DonutFridayScentedT-Shirt',
'item_id':'67890',
‘Otheroptionalvalues’
}]
}
});
使用購買動作將交易明細和會觸發加強型電子商務代碼的事件,一併推送至dataLayer。
載入網頁時,連同網頁瀏覽一併傳送交易資料(如果有的話)。
或者,在出現交易資料時使用事件。
重要異動:
GA4會列出項目,而非產品。
雖然您可以使用通用Analytics(分析)導入設定,但GA4資源只會收集事件計數等基本資訊,且不會隨附其他功能(例如程序報表)。
必要值的名稱不同,例如「id」改為「item_id」,「name」則改為「item_name」。
另外請注意,選用值也有差異。
如要評估交易,請將項目清單推送到資料層中,然後與該資料一併收集purchase事件。
以下範例假設網頁載入時,已經知道網頁上顯示產品的詳細資料:
其他電子商務活動
GA4資源也可以擷取其他資訊:
醒目顯示與某個項目或活動相關的獎勵
Coupon:可用於指定任何與特定項目相關的優待券名稱(例如免運費或打8折);資料類型為字串,屬於項目參數
Discount(新參數):可用於指定與特定項目相關的折扣金額(例如「0.05」);資料類型為浮點
Promotion:包括引導使用者前往網站/應用程式中特定部分的站內訊息
必須有promotion_id或promotion_name,否則只有事件表格標準報表可提供資料
如要將購買歸因於促銷活動,您必須在每個電子商務事件的項目或商品清單層級加入promotion_id或promotion_name參數。
Refunds:評估交易退款
退款是特定事件,可處理完整或部分退款
必須有transaction_id,否則只有事件表格標準報表可提供資料
這對您有幫助嗎?我們應如何改進呢?是否送出true[UA→GA4]GoogleAnalytics(分析)4轉換基礎知識[UA→GA4]GoogleAnalytics(分析)4中的轉換[UA→GA4]將電子商務資料收集設定從通用Analytics(分析)遷移至GA4[UA→GA4]大型/小型轉換和程序[UA→GA4]驗證已遷移的轉換[UA→GA4]在GoogleAds中對GoogleAnalytics(分析)4轉換出價搜尋清除搜尋內容關閉搜尋Google應用程式主選單搜尋說明中心true69256falsefalse
延伸文章資訊
- 1Google Analytics 4 實現電子商務事件设定
purchase:購買成功
- 2Google Tag Manager vs Google Analytics: Fully Explained (2022)
- 3How to Measure Purchases With gtag.js From iFrame - Medium
Global site tag (gtag.js) - Google Analytics --> ... we use gtag with the 'purchase' event to sen...
- 4Gtag Purchase Event Ignored On Google Analytics - ADocLib
- 5[UA → GA4] 將電子商務資料收集設定從通用Analytics (分析 ...
已變更的事件:. ecommerce_purchase (Google Analytics for Firebase) -> purchase; ecommerce_refund (Google...