Show Menu
화제×

Adobe 플러그인: apl(appendToList)

이 플러그인은 Adobe Analytics를 최대한 활용할 수 있도록 Adobe Consulting에서 무료로 제공합니다. Adobe 고객 지원 팀에서는 설치 또는 문제 해결 등 이 플러그인에 대한 지원을 제공하지 않습니다. 이 플러그인에 대한 도움이 필요한 경우 조직의 계정 관리자에게 문의하십시오. 계정 관리자가 도와줄 컨설턴트와의 만남을 주선할 수 있습니다.
apl 플러그인을 사용하면 events , linkTrackVars , list 및 기타 변수와 같은 목록 구분 변수에 새 값을 안전하게 추가할 수 있습니다.
  • 추가하려는 값이 변수에 없으면 코드는 값을 문자열 끝에 추가합니다.
  • 추가하려는 값이 변수에 이미 있으면 이 플러그인은 값을 변경하지 않습니다. 이 기능을 사용하면 구현에서 중복 값을 방지할 수 있습니다.
  • 추가하려는 변수가 비어 있으면 플러그인은 이 변수를 새 값으로 설정합니다.
구분된 값으로 이루어진 문자열을 포함하는 기존 변수에 새 값을 추가하려면 이 플러그인을 사용하는 것이 좋습니다. 구분된 값이 포함된 변수용 문자열을 연결하려는 경우에는 이 플러그인이 필요하지 않습니다.

Adobe Experience Platform Launch 확장을 사용하여 플러그인 설치

Adobe는 가장 일반적으로 사용되는 플러그인을 사용할 수 있도록 해주는 확장을 제공합니다.
  1. AdobeID 자격 증명을 사용하여 launch.adobe.com 에 로그인합니다.
  2. 원하는 속성을 클릭합니다.
  3. 확장 탭으로 이동한 다음, 카탈로그 단추를 클릭합니다.
  4. 일반적인 Analytics 플러그인 확장을 설치 및 게시합니다.
  5. 아직 없다면 다음 구성으로 "플러그인 초기화"라는 레이블이 지정된 규칙을 만듭니다.
    • 조건: 없음
    • 이벤트: 핵심 - 라이브러리가 로드됨(페이지 상단)
  6. 다음 구성으로 위의 규칙에 작업을 추가합니다.
    • 확장: 일반적인 Analytics 플러그인
    • 작업 유형: APL 초기화(목록에 추가)
  7. 변경 사항을 저장하고 규칙에 게시합니다.

Launch 사용자 지정 코드 편집기를 사용하여 플러그인 설치

플러그인 확장을 사용하지 않으려는 경우 사용자 지정 코드 편집기를 사용할 수 있습니다.
  1. AdobeID 자격 증명을 사용하여 launch.adobe.com 에 로그인합니다.
  2. 원하는 속성을 클릭합니다.
  3. 확장 탭으로 이동한 다음, Adobe Analytics 확장 아래의 구성 단추를 클릭합니다.
  4. 사용자 지정 코드를 사용하여 추적 구성 아코디언을 확장합니다. 그러면 편집기 열기 단추가 표시됩니다.
  5. 사용자 지정 코드 편집기를 열고 아래에 제공된 플러그인 코드를 편집 창에 붙여 넣습니다.
  6. 변경 사항을 저장하고 Analytics 확장에 게시합니다.

AppMeasurement를 사용하여 플러그인 설치

Analytics 추적 개체가 인스턴스화( s_gi 사용)된 후 AppMeasurement 파일의 아무 곳에나 다음 코드를 복사하여 붙여 넣으십시오. 구현에서 코드의 주석 및 버전 번호를 보존하면 Adobe에서 잠재적인 문제를 해결하는 데 도움이 됩니다.
/******************************************* BEGIN CODE TO DEPLOY *******************************************/
/* Adobe Consulting Plugin: apl (appendToList) v3.2 (Requires inList v2.0 or higher) */
s.apl=function(lv,vta,d1,d2,cc){if(!lv||"string"===typeof lv){if("undefined"===typeof this.inList||"string"!==typeof vta||""===vta)return lv;d1=d1||",";d2=d2||d1;1==d2&&(d2=d1,cc||(cc=1));2==d2&&1!=cc&&(d2=d1);vta=vta.split(",");for(var g=vta.length,e=0;e<g;e++)this.inList(lv,vta[e],d1,cc)||(lv=lv?lv+d2+vta[e]:vta[e])}return lv};

/* Adobe Consulting Plugin: inList v2.1 */
s.inList=function(lv,vtc,d,cc){if("string"!==typeof vtc)return!1;if("string"===typeof lv)lv=lv.split(d||",");else if("object"!== typeof lv)return!1;d=0;for(var e=lv.length;d<e;d++)if(1==cc&&vtc===lv[d]||vtc.toLowerCase()===lv[d].toLowerCase())return!0;return!1};
/******************************************** END CODE TO DEPLOY ********************************************/

플러그인 사용

apl 메서드에서는 다음 인수를 사용합니다.
  • lv (필수, 문자열): 구분 기호로 구분된 항목 목록을 포함하여 새 값을 추가할 변수입니다.
  • vta (필수, 문자열): lv 인수 값에 추가할 새 값들을 쉼표로 구분한 목록입니다.
  • d1 (선택 사항, 문자열): lv 인수에 이미 포함되어 있는 개별 값을 구분하는 데 사용되는 구분 기호입니다. 설정하지 않으면 기본값이 쉼표( , )로 설정됩니다.
  • d2 (선택 사항, 문자열): 출력 구분 기호입니다. 설정하지 않으면 기본값이 d1 과 동일한 값으로 설정됩니다.
  • cc (선택 사항, 부울): 대/소문자 검사를 사용하는지 여부를 나타내는 플래그입니다. true 면 중복 검사는 대/소문자를 구분합니다. false 거나 설정되지 않으면 중복 검사는 대/소문자를 구분하지 않습니다. 기본값은 false 입니다.
apl 메서드는 lv 인수의 값과 vta 인수에 있는 중복되지 않은 값을 반환합니다.

호출 예

예 #1

...
s.events = "event22,event24";

...이고, 다음 코드가 실행되면...
s.events = s.apl(s.events, "event23");

...s.events의 최종 값은 다음과 같습니다.
s.events = "event22,event24,event23";

예 #2

...
s.events = "event22,event23";

...이고, 다음 코드가 실행되면...
s.events = s.apl(s.events, "event23");

...s.events의 최종 값은 여전히 다음과 같습니다.
s.events = "event22,event23";

이 예에서 s.events은 이미 "event23"을 포함했으므로 apl 호출을 수행해도 s.events에 변화가 생기지 않았습니다.

예 #3

...
s.events = ""; //blank value

...이고, 다음 코드가 실행되면...
s.events = s.apl(s.events, "event23");

...s.events의 최종 값은 다음과 같습니다.
s.events = "event23";

예 #4

...
s.prop4 = "hello|people";

...이고, 다음 코드가 실행되면...
s.eVar5 = s.apl(s.prop4, "today", "|");

...s.prop4의 최종 값은 여전히 다음과 같습니다.
s.prop4 = "hello|people";

...하지만 s.eVar5의 최종 값은 다음과 같습니다.
s.eVar5 = "hello|people|today";

플러그인은 값을 반환한다는 점만 기억하십시오. lv 인수를 통해 전달된 변수를 반드시 "재설정"하지는 않습니다.

예 #5

...
s.prop4 = "hello|people";

...이고, 다음 코드가 실행되면...
s.prop4 = s.apl(s.prop4, "today");

...s.prop4의 최종 값은 다음과 같습니다.
s.prop4 = "hello|people,today";

lv 인수의 값에 있는 내용과 d1/d2 인수에 있는 내용 간에 구분 기호는 반드시 일관되게 유지하십시오.

예 #6

...
s.events = "event22,event23";

...이고, 다음 코드가 실행되면...
s.events = s.apl(s.events,"EVenT23", ",", ",", true);

...s.events의 최종 값은 다음과 같습니다.
s.events = "event22,event23,EVentT23";

이 예는 실용적이지 않지만 대/소문자를 구분하는 플래그를 사용할 때 주의할 필요가 있음을 보여 줍니다.

예 #7

...
s.events = "event22,event23";

...이고, 다음 코드가 실행되면...
s.events = s.apl(s.events, "event23,event24,event25");

...s.events의 최종 값은 다음과 같습니다.
s.events = "event22,event23,event24,event25");

event23이 s.events에 이미 있으므로 플러그인은 이 값을 s.events에 추가하지 않습니다. 그러나 event24와 event25는 모두 이전에 s.events에 포함되지 않았으므로 s.events에 추가합니다.

예 #8

...
s.linkTrackVars = "events,eVar1";

...이고, 다음 코드가 실행되면...
s.linkTrackVars = s.apl(s.linkTrackVars, "campaign", ",", ",", false);

...s.linkTrackVars의 최종 값은 다음과 같습니다.
s.linkTrackVars = "events,eVar1,campaign";

이 apl 호출의 끝에 있는 마지막 세 개의 인수(즉, ",", ",", false)는 필요하지 않지만, 기본 인수 값과 일치하므로 설정해도 "아무런 해가" 되지 않습니다.

예 #9

...
s.events = "event22,event24";

...이고, 다음 코드가 실행되면...
s.apl(s.events, "event23");

...s.events의 최종 값은 여전히 다음과 같습니다.
s.events = "event22,event24";

반환 값을 변수에 지정하지 않고 플러그인을 실행해도 실제로 lv 인수를 통해 전달된 변수가 "재설정"되지는 않습니다.

예 #10

...
s.list2 = "casesensitivevalue|casesensitiveValue"

...이고, 다음 코드가 실행되면...
s.list2 = s.apl(s.list2, "CasESensiTiveValuE", "|", "-", true);

...s.list2의 최종 값은 다음과 같습니다.
s.list2 = "casesensitivevalue-casesensitiveValue-CasESensiTiveValuE"

두 구분 기호 인수가 다르므로 전달된 값은 첫 번째 구분 기호 인수(“|”)로 구분된 다음, 두 번째 구분 기호 인수(“-“)에 의해 함께 결합됩니다.

버전 기록

3.2(2019년 9월 25일)

  • 이 플러그인의 이전 버전을 사용한 apl 호출의 호환성 문제를 해결했습니다.
  • 콘솔 경고를 제거하여 크기를 줄였습니다.
  • inList 2.1 을 추가했습니다.

3.1(2018년 4월 22일)

  • d2 인수는 설정되지 않은 경우 기본값이 d1 인수의 값으로 설정됩니다.

3.0(2018년 4월 16일)

  • 전체 플러그인 분석/다시 작성
  • 고급 오류 검사를 추가했습니다.
  • vta 인수가 이제 여러 값을 한 번에 허용합니다.
  • 반환 값의 형식을 지정하는 d2 인수를 추가했습니다.
  • cc 인수를 부울로 변경했습니다.

2.5(2016년 2월 18일)

  • 이제 비교 처리를 위해 inList 메서드를 사용합니다.

2.0(2016년 1월 26일)

  • d (구분 기호) 인수는 이제 선택 사항입니다(기본값: 쉼표).
  • u (대/소문자 구분 플래그) 인수는 이제 선택 사항입니다(기본값: 대/소문자를 구분하지 않음).
  • u (대/소문자 구분 플래그) 인수에 관계없이, 목록에 값이 이미 있으면 플러그인이 값을 목록에 더 이상 추가하지 않습니다.