GTM 데이터 레이어에서 Liferay rest API 호출에서 값을 가져 오는 변수를 사용하고 있습니다. GTM의 데이터 레이어에 자바 스크립트 변수가 정의되지 않았습니다.
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 = [{
"page" : Liferay.currentURL
,"pageType" : instrDetail
,"user" : {
"type" : userType
,"accountId" : openId
}
}];
과 끝에서, 우리는 블록 GTM있다. I는 데이터 영역에 openId
변수에 액세스하려고하면 I가 동일한 하나의 브라우저 콘솔을 액세스 할 때, 올바른 값을 표시하는 반면
(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');
지금, 그와 같은 정의이다.