at.js에서 플리커를 관리하는 방법

페이지 또는 앱 로드 중 Adobe Target at.js JavaScript 라이브러리가 어떻게 플리커를 방지하는지에 대한 정보입니다.

플리커는 기본 컨텐츠가 활동 컨텐츠로 대체되기 전에 방문자에게 순간적으로 표시될 때 발생합니다. 플리커는 방문자에게 혼란을 야기할 수 있으므로 달갑지 않습니다.

자동 생성된 글로벌 mbox 사용

at.js 구성 시 글로벌 mbox를 자동으로 만들기 설정을 활성화하면 at.js가 페이지 로드 시 불투명도 설정을 변경하여 플리커(깜박임)를 관리합니다. at.js가 로드되면 <body> 요소의 불투명도 설정이 "0"으로 변경되어 방문자가 처음에 페이지를 볼 수 없게 됩니다. Target의 응답을 받은 후 또는 Target 요청의 오류가 감지된 경우 at.js는 불투명도를 "1"로 재설정합니다. 이렇게 하면 활동의 컨텐츠가 적용된 후에만 방문자에게 페이지가 표시됩니다.

at.js 구성 시 이 설정을 활성화할 경우 at.js가 HTML BODY 스타일 불투명도를 0으로 설정합니다. Target의 응답을 받은 후 at.js는 HTML BODY 불투명도를 1로 재설정합니다.

0으로 설정된 불투명도는 깜박임을 방지하기 위해 페이지 컨텐츠를 숨기지만, 브라우저가 여전히 페이지를 렌더링하고 CSS, 이미지 등과 같은 필요한 모든 자산을 로드합니다.

구현에서 opacity: 0이(가) 작동하지 않는 경우 bodyHiddenStyle을(를) 사용자 지정하여 깜박임을 관리하고 body {visibility:hidden !important}(으)로 설정할 수도 있습니다. body {opacity:0 !important} 또는 body {visibility:hidden !important} 중 특정 환경에 가장 적합한 것을 사용할 수 있습니다.

다음 그림에서는 at.js 1.x ​와 at.js 2.x의 본문 숨기기와 본문 표시 호출을 보여줍니다.

at.js 2.x

이미지 를 클릭하여 전체 너비로 확장합니다.

Target 흐름: at.js 페이지 로드 요청

at.js 1.x

이미지 를 클릭하여 전체 너비로 확장합니다.

대상 흐름: 자동으로 만든 글로벌 mbox

bodyHiddenStyle 무시에 대한 자세한 내용은 targetGlobalSettings()를 참조하십시오.

at.js를 비동기식으로 로드할 때 플리커 관리

at.js를 비동기식으로 로드하는 것은 브라우저 렌더링이 차단되지 않도록 하는 좋은 방법입니다. 그러나 이 기법은 웹 페이지에서 플리커를 유발할 수 있습니다.

관련 HTML 요소가 Target에 의해 개인화된 후 표시되는 사전에 숨기는 코드 조각을 사용하여 플리커를 방지할 수 있습니다.

at.js는 페이지에 직접 포함되거나 태그 관리자(예: Adobe Experience Platform Launch)를 통해 비동기식으로 로드할 수 있습니다.

at.js가 페이지에 포함된 경우 at.js를 로드하기 전에 코드 조각을 추가해야 합니다. 비동기적으로 로드되는 태그 관리자를 통해 at.js를 로드하는 경우 태그 관리자를 로드하기 전에 코드 조각을 추가해야 합니다. 태그 관리자가 동기적으로 로드되면 스크립트가 at.js 앞에 태그 관리자 내에 포함될 수 있습니다.

사전에 숨기는 코드 조각은 다음과 같습니다.

;(function(win, doc, style, timeout) {
  var STYLE_ID = 'at-body-style';

  function getParent() {
    return doc.getElementsByTagName('head')[0];
  }

  function addStyle(parent, id, def) {
    if (!parent) {
      return;
    }

    var style = doc.createElement('style');
    style.id = id;
    style.innerHTML = def;
    parent.appendChild(style);
  }

  function removeStyle(parent, id) {
    if (!parent) {
      return;
    }

    var style = doc.getElementById(id);

    if (!style) {
      return;
    }

    parent.removeChild(style);
  }

  addStyle(getParent(), STYLE_ID, style);
  setTimeout(function() {
    removeStyle(getParent(), STYLE_ID);
  }, timeout);
}(window, document, "body {opacity: 0 !important}", 3000));

기본적으로 이 코드 조각은 전체 HTML BODY를 사전에 숨깁니다. 일부 경우, 전체 페이지가 아닌 특정 HTML 요소만 사전에 숨길 수 있습니다. 이 작업은 스타일 매개 변수를 사용자 지정하여 수행할 수 있습니다. 이것은 페이지의 특정 영역만을 사전에 숨기는 어떤 것으로 대체할 수 있습니다.

예를 들어, ID별로 식별되는 두 개의 영역인 container-1 및 container-2가 있으면 이 스타일을 기본값 대신 다음과 같이 바꿀 수 있습니다.

#container-1, #container-2 {opacity: 0 !important}

기본값:

body {opacity: 0 !important}

at.js 2.x에서 triggerView()에 대한 플리커 관리

triggerView()를 사용하여 SPA에서 타깃팅된 컨텐츠를 표시할 때 플리커(깜박임) 관리가 즉시 제공됩니다. 이것은 사전 숨김 로직을 수동으로 추가할 필요가 없음을 의미합니다. 대신 at.js 2.x에서는 타깃팅된 콘텐츠를 적용하기 전에 보기를 표시해야 하는 위치를 사전에 숨깁니다.

getOffer() 및 applyOffer()를 사용하여 플리커 관리

getOffer()applyOffer()는 모두 낮은 수준의 API이므로 기본으로 제공되는 플리커 제어 기능이 없습니다. applyOffer()에 선택기 또는 HTML 요소를 선택 사항으로 전달할 수 있습니다. 이 경우 applyOffer()는 활동 컨텐츠를 이 특정 요소에 추가하게 됩니다. 하지만, getOffer()applyOffer()를 호출하기 전에 해당 요소가 제대로 미리 숨겨져 있는지 확인해야 합니다.

document.documentElement.style.opacity = "0";

adobe.target.getOffer({
    mbox: 'target-global-mbox',
    success: function(offer) {
        adobe.target.applyOffer({
            mbox: 'target-global-mbox',
            offer: offer
        });

        document.documentElement.style.opacity = "1";
    },
    error: function() {
        document.documentElement.style.opacity = "1";
    }
});

at.js 1.x에서 mboxCreate()와 함께 지역 mbox 사용(at.js 2.x에서는 지원되지 않음)

지역 mbox 구현을 사용하는 경우 다음 샘플 코드와 유사하게 공급된 페이지에 mboxCreate()을 사용할 수 있습니다.

<div class="mboxDefault">
Some default content
</div>
<script>
mboxCreate('some-mbox');
</script>

페이지가 적절하게 공급되면 at.js는 mboxDefault 클래스를 사용하여 요소의 CSS "가시성" 속성을 적절하게 전환하여 플리커를 관리합니다.

recommendation-more-help
6906415f-169c-422b-89d3-7118e147c4e3