對話動作功能將於 2023 年 6 月 13 日淘汰。詳情請參閱「對話動作已淘汰」。

條件

您可以利用資料模型物件的值,在背景處理條件邏輯。以下各節說明瞭條件的有效語法。

邏輯運算子

運算子 說明
&& 邏輯 AND。內部運算式會反覆評估,而如果有任一運算式評估為 false,評估就會減短。
|| 邏輯 OR 內部運算式會反覆評估,而如果有任一運算式評估為 true,評估結果就會短暫
! 邏輯邏輯 NOT。內部運算式的評估結果為否

數字和字串運算子

支援的數字和字串運算子如下:

運算子 說明
+ 新增數字或字串串連
- 將數字相減
* 將數字相乘
/ 除號

布林值

支援的常數布林值如下:

常數 說明
true 必須為小寫
false 必須為小寫
!false 評估為 true。必須為小寫。

比較運算子

您可以使用下列比較運算子:

運算子 說明
== 等於
!= 不等於
< 小於
<= 小於等於
> 大於
>= 大於等於

清單與地圖

假設有一份清單,名為 session.params.myList

語法 說明
x in session.params.myList 如果 x 的值在 session.params.myList 中,則傳回「是」
myList[x] 傳回 myList 的索引值 x
size(session.params.myList) 傳回清單大小

指定名為 session.params.myMap 的地圖:

語法 說明
session.params.myMap == {"one": 1, "two":2} 如果地圖等於,則傳回 true
session['params']['myMap']['one'] 傳回具有指定鍵的值
size(session.params.myMap) 傳回地圖大小

資料模型

下列物件可在情境下使用:

語法 說明
intent 相符意圖參數資料
scene 運算單元填充資料
session 工作階段儲存空間資料
user 使用者儲存空間資料
home Home 儲存空間資料
device 裝置功能位置資料
canvas 畫布狀態資料
resources 本地化專案資源 (音訊、圖片、字串等)

以下為 JSON 完整資料模型的範例程式碼片段:

{
  "intent": {
    "params": {
      "<param_name>": {
        "original": "five people",
        "resolved": 5
      }
    }
   },
  "session": {
    "params": {
      "<session_params_key>": "<session_params_value>"
    }
  },
  "scene": {
    "slots": {
      "status": "FINAL",
      "params": {
        "<slot_name>": "<slot_value>"
      }
    }
  },
  "user": {
    "params": {
      "<user_params_key>": "<user_params_value>"
    },
    "permissions": [
      "DEVICE_PRECISE_LOCATION"
    ],
    "accountLinkingStatus": "LINKED",
    "verificationStatus": "VERIFIED",
    "lastSeenTime": {
      "seconds": 123,
      "nanos": 456
    },
    "engagement": {
      "pushNotificationIntents": [
        "intent1",
        "intent2"
      ]
    }
  },
  "home": {
    "params": {
      "<home_params_key>": "<home_params_value>"
    }
  },
  "canvas": {
    "state": {
      "<canvas_state_key>": "<canvas_state_value>"
    }
  },
  "device": {
    "capabilities": [
      "SPEECH",
      "RICH_RESPONSE",
      "LONG_FORM_AUDIO",
      "INTERACTIVE_CANVAS"
    ],
    "currentLocation": {
      "coordinates": {
        "latitude": 37.422,
        "longitude": -122.084
      },
      "postalAddress": {
        "revision": 0,
        "regionCode": "US",
        "languageCode": "en",
        "postalCode": "94043",
        "sortingCode": "",
        "administrativeArea": "California",
        "locality": "Mountain View",
        "sublocality": "",
        "addressLines": ["1600 Amphitheatre Parkway"],
        "recipients": [],
        "organization": ""
      }
    }
  },
  "resources": {
    "strings": {
      "<resource_string_key>": "<resource_string_value>"
    },
    "images": {
      "<resource_image_key>": "<resource_image_value>"
    }
  }
}

使用參考資料

以下語法範例假設您使用的是 session.params 物件:

session.params = {
  "flag": true,
  "count": 10,
  "name": "john smith",
  "myList": [1, 2, 3],
  "myMap": {"one": 1, "two":2}
}

您可以執行下列條件作業:

// numbers and boolean logic
session.params.count > 0 && session.params.count < 100    // AND
session.params.count == 0 || session.params.count != 5    // OR
!(session.params.count <= 0)         // NOT

// booleans
!false                      // true constant
session.params.flag         // boolean variable
session.params.flag == true // explicitly compare with true constant

// strings
session.params.name == "john smith"  // double quotes supported
session.params.name == 'john smith'  // single quotes supported
session.params.name.contains("john") // substring
session.params.name + "!!!" == "john smith!!!" // string concatenation
session.params.name < "abc"          // compares lexicographically
size(session.params.name) == 10      // length of string

// lists
1 in session.params.myList        // "contains in list" operator
session.params.myList[0] == 1     // "index into list" operator
size(session.params.myList) == 3  // returns number of elements in the list

// maps
session.params.myMap == {"one": 1, "two":2} // compare map with json
session['params']['myMap']['one'] == 1      // index using square brackets
size(session.params.myMap) == 2             // number of entries in the map