欄位引用可以附加到事件或欄位組。 唯一有意義的資訊是欄位的名稱及其路徑。
如果在欄位中使用特殊字元,則需要使用雙引號或簡單引號。 以下是需要引用引號的情況:
例如,如果欄位為 3小時: #{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}
在表達式中,事件欄位與「@」一起引用,資料源欄位與「#」一起引用。
語法顏色用於直觀地區分事件欄位(綠色)和欄位組(藍色)。
預設值可以與欄位名關聯。 語法如下:
// 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"}
欄位的類型和預設值必須相同。 例如,@{LobbyBeacon.endUserID。_experience.emailid.id,預設值:2}將無效,因為預設值是整數,而預期值應是字串。
範例:
// 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
可以添加任何類型的表達式作為預設值。 唯一的約束是表達式必須返回預期的資料類型。 使用函式時,需要用()封裝函式。
#{ExperiencePlatform.Subscriptions.profile.consents.marketing.any.time, defaultValue : (now())}
== date("2022-02-10T00:00:00Z")
使用特定函式引用集合中定義的元素 all
。 first
和 last
。 如需詳細資訊,請參閱本頁面。
範例 :
@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.all()
entry
函數為了檢索映射中的元素,我們使用帶給定鍵的entry函式。 例如,在根據所選命名空間定義事件的鍵時使用它。 請參閱選擇命名空間。 有關詳細資訊,請參見 此頁。
@{MyEvent.identityMap.entry('Email').first().id}
在此表達式中,我們將獲取事件的「IdentityMap」欄位的「Email」鍵的條目。 「Email」條目是一個集合,我們從中使用「first()」獲取第一個元素中的「id」。 有關詳細資訊,請參見 此頁。
firstEntryKey
函數要檢索映射的第一個條目鍵,請使用 firstEntryKey
的子菜單。
此示例說明如何檢索特定清單的訂戶的第一個電子郵件地址:
#{ExperiencePlatform.Subscriptions.profile.consents.marketing.email.subscriptions.entry('daily-email').subscribers.firstEntryKey()}
在本示例中,訂閱清單被命名 daily-email
。 電子郵件地址被定義為 subscribers
映射,它連結到訂閱清單映射。
keys
函數要檢索到映射的所有鍵,請使用 keys
的子菜單。
此示例說明如何為特定配置檔案檢索與特定清單的訂戶關聯的所有電子郵件地址:
#{ExperiencePlatform.Subscriptions.profile.consents.marketing.email.subscriptions.entry('daily-mail').subscribers.keys()
如果從外部資料源中選擇一個需要調用參數的欄位,則右側將顯示一個新頁籤,以便您指定此參數。 請參閱此頁面。
對於更複雜的使用情形,如果要在主表達式中包括資料源的參數,可以使用關鍵字定義其值 帕拉。 參數可以是任何有效的表達式,即使來自另一個資料源,該資料源也包含另一個參數。
在表達式中定義參數值時,右側的頁籤將消失。
使用以下語法:
#{<datasource>.<field group>.fieldName, params: {<params-1-name>: <params-1-value>, <params-2-name>: <params-2-value>}}
<params-1-name>
:資料源中第一個參數的準確名稱。<params-1-value>
:第一個參數的值。 它可以是任何有效的表達式。範例:
#{Weather.main.temperature, params: {localisation: @{Profile.address.localisation}}}
#{Weather.main.temperature, params: {localisation: #{GPSLocalisation.main.coordinates, params: {city: @{Profile.address.city}}}}}