Основные API
Используются в изолированном скрипте JavaScript для создания пользовательских шаблонов Google Менеджера тегов. Всегда добавляются с оператором require()
. Пример:
const myAPI = require('myAPI');
addConsentListener
Регистрирует функцию прослушивателя, которая выполняется при изменении состояния указанного типа согласия.
Этот прослушиватель будет вызываться каждый раз, когда состояние для указанного типа согласия меняется с denied (отклонено) на granted (предоставлено) или наоборот. Тип согласия без состояния считается предоставленным. Прослушиватель не будет вызываться, если неустановленный тип согласия изменился на granted. Функции прослушивателя будут отвечать за то, чтобы код запускался столько раз, сколько требуется.
Пример:
const isConsentGranted = require('isConsentGranted');
const addConsentListener = require('addConsentListener');
if (!isConsentGranted('ad_storage')) {
let wasCalled = false;
addConsentListener('ad_storage', (consentType, granted) => {
if (wasCalled) return;
wasCalled = true;
const cookies = getMyCookies();
sendFullPixel(cookies);
});
}
Синтаксис
addConsentListener(consentType, listener)
Параметры
Параметр | Тип | Описание |
---|---|---|
consentType |
string | Тип согласия для отслеживания изменений состояния. |
listener |
function | Функция, которая выполняется при изменении состояния указанного типа согласия. |
При вызове прослушивателя ему передается изменяемый тип согласия и новое значение этого типа:
Параметр | Тип | Описание |
---|---|---|
consentType |
string | Изменяемый тип согласия. |
granted |
boolean | Логическое значение, которое принимает значение true, если указанный тип согласия меняется на granted. |
Связанные разрешения
Разрешение access_consent
с доступом на чтение для типа согласия.
addEventCallback
API addEventCallback
позволяет зарегистрировать функцию обратного вызова, которая будет выполняться в конце события. Функция вызывается после выполнения всех тегов события или по истечении времени ожидания для события на странице.
В обратном вызове передаются два значения: идентификатор контейнера, вызывающего функцию, и объект с информацией о событии.
Синтаксис
addEventCallback(callback)
Параметры
Параметр | Тип | Описание |
---|---|---|
callback |
function | Функция, вызываемая в конце события. |
Объект eventData
содержит следующие данные:
Название ключа | Тип | Описание |
---|---|---|
tags |
Array | Массив объектов с данными о тегах. Содержит записи о каждом теге, активированном во время события. Объект с данными о теге имеет такую структуру: идентификатор тега (id ), статус его выполнения (status ), время выполнения (executionTime ) и дополнительные метаданные, настроенные в теге. |
Пример
addEventCallback(function(ctid, eventData) {
logToConsole('Tag count for container ' + ctid + ': ' + eventData['tags'].length);
});
Связанные разрешения
aliasInWindow
API aliasInWindow
позволяет создать псевдоним (например, window.foo =
window.bar
), который требуется для некоторых тегов. Присваивает значение объекта window
, указанное в параметре fromPath
, ключу в объекте window
, который указан в toPath
. Если операция прошла успешно, возвращает true
, в противном случае – false
.
Синтаксис
aliasInWindow(toPath, fromPath)
Параметры
Параметр | Тип | Описание |
---|---|---|
toPath |
string | Разделенный точками путь к объекту window , в который копируется значение. Все части пути в объекте window должны уже существовать. |
fromPath |
string | Путь к копируемому значению window , разделенный точками. Если значение не существует, операция выполнена не будет. |
Пример
aliasInWindow('foo.bar', 'baz.qux')
Связанные разрешения
Разрешение access_globals
обязательно для параметров toPath
и fromPath
. Для toPath
требуется доступ с правом записи, а для fromPath
– чтения.
callInWindow
Позволяет вызывать функции по указанному пути вне объекта window
в соответствии с правилами. Вызывает в объекте window
функцию с заданными аргументами, находящуюся по указанному пути, и возвращает значение. Если возвращаемое значение нельзя прямо сопоставить с типом, поддерживаемым в тестовой среде JavaScript, то возвращается значение undefined
. Поддерживаемые типы переменных: null
, undefined
, boolean
, number
, string
, Array
, Object
и function
. Если заданный путь не существует или не указывает на функцию, возвращается значение undefined
.
Синтаксис
callInWindow(pathToFunction, argument [, argument2,... argumentN])
Параметры
Параметр | Тип | Описание |
---|---|---|
pathToFunction |
string | Путь, разделенный точками, к вызываемой функции в объекте window . |
args |
* | Аргументы, передаваемые в функцию. |
Связанные разрешения
Разрешение access_globals
с доступом execute
.
callLater
Позволяет запланировать асинхронный вызов функции. Функция будет вызвана после выполнения текущего кода. Это эквивалентно setTimeout(<function>, 0)
.
Синтаксис
callLater(function)
Параметры
Параметр | Тип | Описание |
---|---|---|
function |
function | Вызываемая функция. |
copyFromDataLayer
Возвращает текущее значение ключа на уровне данных, если оно примитивного типа, является функцией или литералом объекта. В противном случае возвращается значение undefined
.
Синтаксис
copyFromDataLayer(key[, dataLayerVersion])
Параметры
Параметр | Тип | Описание |
---|---|---|
key |
string | Ключ в формате "a.b.c". |
dataLayerVersion |
number | Необязательная версия уровня данных. Значение по умолчанию – 2. Указывать значение "1" не рекомендуется. |
Связанные разрешения
copyFromWindow
Копирует переменную из объекта window
. Если значение из объекта window
невозможно прямо сопоставить с типом, который поддерживает изолированный JavaScript, возвращается значение undefined
. Поддерживаемые типы переменных: null
, undefined
, boolean
, number
, string
, Array
, Object
и function
.
Результат представляет собой полученное значение, приведенное к поддерживаемому типу переменных.
Синтаксис
copyFromWindow(key)
Параметры
Параметр | Тип | Описание |
---|---|---|
key |
string | Ключ в объекте window , из которого нужно скопировать значение. |
Связанные разрешения
createArgumentsQueue
Создает очередь, заполняемую объектами аргументов, которая требуется некоторым решениям для тегов.
Создает функцию в глобальном контексте (window
) с помощью аргумента fnKey
. Используется та же семантика, что и для метода createQueue
. После создания функции API добавляет в объект window
массив (если его ещё там нет) с помощью аргумента arrayKey
.
Когда вызывается функция, созданная с помощью fnKey
, она передает объект этого аргумента в массив, созданный в arrayKey
. API возвращает значение, которое представляет собой функцию, созданную в fnKey
.
Для этой функции необходимо задать настройки чтения и записи fnKey
и arrayKey
в разрешении access_globals
.
Пример:
const gtag = createArgumentsQueue('gtag', 'dataLayer');
gtag('set', {'currency': 'USD'});
Синтаксис
createArgumentsQueue(fnKey, arrayKey)
Параметры
Параметр | Тип | Описание |
---|---|---|
fnKey |
string | Путь в объекте window , где находится или будет создана функция. Аргумент поддерживает стандартную точечную нотацию. Если путь к ключу не существует, выдается исключение. Например, исключение будет выдано, если аргументу fnKey присвоить значение 'one.two' . |
arrayKey |
string | Путь в объекте window , где находится или будет создан массив. Аргумент поддерживает стандартную точечную нотацию. Если путь к ключу не существует, выдается исключение. Например, исключение будет выдано, если аргументу arrayKey присвоить значение 'one.two' , но глобального объекта с названием 'one' не существует. |
Связанные разрешения
createQueue
Создает массив в объекте window
(если он ещё не существует) и возвращает функцию, которая передает значения в этот массив.
Для этой функции необходимо задать настройки чтения и записи аргумента arrayKey
в разрешении access_globals
.
Пример:
const dataLayerPush = createQueue('dataLayer');
dataLayerPush({'currency': 'USD'}, {'event': 'myConversion'});
Синтаксис
createQueue(arrayKey)
Параметры
Параметр | Тип | Описание |
---|---|---|
arrayKey |
string | Ключ в объекте window , где находится или будет создан массив. Аргумент поддерживает стандартную точечную нотацию. Если путь к ключу не существует, выдается исключение. Например, исключение будет выдано, если аргументу arrayKey присвоить значение 'one.two' , но глобального объекта с названием 'one' не существует. |
Связанные разрешения
decodeUri
Декодирует любые закодированные символы в предоставленном URI. Возвращает строку с расшифрованным компонентом URI. Если входные данные недействительны, возвращает значение undefined
.
Пример:
const decode = require('decodeUri');
const decodedUrl = decode(data.encodedUrl);
if (decodedUrl) {
// ...
}
Синтаксис
decodeUri(encoded_uri)
Параметры
Параметр | Тип | Описание |
---|---|---|
encoded_uri |
string | URI, закодированный с помощью функции encodeUri() или другими методами. |
Связанные разрешения
Нет.
decodeUriComponent
Декодирует любые закодированные символы в предоставленном компоненте URI. Возвращает строку с расшифрованным компонентом URI. Возвращает значение undefined
в случае ввода неправильных данных.
Пример:
const decode = require('decodeUriComponent');
const decodedUrl = decode(data.encodedUrl);
if (decodedUrl) {
// ...
}
Синтаксис
decodeUriComponent(encoded_uri_component)
Параметры
Параметр | Тип | Описание |
---|---|---|
encoded_uri_component |
string | Компонент URI, закодированный с помощью функции encodeUriComponent() или другими методами. |
Связанные разрешения
Нет.
encodeUri
Возвращает закодированный унифицированный идентификатор ресурса (URI) с экранированными специальными символами. Возвращаемая строка представляет собой результат кодирования полученной строки в формат URI.
Пример:
sendPixel('https://www.example.com/' + encodeUri(pathInput));
Синтаксис
encodeUri(uri)
Параметры
Параметр | Тип | Описание |
---|---|---|
uri |
string | Полный URI. |
Связанные разрешения
Нет.
encodeUriComponent
Возвращает закодированный унифицированный идентификатор ресурса (URI) с экранированными специальными символами. Возвращаемая строка представляет собой результат кодирования полученной строки в формат URI.
Пример:
sendPixel('https://www.example.com/?' + encodeUriComponent(queryInput));
Синтаксис
encodeUriComponent(str)
Параметры
Параметр | Тип | Описание |
---|---|---|
str |
string | Компонент URI. |
Связанные разрешения
Нет.
fromBase64
API fromBase64
позволяет расшифровывать строки, представленные в кодировке base64. Возвращает значение undefined
в случае ввода неправильных данных.
Синтаксис
fromBase64(base64EncodedString)
Параметры
Параметр | Тип | Описание |
---|---|---|
base64EncodedString |
string | Строка в кодировке Base64. |
Пример
const fromBase64 = require('fromBase64');
const greeting = fromBase64('aGVsbG8=');
if (greeting === 'hello') {
// ...
}
Связанные разрешения
Нет
generateRandom
Возвращает случайное целое число из заданного диапазона.
Синтаксис
generateRandom(min, max)
Параметры
Параметр | Тип | Описание |
---|---|---|
min |
number | Минимальное значение диапазона. |
max |
number | Максимальное значение диапазона. |
Связанные разрешения
Нет.
getContainerVersion
Возвращает объект с данными о текущем контейнере. Объект содержит следующие поля:
{
containerId: string,
debugMode: boolean,
environmentName: string,
environmentMode: boolean,
previewMode: boolean,
version: string,
}
Пример
const getContainerVersion = require('getContainerVersion');
const sendPixel = require('sendPixel');
if (query('read_container_data')) {
const cv = getContainerVersion();
const pixelUrl = 'https://pixel.com/' +
'?version=' + cv.version +
'&envName=' + cv.environmentName +
'&ctid=' + cv.containerId +
'&debugMode=' + cv.debugMode +
'&previewMode=' + cv.previewMode;
if (query('send_pixel', pixelUrl)) {
sendPixel(pixelUrl);
}
}
Синтаксис
getContainerVersion();
Связанные разрешения
getCookieValues
Возвращает значения всех файлов cookie с указанным именем.
Синтаксис
getCookieValues(name[, decode])
Параметры
Параметр | Тип | Описание |
---|---|---|
name |
string | Имя файла cookie. |
decode |
boolean | Определяет, следует ли декодировать значения файлов cookie с помощью метода JavaScript decodeURIComponent() . Значение по умолчанию – true . |
Связанные разрешения
getQueryParameters
Возвращает первый или все параметры для ключа queryKey
текущего URL.
Возвращает первое значение ключа queryKey
или массив значений queryKey
.
Синтаксис
getQueryParameters(queryKey[, retrieveAll])
Параметры
Параметр | Тип | Описание |
---|---|---|
queryKey |
string | Ключ для считывания параметров запроса. |
retrieveAll |
boolean | Определяет, получать ли все значения. |
Например, для текущего URL https://example.com/path?var=foo&var1=foo1&var=foo2&var=foo
будут получены следующие значения:
getQueryParameters('var') == 'foo'
getQueryParameters('var', false) == 'foo'
getQueryParameters('var', null) == 'foo'
getQueryParameters('var', true) == ['foo', 'foo2', 'foo']
Связанные разрешения
В разрешении get_url
должен быть допущен компонент query
, а в числе разрешенных ключей запроса должен быть указан queryKey
(или разрешены все ключи).
getReferrerQueryParameters
API getReferrerQueryParameters
действует так же, как и getQueryParameters
, но применяется не к текущему URL, а к URL перехода. Возвращает первый или все параметры для ключа queryKey
URL перехода. Возвращает первое значение ключа queryKey
или массив значений queryKey
.
Синтаксис
getReferrerQueryParameters(queryKey[, retrieveAll])
Параметры
Параметр | Тип | Описание |
---|---|---|
queryKey |
string | Ключ для считывания параметров запроса. |
retrieveAll |
boolean | Определяет, получать ли все значения. |
Например, для URL перехода https://example.com/path?var=foo&var1=foo1&var=foo2&var=foo
будут получены следующие значения:
getReferrerQueryParameters('var') == 'foo'
getReferrerQueryParameters('var', false) == 'foo'
getReferrerQueryParameters('var', null) == 'foo'
getReferrerQueryParameters('var', true) == ['foo', 'foo2', 'foo']
Связанные разрешения
В разрешении get_referrer
должен быть допущен компонент query
, а в числе разрешенных ключей запроса должен быть указан queryKey
(или разрешены все ключи).
getReferrerUrl
Учитывая тип компонента, API читает объект документа для URL перехода и возвращает строку, которая представляет собой фрагмент URL перехода. Если компонент не задан, возвращается полный URL перехода.
Синтаксис
getReferrerUrl([component])
Параметры
Параметр | Тип | Описание |
---|---|---|
component |
string | Возвращаемый компонент URL. Допустимые типы: protocol , host , port , path , query , extension . Если component имеет значение undefined , null или не совпадает с допустимыми типами, возвращается полный URL. |
Связанные разрешения
В разрешении get_referrer
должен быть допущен компонент query
, а в числе разрешенных ключей запроса должен быть указан queryKey
(или разрешены все ключи).
getTimestamp
Поддержка прекращена. Предпочитаемый API – getTimestampMillis.
Выводит число с текущим Unix-временем в миллисекундах, возвращенным функцией Date.now()
.
Синтаксис
getTimestamp();
Связанные разрешения
Нет.
getTimestampMillis
Выводит число с текущим Unix-временем в миллисекундах, возвращенным функцией Date.now()
.
Синтаксис
getTimestampMillis();
Связанные разрешения
Нет.
getType
Возвращает строку, описывающую тип значения. В отличие от typeof
, getType
различает array
и object
.
Синтаксис
getType(data.someField)
Примечания
В таблице ниже показаны строки, возвращаемые для каждого введенного значения.
Значение | Результат |
---|---|
undefined |
undefined |
null |
null |
true |
boolean |
12 |
number |
'string' |
string |
{ a: 3 } |
object |
[ 1, 3 ] |
array |
(x) => x + 1 |
function |
Связанные разрешения
Нет.
getUrl
Возвращает строку, которая представляет собой полный текущий URL или его часть (в зависимости от определенного в запросе компонента), а также некоторые параметры конфигурации URL.
Синтаксис
getUrl(component)
Параметры
Параметр | Тип | Описание |
---|---|---|
component |
string | Возвращаемый компонент URL. Допустимые типы: protocol , host , port , path , query , extension , fragment . Если компонент имеет значение undefined , null или не совпадает с допустимыми типами, возвращается полный атрибут href . |
Связанные разрешения
injectHiddenIframe
Добавляет на страницу невидимое окно iframe.
Обратные вызовы имеют вид экземпляров функции, упакованных в осуществляющие вызовы функции JavaScript.
Синтаксис
injectHiddenIframe(url, onSuccess)
Параметры
Параметр | Тип | Описание |
---|---|---|
url |
string | URL, используемый в качестве значения атрибута src окна iframe. |
onSuccess |
function | Вызывается при успешной загрузке окна iframe. |
Связанные разрешения
injectScript
Добавляет на страницу тег скрипта для асинхронной загрузки предоставленного URL. Обратные вызовы имеют вид экземпляров функции, упакованных в осуществляющие вызовы функции JavaScript.
Синтаксис
injectScript(url, onSuccess, onFailure[, cacheToken])
Параметры
Параметр | Тип | Описание |
---|---|---|
url |
string | Адрес добавляемого скрипта. |
onSuccess |
function | Вызывается при успешной загрузке скрипта. |
onFailure |
function | Вызывается при ошибке загрузки скрипта. |
cacheToken |
string | Необязательная строка, которая указывает, что предоставленный URL необходимо кешировать. Если задать это значение, для запроса JavaScript будет создан только один элемент скрипта. Последующие попытки загрузки приведут к тому, что методы onSuccess и onFailure будут помещены в очередь, пока не загрузится скрипт. |
Связанные разрешения
isConsentGranted
Возвращает true, если согласие предоставлено.
Согласие для определенного типа считается предоставленным, если для него задано значение granted или не задано никакого. При любых других вариантах значений согласие не считается предоставленным.
Пользовательский интерфейс Менеджера тегов для настроек тега предлагает вариант с постоянной активацией. Если тег с постоянной активацией использует этот API, согласие считается предоставленным и true
возвращается независимо от фактического состояния согласия.
Пример:
const isConsentGranted = require('isConsentGranted');
if (isConsentGranted('ad_storage')) {
sendFullPixel();
} else {
sendPixelWithoutCookies();
}
Синтаксис
isConsentGranted(consentType)
Параметры
Параметр | Тип | Описание |
---|---|---|
consentType |
string | Тип согласия, состояние которого нужно проверить. |
Связанные разрешения
Разрешение access_consent
с доступом на чтение для типа согласия.
JSON
Возвращает объект с функциями JSON.
Функция parse()
анализирует строку JSON и создает описанный в ней объект или значение. Если строка JSON не поддается анализу (например, из-за неверного формата), возвращается значение undefined
. А если тип входных данных – не string, они автоматически преобразуются в строку.
Функция stringify()
преобразует входные данные в строку JSON. Если она не поддается анализу (например, потому что содержит цикл), возвращается значение undefined
.
Синтаксис
JSON.parse(stringInput)
JSON.stringify(value);
Параметры
JSON.parse
Параметр | Тип | Описание |
---|---|---|
stringInput | любой | Конвертируемое значение. Если значение не является строкой, оно автоматически преобразуется в строку. |
JSON.stringify
Параметр | Тип | Описание |
---|---|---|
значение | любой | Конвертируемое значение. |
Пример
const JSON = require('JSON');
// The JSON input string is converted to an object.
const object = JSON.parse('{"foo":"bar"}');
// The input object is converted to a JSON string.
const str = JSON.stringify({foo: 'bar'});
localStorage
Возвращает объект с методами для доступа к локальному хранилищу.
Синтаксис
const localStorage = require('localStorage');
// Requires read access for the key. Returns null if the key does not exist.
localStorage.getItem(key);
// Requires write access for the key. Returns true if successful.
localStorage.setItem(key, value);
// Requires write access for the key.
localStorage.removeItem(key);
Связанные разрешения
Пример
const localStorage = require('localStorage');
if (localStorage) {
const value = localStorage.getItem('my_key');
if (value) {
const success = localStorage.setItem('my_key', 'new_value');
if (success) {
localStorage.removeItem('my_key');
}
}
}
logToConsole
Регистрирует аргументы в консоли браузера.
Синтаксис
logToConsole(obj1 [, obj2,... objN])
Параметры
Параметр | Тип | Описание |
---|---|---|
obj1 [, obj2,... objN] |
любой | Аргументы |
Связанные разрешения
makeInteger
Конвертирует указанное значение в целое число.
Синтаксис
makeInteger(value)
Параметры
Параметр | Тип | Описание |
---|---|---|
value |
любой | Конвертируемое значение. |
Связанные разрешения
Нет.
makeNumber
Конвертирует указанное значение в число.
Синтаксис
makeNumber(value)
Параметры
Параметр | Тип | Описание |
---|---|---|
value |
любой | Конвертируемое значение. |
Связанные разрешения
Нет.
makeString
Возвращает указанное значение в виде строки.
Синтаксис
makeString(value)
Параметры
Параметр | Тип | Описание |
---|---|---|
value |
любой | Конвертируемое значение. |
Связанные разрешения
Нет.
makeTableMap
Преобразует простую таблицу из двух столбцов в массив Map
. Используется для преобразования полей шаблона SIMPLE_TABLE
в более удобный для работы формат.
Например, так могут выглядеть данные в таблице до преобразования:
[
{'key': 'k1', 'value': 'v1'},
{'key': 'k2', 'value': 'v2'}
]
А так будут выглядеть те же самые данные в виде массива:
{
'k1': 'v1',
'k2': 'v2'
}
Возвращаемый объект: ассоциативный массив Map
(если в него при преобразовании были добавлены пары "ключ-значение") или значение null
.
Синтаксис
makeTableMap(tableObj, keyColumnName, valueColumnName)
Параметры
Параметр | Тип | Описание |
---|---|---|
tableObj |
List | Таблица, которую нужно преобразовать. Представляет собой список массивов, в котором каждому объекту Map соответствует одна строка в таблице. Имена свойств в строках являются названиями столбцов, а значения этих свойств – значениями столбцов в строке. |
keyColumnName |
string | Название столбца, значения из которого станут ключами в полученном массиве Map . |
valueColumnName |
string | Название столбца, значения из которого станут значениями в полученном массиве Map . |
Связанные разрешения
Нет.
Math
Объект, предоставляющий математические функции Math
.
Синтаксис
const Math = require('Math');
// Retrieve the absolute value.
const absolute = Math.abs(-3);
// Round the input down to the nearest integer.
const roundedDown = Math.floor(3.6);
// Round the input up to the nearest integer.
const roundedUp = Math.ceil(2.2);
// Round the input to the nearest integer.
const rounded = Math.round(3.1);
// Return the largest argument.
const biggest = Math.max(1, 3);
// Return the smallest argument.
const smallest = Math.min(3, 5);
// Return the first argument raised to the power of the second argument.
const powerful = Math.pow(3, 1);
// Return the square root of the argument.
const unsquared = Math.sqrt(9);
Параметры
Параметры математических функций преобразуются в числа.
Связанные разрешения
Нет.
parseUrl
Возвращает объект, содержащий все части предоставленного URL, и похож на объект URL
.
Если формат URL неверный, этот API будет возвращать код undefined
. При правильном формате URL поля, отсутствующие в строке URL, будут иметь значение пустой строки, а при использовании searchParams
– пустой объект.
Объект содержит следующие поля:
{
href: string,
origin: string,
protocol: string,
username: string,
password: string,
host: string,
hostname: string,
port: string,
pathname: string,
search: string,
searchParams: Object<string, (string|Array)>,
hash: string,
}
Пример
const parseUrl = require('parseUrl');
const urlObject = parseUrl('https://abc:xyz@example.com:8080/foo?param=val%2Cue#bar');
Синтаксис
parseUrl(url);
Параметры
Параметр | Тип | Описание |
---|---|---|
url |
string | Полный URL для анализа. |
Связанные разрешения
Нет.
queryPermission
Запрашивает предоставленные и ограниченные разрешения. Возвращает логическое значение: true
, если разрешение предоставлено, и false
, если нет.
Синтаксис
queryPermission(permission, functionArgs*)
Параметры
Параметр | Тип | Описание |
---|---|---|
permission |
string | Название разрешения. |
functionArgs |
любой | Аргументы функции зависят от запрашиваемого разрешения (см. раздел Аргументы функции ниже). |
Аргументы функции
sendPixel
, injectScript
, injectHiddenIframe
. Второй параметр представляет собой строку URL.
writeGlobals
, readGlobals
. Второй параметр представляет собой ключ для записи или чтения.
readUrl
. Для запроса разрешения на чтение целого URL дополнительные аргументы указывать не нужно. Если вы запрашиваете разрешение на чтение определенного компонента, передайте его название в качестве второго аргумента:
if (queryPermission('readUrl','port')) {
// read the port
}
Чтобы проверить, читается ли ключ запроса, передайте его в качестве третьего аргумента:
if (queryPermission('readUrl','query','key')) {
getUrlComponent(...);
}
Связанные разрешения
Нет.
readCharacterSet
Возвращает значение document.characterSet
.
Синтаксис
readCharacterSet()
Параметры
Нет.
Связанные разрешения
readTitle
Возвращает значение document.title
.
Синтаксис
readTitle()
Параметры
Нет.
Связанные разрешения
require
Импортирует встроенную функцию по ее названию. Возвращает функцию или объект, которые можно вызывать в вашей программе. Возвращает значение undefined (нет данных), если браузер не поддерживает встроенную функцию.
Синтаксис
require(name)
Параметры
Параметр | Тип | Описание |
---|---|---|
name |
string | Название импортируемой функции. |
Пример
const getUrl = require('getUrl');
const url = getUrl();
Связанные разрешения
Нет.
sendPixel
Отправляет запрос GET в конечную точку заданного URL.
Синтаксис
sendPixel(url, onSuccess, onFailure)
Параметры
Параметр | Тип | Описание |
---|---|---|
url |
string | Куда передавать пиксель. |
onSuccess |
function | Вызывается при успешной отправке пикселя. |
onFailure |
function | Вызывается при ошибке отправки пикселя. |
Связанные разрешения
setCookie
Создает или удаляет файл cookie с указанным именем, значением и параметрами.
Синтаксис
setCookie(name, value[, options, encode])
Параметры
Параметр | Тип | Описание |
---|---|---|
name |
string | Имя файла cookie. |
value |
string | Значение файла cookie. |
options |
object | Определяет следующие атрибуты: Domain, Path, Expires, Max-Age, Secure, SameSite (см. раздел Дополнительные параметры ниже). |
encode |
boolean | Определяет, кодировать ли значение файла cookie с помощью метода JavaScript encodeURIComponent() .
Значение по умолчанию – true . |
- Domain. Задается свойством
options['domain']
, если оно есть. Укажите значение'auto'
, чтобы создать файл cookie, используя максимально широкий домен с учетом того, где находится документ. Если это не удастся, попытки будут последовательно повторяться со все более узкими субдоменами. Если все попытки закончатся неудачей, функция попытается создать файл cookie без домена. Если значение этого свойства не указано, функция также попытается создать файл cookie без домена. Примечание: если в свойствеdocument.cookie
указан файл cookie без домена, то агент пользователя по умолчанию использует для этого файла cookie домен, в котором размещен текущий документ. - Path. Задается свойством
options['path']
, если оно есть. Если в свойствеdocument.cookie
указан файл cookie без пути, агент пользователя будет по умолчанию применять путь текущего местоположения документа. - Max-Age. Задается свойством
options['max-age']
, если оно есть. - Expires. Задается свойством
options['expires']
, если оно есть. В нем указывается строковое значение даты в формате UTC. Форматировать свойствоDate
этого параметра можно с помощью методаDate.toUTCString()
. - Secure. Задается свойством
options['secure']
, если оно есть. - SameSite. Задается свойством
options['samesite']
, если оно есть.
Связанные разрешения
setDefaultConsentState
Устанавливает (или обновляет) состояние согласия по умолчанию на странице.
Пример:
const setDefaultConsentState = require('setDefaultConsentState');
setDefaultConsentState({
'ad_storage': 'denied',
'analytics_storage': 'granted',
'region': ['US-CA'],
'wait_for_update': 500
});
Синтаксис
setDefaultConsentState(consentSettings)
Параметры
Параметр | Тип | Описание |
---|---|---|
consentSettings |
object | Объект, определяющий состояние по умолчанию для указанных типов согласия. |
Объект consentSettings
представляет собой сопоставление строк произвольного типа согласия с 'granted'
или 'denied'
. Возможные значения:
Название ключа | Тип | Описание |
---|---|---|
consentType |
string |
Для каждого типа согласия может быть установлено значение 'granted' или 'denied' . Если значение не равно 'granted' , оно воспринимается как 'denied' . Если вы зададите значение undefined , это не повлияет на ранее указанное значение.
|
region |
Array | Необязательный массив кодов регионов, определяющих, к какому региону применяются настройки согласия. Допустимые значения – коды стран и/или административных единиц в формате ISO 3166-2. |
wait_for_update |
number | Время ожидания перед отправкой данных. Значение в миллисекундах. Используется с инструментами для запроса согласия, которые загружаются асинхронно. |
Связанные разрешения
Разрешение access_consent
с правом записи для всех типов согласия в объекте consentSettings.
setInWindow
Вводит в объекте window
заданное значение по ключу. По умолчанию данные не вводятся, если они уже есть в объекте window
. Чтобы заданное значение было введено независимо от того, пустой объект overrideExisting
или нет, присвойте параметру true
значение window
. Функция возвращает логическое значение: true
– если значение было задано успешно, и false
– если нет.
Синтаксис
setInWindow(key, value, overrideExisting)
Параметры
Параметр | Тип | Описание |
---|---|---|
key |
string | Ключ в объекте window , куда нужно ввести данные. |
value |
* | Значение задается в window . |
overrideExisting |
boolean | Вводить ли данные, независимо от того, пустой объект window или нет. |
Связанные разрешения
sha256
Вычисляет дайджест ввода SHA-256 и вызывает обратный вызов с дайджестом, закодированным в base64, если только в объекте options
не указана другая кодировка выходных данных.
Пример:
sha256('inputString', (digest) => {
sendPixel('https://example.com/collect?id=' + digest);
data.gtmOnSuccess();
}, data.gtmOnFailure);
sha256('inputString', (digest) => {
sendPixel('https://example.com/collect?id=' + digest);
data.gtmOnSuccess();
}, data.gtmOnFailure, {outputEncoding: 'hex'});
Синтаксис
sha256(input, onSuccess, onFailure = undefined, options = undefined)
Параметры
Параметр | Тип | Описание |
---|---|---|
input |
string | Строка для вычисления хеша. |
onSuccess |
function | Вызывается с полученным дайджестом, закодированным в base64, если только в объекте options не указана другая кодировка выходных данных. |
onFailure |
function | Вызывается, если при вычислении дайджеста возникает ошибка либо если в браузере нет встроенной поддержки sha256. Обратный вызов осуществляется с объектом, содержащим имя ошибки и сообщение. |
options |
object | Необязательный объект настроек, в котором можно задать кодировку выходных данных. Если объект используется, он должен содержать ключ outputEncoding со значением base64 или hex . |
Связанные разрешения
Нет.
templateStorage
Возвращает объект с методами для доступа к хранилищу шаблона. Хранилище шаблона обеспечивает обмен данными между выполнениями одного шаблона. Данные хранятся в нем в течение всего времени существования страницы.
Синтаксис
const templateStorage = require('templateStorage');
templateStorage.getItem(key);
templateStorage.setItem(key, value);
templateStorage.removeItem(key);
// Deletes all stored values for the template.
templateStorage.clear();
Связанные разрешения
Пример
const templateStorage = require('templateStorage');
const sendPixel = require('sendPixel');
// Ensure sendPixel is called only once per page.
if (templateStorage.getItem('alreadyRan')) {
data.gtmOnSuccess();
return;
}
templateStorage.setItem('alreadyRan', true);
sendPixel(
data.oncePerPagePixelUrl,
data.gtmOnSuccess,
() => {
templateStorage.setItem('alreadyRan', false);
data.gtmOnFailure();
});
toBase64
API toBase64
позволяет преобразовать строки в кодировку base64.
Синтаксис
toBase64(input)
Параметры
Параметр | Тип | Описание |
---|---|---|
input |
string | Кодируемая строка. |
Пример
const toBase64 = require('toBase64');
const base64Hello = toBase64('hello');
Связанные разрешения
Нет
updateConsentState
Обновляет состояние указанных типов согласия.
Пример:
const updateConsentState = require('updateConsentState');
updateConsentState({
'ad_storage': 'granted',
'analytics_storage': 'denied'
});
Синтаксис
updateConsentState(consentSettings)
Параметры
Параметр | Тип | Описание |
---|---|---|
consentSettings |
object | Объект, обновляющий состояние по умолчанию для указанных типов согласия. |
Объект consentSettings
представляет собой сопоставление строк произвольного типа согласия с 'granted'
или 'denied'
. Возможные значения:
Название ключа | Тип | Описание |
---|---|---|
consentType |
string |
Для каждого типа согласия может быть установлено значение 'granted' или 'denied' . Если значение не равно 'granted' , оно воспринимается как 'denied' . Если вы зададите значение undefined , это не повлияет на ранее указанное значение.
|
Связанные разрешения
Разрешение access_consent
с правом записи для всех типов согласия в объекте consentSettings.
API тестирования
Используются для создания тестов, проверяющих работу изолированного JavaScript в пользовательских шаблонах Google Менеджера тегов. Для этих API не требуется оператор require()
. Подробнее о тестировании пользовательских шаблонов…
assertApi
Возвращает объект Matcher, который можно использовать, чтобы быстро делать утверждения о конкретном API.
Синтаксис
assertApi(apiName)
Параметры
Параметр | Тип | Описание |
---|---|---|
apiName |
string | Название тестируемого API (та же строка, которая передается require() ). |
Методы сопоставления
Subject.wasCalled()
Subject.wasNotCalled()
Subject.wasCalledWith(...expected)
Subject.wasNotCalledWith(...expected)
Примеры
assertApi('sendPixel').wasCalled();
assertApi('getUrl').wasNotCalled();
assertApi('makeNumber').wasCalledWith('8');
assertApi('setInWindow').wasNotCalledWith('myVar', 'theWrongValue');
assertThat
API assertThat
смоделирован на основе библиотеки Google Truth. Он возвращает объект, с помощью которого можно проверять утверждения о значении исследуемого объекта. Если проверка утверждения дает неудачный результат, она сразу завершается и отмечается как неудачная. Впрочем, неудачный результат одной проверки не влияет на остальные.
Синтаксис
assertThat(actual, opt_message)
Параметры
Параметр | Тип | Описание |
---|---|---|
actual |
любой | Значение, которое будет использоваться для быстрой проверки. |
opt_message |
string | Необязательное сообщение, которое будет показано, если утверждение окажется неверным. |
Методы сопоставления
Метод сопоставления | Описание |
---|---|
isUndefined() |
Проверяет утверждение о том, что субъект является undefined . |
isDefined() |
Проверяет утверждение о том, что субъект не является undefined . |
isNull() |
Проверяет утверждение о том, что субъект является null . |
isNotNull() |
Проверяет утверждение о том, что субъект не является null . |
isFalse() |
Проверяет утверждение о том, что субъект является false . |
isTrue() |
Проверяет утверждение о том, что субъект является true . |
isFalsy() |
Проверяет утверждение о том, что субъект имеет ложное значение. Ложными значениями считаются undefined , null , false , NaN , 0 и '' (пустая строка). |
isTruthy() |
Проверяет утверждение о том, что субъект имеет истинное значение. Ложными значениями считаются undefined , null , false , NaN , 0 и '' (пустая строка). |
isNaN() |
Проверяет утверждение о том, что значение не является числовым. |
isNotNaN() |
Проверяет утверждение о том, что значение является любым, кроме нечислового. |
isInfinity() |
Проверяет утверждение о том, что значение является положительной или отрицательной бесконечностью. |
isNotInfinity() |
Проверяет утверждение о том, что значение является любым, кроме положительной или отрицательной бесконечности. |
isEqualTo(expected) |
Проверяет утверждение о том, что значение равно указанному. Сравниваются значения, а не ссылки. Содержимое объектов и массивов сравнивается рекурсивно. |
isNotEqualTo(expected) |
Проверяет утверждение о том, что значение субъекта не равно указанному значению. Сравниваются значения, а не ссылки. Содержимое объектов и массивов сравнивается рекурсивно. |
isAnyOf(...expected) |
Проверяет утверждение о том, что значение равно одному из указанных. Сравниваются значения, а не ссылки. Содержимое объектов и массивов сравнивается рекурсивно. |
isNoneOf(...expected) |
Проверяет утверждение о том, что значение не равно указанным. Сравниваются значения, а не ссылки. Содержимое объектов и массивов сравнивается рекурсивно. |
isStrictlyEqualTo(expected) |
Проверяет утверждение о том, что значение субъекта строго равно (=== ) указанному значению. |
isNotStrictlyEqualTo(expected) |
Проверяет утверждение о том, что значение не строго равно (!== ) указанному. |
isGreaterThan(expected) |
Проверяет утверждение о том, что значение больше (> ) указанного, согласно сравнению с учетом порядка. |
isGreaterThanOrEqualTo(expected) |
Проверяет утверждение о том, что значение больше или равно (>= ) указанному, согласно сравнению с учетом порядка. |
isLessThan(expected) |
Проверяет утверждение о том, что значение меньше (< ) указанного, согласно сравнению с учетом порядка. |
isLessThanOrEqualTo(expected) |
Проверяет утверждение о том, что значение меньше или равно (<= ) указанному, согласно сравнению с учетом порядка. |
contains(...expected) |
Проверяет утверждение о том, что значение является массивом или строкой, которые содержат все указанные значения в любом порядке. Сравниваются значения, а не ссылки. Содержимое объектов и массивов сравнивается рекурсивно. |
doesNotContain(...expected) |
Проверяет утверждение о том, что значение является массивом или строкой, которые не содержат указанные значения. Сравниваются значения, а не ссылки. Содержимое объектов и массивов сравнивается рекурсивно. |
containsExactly(...expected) |
Проверяет утверждение о том, что значение является массивом, который содержит только все указанные значения в любом порядке. Сравниваются значения, а не ссылки. Содержимое объектов и массивов сравнивается рекурсивно. |
doesNotContainExactly(...expected) |
Проверяет утверждение о том, что значение является массивом, который содержит другой набор из указанных значений в любом порядке. Сравниваются значения, а не ссылки. Содержимое объектов и массивов сравнивается рекурсивно. |
hasLength(expected) |
Проверяет утверждение о том, что значение является массивом или строкой указанной длины. Утверждение всегда будет неверным, если значение не является массивом или строкой. |
isEmpty() |
Проверяет утверждение о том, что значение является пустым массивом или строкой (длина = 0). Утверждение всегда будет неверным, если значение не является массивом или строкой. |
isNotEmpty() |
Проверяет утверждение о том, что значение является не пустым массивом или строкой (длина > 0). Утверждение всегда будет неверным, если значение не является массивом или строкой. |
isArray() |
Проверяет утверждение о том, что тип значения – массив. |
isBoolean() |
Проверяет утверждение о том, что значение является логическим. |
isFunction() |
Проверяет утверждение о том, что тип значения – функция. |
isNumber() |
Проверяет утверждение о том, что тип значения – число. |
isObject() |
Проверяет утверждение о том, что тип значения – объект. |
isString() |
Проверяет утверждение о том, что тип значения – строка. |
Примеры
assertThat(undefined).isUndefined();
assertThat(id, 'ID must be defined').isDefined();
assertThat(null).isNull();
assertThat(undefined).isNotNull();
assertThat(true).isTrue();
assertThat(false).isFalse();
assertThat(1).isTruthy();
assertThat('').isFalsy();
assertThat(1/0).isInfinity();
assertThat(0).isNotInfinity();
assertThat(-'foo').isNaN();
assertThat(100).isNotNaN();
assertThat(sentUrl).isEqualTo('https://endpoint.example.com/?account=12345');
assertThat(category).isNotEqualTo('premium');
assertThat(5).isAnyOf(1, 2, 3, 4, 5);
assertThat(42).isNoneOf('the question', undefined, 41.9);
assertThat('value').isStrictlyEqualTo('value');
assertThat('4').isNotStrictlyEqualTo(4);
assertThat(['a', 'b', 'c']).contains('a', 'c');
assertThat(['x', 'y', 'z']).doesNotContain('f');
assertThat(['1', '2', '3']).containsExactly('3', '2', '1');
assertThat(['4', '5']).doesNotContainExactly('4');
assertThat('a string').hasLength(8);
assertThat([]).isEmpty();
assertThat('another string').isNotEmpty();
fail
Незамедлительно выдает неудачу для текущего теста и выводит сообщение об ошибке, если оно предусмотрено.
Синтаксис
fail(opt_message);
Параметры
Параметр | Тип | Описание |
---|---|---|
opt_message |
string | Вариант сообщения об ошибке. |
Пример
fail('This test has failed.');
mock
API mock
позволяет изменить работу изолированных API. API имитации можно без опасений использовать в коде шаблона, однако вне режима тестирования этот API не функционирует. Черновики сбрасываются перед запуском каждого теста.
Синтаксис
mock(apiName, returnValue);
Параметры
Параметр | Тип | Описание |
---|---|---|
apiName |
string | Название имитируемого API (та же строка, которая передается require() ). |
returnValue |
любой | Значение, возвращаемое для API или функции, которая вызывается вместо этого API. Если returnValue представляет собой функцию, то она вызывается вместо изолированного API; если же returnValue не является функцией, то вместо изолированного API возвращается это значение. |
Примеры
mock('encodeUri', "https://endpoint.example.com/?account=12345");
mock('sendPixel', function(url, onSuccess, onFailure) {
onSuccess();
});
runCode
Выполняет код для шаблона, т. е. содержание вкладки Код, в текущей тестовой среде с указанным объектом входных данных.
Синтаксис
runCode(data)
Параметры
Параметр | Тип | Описание |
---|---|---|
data |
object | Объект данных, который будет использоваться в тесте. |
Возвращаемое значение
Возвращает значение переменной для шаблонов переменных; для всех остальных типов шаблонов возвращает undefined
.
Пример
runCode({field1: 123, field2: 'value'});