Riferimenti campo concept_fkj_ll5_dgb

Un riferimento di campo può essere allegato a un evento o a un gruppo di campi. L’unica informazione significativa è il nome del campo e il relativo percorso.

Se in un campo si utilizzano caratteri speciali, è necessario utilizzare virgolette doppie o semplici. Di seguito sono riportati i casi in cui sono necessarie virgolette:

  • il campo inizia con caratteri numerici
  • il campo inizia con il carattere "-"
  • il campo contiene elementi diversi da: a-z, A-Z, 0-9, _ , -

Ad esempio, se il campo è 3 ore: #{OpenWeather.weatherData.rain.'3h'} > 0

// event field
@{<event name>.<XDM path to the field>}
@{LobbyBeacon.endUserIDs._experience.emailid.id}

// field group
#{<data source name>.<field group name>.<path to the field>}
#{ExperiencePlatform.ProfileFieldGroup.profile.personalEmail.address}

Nell’espressione, ai campi evento viene fatto riferimento con "@" e ai campi dell’origine dati viene fatto riferimento con "#".

Un colore di sintassi viene utilizzato per distinguere visivamente i campi degli eventi (verde) dai gruppi di campi (blu).

Valori predefiniti per riferimenti campo default-value

Un valore predefinito può essere associato a un nome di campo. La sintassi è la seguente:

// event field
@{<event name>.<XDM path to the field>, defaultValue: <default value expression>}
@{LobbyBeacon.endUserIDs._experience.emailid.id, defaultValue: "example@adobe.com"}
// field group
#{<data source name>.<field group name>.<path to the field>, defaultValue: <default value expression>}
#{ExperiencePlatform.ProfileFieldGroup.profile.personalEmail.address, defaultValue: "example@adobe.com"}
NOTE
Il tipo del campo e il valore predefinito devono essere uguali. Ad esempio, @{LobbyBeacon.endUserIDs._experience.emailid.id, defaultValue : 2} non sarà valido perché il valore predefinito è un numero intero, mentre il valore previsto deve essere una stringa.

Esempi:

// for an event 'OrderEvent' having the following payload:
{
    "orderId": "12345"
}

expression example:
- @{OrderEvent.orderId}                                    -> "12345"
- @{OrderEvent.producdId, defaultValue : "not specified" } -> "not specified" // default value, productId is not a field present in the payload
- @{OrderEvent.productId}                                  -> null


// for an entity 'Profile' on datasource 'ACP' having fields person/lastName, with fetched data such as:
{
    "person": {
        "lastName":"Snow"
    },
    "emails": [
        { "email":"john.snow@winterfell.westeros" },
        { "email":"snow@thewall.westeros" }
    ]
}

expression examples:
- #{ACP.Profile.person.lastName}                 -> "Snow"
- #{ACP.Profile.emails.at(1).email}              -> "snow@thewall.westeros"
- #{ACP.Profile.person.age, defaultValue : -1}   -> -1 // default value, age is not a field present in the payload
- #{ACP.Profile.person.age}                      -> null

È possibile aggiungere qualsiasi tipo di espressione come valore predefinito. L’unico vincolo è che l’espressione deve restituire il tipo di dati previsto. Quando si utilizza una funzione, è necessario incapsularla con ().

#{ExperiencePlatform.Subscriptions.profile.consents.marketing.any.time, defaultValue : (now())}
== date("2022-02-10T00:00:00Z")

Riferimento a un campo all’interno di raccolte

Per fare riferimento agli elementi definiti nelle raccolte vengono utilizzate le funzioni specifiche all, first e last. Per ulteriori informazioni, consulta questa pagina.

Esempio :

@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.all()

Riferimento a un campo definito in una mappa

Funzione di entry

Per recuperare un elemento in una mappa, utilizziamo la funzione di immissione con una determinata chiave. Ad esempio, viene utilizzato quando si definisce la chiave di un evento, in base allo spazio dei nomi selezionato. Consulta Selezione dello spazio dei nomi. Per ulteriori informazioni, consulta questa pagina.

@{MyEvent.identityMap.entry('Email').first().id}

In questa espressione, si ottiene la voce per la chiave "E-mail" del campo "IdentityMap" di un evento. La voce "E-mail" è una raccolta, da cui prendiamo l’"id" nel primo elemento utilizzando "first()". Per ulteriori informazioni, consulta questa pagina.

Funzione di firstEntryKey

Per recuperare la prima chiave di ingresso di una mappa, utilizza firstEntryKey funzione.

Questo esempio mostra come recuperare il primo indirizzo e-mail degli abbonati di un elenco specifico:

#{ExperiencePlatform.Subscriptions.profile.consents.marketing.email.subscriptions.entry('daily-email').subscribers.firstEntryKey()}

In questo esempio, l’elenco degli abbonamenti è denominato daily-email. Gli indirizzi e-mail sono definiti come chiavi nella subscribers mappa, collegata alla mappa dell’elenco di iscrizioni.

Funzione di keys

Per recuperare in tutte le chiavi di una mappa, utilizza keys funzione.

Questo esempio mostra come recuperare, per un profilo specifico, tutti gli indirizzi e-mail associati agli abbonati di un elenco specifico:

#{ExperiencePlatform.Subscriptions.profile.consents.marketing.email.subscriptions.entry('daily-mail').subscribers.keys()

Valori dei parametri di un’origine dati (valori dinamici dell’origine dati)

Se selezioni un campo da un’origine dati esterna che richiede la chiamata di un parametro, a destra viene visualizzata una nuova scheda che consente di specificare questo parametro. Consulta questa pagina.

Per casi d’uso più complessi, se desideri includere i parametri dell’origine dati nell’espressione principale, puoi definirne i valori utilizzando la parola chiave parametri. Un parametro può essere qualsiasi espressione valida anche da un'altra origine dati che include anche un altro parametro.

NOTE
Quando definite i valori dei parametri nell'espressione, la linguetta a destra scompare.

Utilizza la seguente sintassi:

#{<datasource>.<field group>.fieldName, params: {<params-1-name>: <params-1-value>, <params-2-name>: <params-2-value>}}
  • <params-1-name>: nome esatto del primo parametro dell’origine dati.
  • <params-1-value>: il valore del primo parametro. Può essere qualsiasi espressione valida.

Esempio:

#{Weather.main.temperature, params: {localisation: @{Profile.address.localisation}}}
#{Weather.main.temperature, params: {localisation: #{GPSLocalisation.main.coordinates, params: {city: @{Profile.address.city}}}}}
recommendation-more-help
4f4a00c1-77c9-4eee-84df-bbe6206c3ab9