GTMデータレイヤの変数を使用して、Liferay rest API呼び出しからその値を取得しています。ここGTMのデータレイヤーで使用するとJavaScriptの変数が未定義
var openId;
AUI().ready('aui-base', function(A){
Liferay.Service(
'/user/get-user-by-id',
{
userId: Liferay.ThemeDisplay.getUserId()
},
function(obj) {
openId=obj.openId;
}
);
});
openId
変数は、それが利用可能でないとundefined
として示すGTM dataLayerのに使用されています。 データ層は以下のように定義される:タグマネージャスクリプトブロックを定義する、
dataLayer = [{
"page" : Liferay.currentURL
,"pageType" : instrDetail
,"user" : {
"type" : userType
,"accountId" : openId
}
}];
を、最後に、我々は、GTMのブロックを有します。今
(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=
'//www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f);
})(window,document,'script','dataLayer','GTM-XXXXXX');
私はdataLayerにopenId
変数にアクセスしようとしたとき、私は同じ1つのブラウザコンソールにアクセスしようとすると、それが正しい値を表示するのに対し、それは、未定義を示しています。