Sie können bedingte Logik in Szenen ausführen, indem Sie Werte aus der Datenmodellobjekte In den folgenden Abschnitten wird beschrieben, die gültige Syntax für Bedingungen.
Logische Operatoren
| Operator | Beschreibung | 
|---|---|
&& | 
    Logisches UND. Innere Ausdrücke werden iterativ ausgewertet und die für die Auswertung wird Kurzschluss verwendet, wenn ein Ausdruck als falsch ausgewertet wird. | 
|| | 
    Logisches ODER. Innere Ausdrücke werden iterativ ausgewertet und die Die Auswertung ist kurzgeschlossen, wenn ein Ausdruck als wahr ausgewertet wird | 
! | 
    Logisches NOT. Die Auswertung des inneren Ausdrucks wird negiert | 
Numerische Operatoren und Stringoperatoren
Die folgenden numerischen und Stringoperatoren werden unterstützt:
| Operator | Beschreibung | 
|---|---|
+ | 
    Zahlen oder Zeichenfolgenverkettungen hinzufügen | 
- | 
    Zahlen subtrahieren | 
* | 
    Zahlen multiplizieren | 
/ | 
    Zahlen dividieren | 
Boolesch
Die folgenden konstanten booleschen Werte werden unterstützt:
| Konstante | Beschreibung | 
|---|---|
true | 
    Muss kleingeschrieben werden | 
false | 
    Muss kleingeschrieben werden | 
!false | 
    Wird mit true ausgewertet. Muss kleingeschrieben werden. | 
  
Vergleichsoperatoren
Die folgenden Vergleichsoperatoren werden bereitgestellt:
| Operator | Beschreibung | 
|---|---|
== | 
    Ist gleich | 
!= | 
    Ungleich | 
< | 
    Weniger als | 
<= | 
    Kleiner als/gleich | 
> | 
    Größer als | 
>= | 
    Größer als/gleich | 
Listen und Zuordnungen
Für eine Liste mit dem Namen session.params.myList gilt:
| Syntax | Beschreibung | 
|---|---|
x in session.params.myList | 
    Gibt „true“ zurück, wenn der Wert x in
      session.params.myList | 
  
myList[x] | 
    Gibt den Wert bei Index x von myList zurück | 
  
size(session.params.myList) | 
    Gibt die Größe einer Liste zurück | 
Bei einer Karte mit dem Namen session.params.myMap:
| Syntax | Beschreibung | 
|---|---|
session.params.myMap == {"one": 1, "two":2} | 
    Gibt true zurück, wenn die Karten gleich sind | 
  
session['params']['myMap']['one'] | 
    Gibt den Wert mit dem angegebenen Schlüssel zurück | 
size(session.params.myMap) | 
    Gibt die Kartengröße zurück | 
Datenmodell
Die folgenden Objekte können in Szenenbedingungen verwendet werden:
| Syntax | Beschreibung | 
|---|---|
intent | 
    Daten zu übereinstimmenden Intent-Parametern | 
scene | 
    Slot-Füllung | 
session | 
    Daten zum Sitzungsspeicher | 
user | 
    Nutzerspeicher-Daten | 
home | 
    Speicherplatz im Zuhause | 
device | 
    Gerätefunktionen und Standortdaten | 
canvas | 
    Canvas-Statusdaten | 
resources | 
    Lokalisierte Projektressourcen (Audio, Bilder, Strings usw.) | 
Das folgende Beispiel zeigt ein Snippet des vollständigen Datenmodells in 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>"
    }
  }
}
Nutzungsreferenz
In den folgenden Syntaxbeispielen wird davon ausgegangen, dass Sie
mit dem Objekt session.params:
session.params = {
  "flag": true,
  "count": 10,
  "name": "john smith",
  "myList": [1, 2, 3],
  "myMap": {"one": 1, "two":2}
}
Sie können die folgenden bedingten Vorgänge ausführen:
// 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