Dans schema.org, une action représente un verbe ou une activité pouvant être exécutée sur un élément de données structurées. Plusieurs types d'actions sont acceptés et peuvent tous être définis avec des données structurées similaires.
Actions directes
Si vous ajoutez un balisage à votre contenu avec des entités schema.org, vous pouvez ajouter des actions Go-To correspondantes. Par exemple, pour qu'une entité EmailMessage
possède un lien de destination ViewAction
, renseignez la propriété potentialAction
de l'adresse e-mail, comme dans l'exemple suivant:
JSON-LD
<script type="application/ld+json">
{
"@context": "http://schema.org",
"@type": "EmailMessage",
"potentialAction": {
"@type": "ViewAction",
"target": "https://watch-movies.com/watch?movieId=abc123",
"name": "Watch movie"
},
"description": "Watch the 'Avengers' movie online"
}
</script>
Microdonnées
<div itemscope itemtype="http://schema.org/EmailMessage">
<div itemprop="potentialAction" itemscope itemtype="http://schema.org/ViewAction">
<link itemprop="target" href="https://watch-movies.com/watch?movieId=abc123"/>
<meta itemprop="name" content="Watch movie"/>
</div>
<meta itemprop="description" content="Watch the 'Avengers' movie online"/>
</div>
Notez que le balisage ci-dessus est automatiquement ignoré par les autres clients de messagerie qui n'acceptent pas les schémas dans les e-mails.
Liens profonds pour mobile
Les actions directes peuvent également rediriger directement vers le contenu des applications mobiles natives sur
Android et
iOS Pour créer un lien profond vers
une application, incluez des URL target
supplémentaires encodées avec les schémas android-app://
et ios-app://
, comme indiqué ci-dessous:
JSON-LD
"target": [
“<web url>”,
“android-app://<android package name>/<scheme>/<host>/<path+query>”,
“ios-app://<App store ID>/<scheme>/<host><path+query>"
]
Microdonnées
<link itemprop="target" href="<web url>"/>
<link itemprop="target" href="android-app://<android package name>/<scheme>/<host>/<path+query>”/>
<link itemprop="target" href="ios-app://<App store ID>/<scheme>/<host>/<path+query>"/>
Pour aller plus loin dans l'exemple EmailMessage
précédent:
JSON-LD
<script type="application/ld+json">
{
"@context": "http://schema.org",
"@type": "EmailMessage",
"name": "Watch movie",
... information about the movie ...
"potentialAction": {
"@type": "ViewAction",
"target": [
"https://watch-movies.com/watch?movieId=abc123",
"android-app://com.watchmovies.app/http/watch-movies.com/watch?movieId=abc123",
"ios-app://12345/movieapp/watch-movies.com/watch?movieId=abc123"
]
}
}
</script>
Microdonnées
<div itemscope itemtype="http://schema.org/EmailMessage">
<meta itemprop="name" content="Watch movie"/>
... information about the movie ...
<div itemprop="potentialAction" itemscope itemtype="http://schema.org/ViewAction">
<meta itemprop="target" content="https://watch-movies.com/watch?movieId=abc123"/>
<meta itemprop="target" content="android-app://com.watchmovies.android/http/watch-movies.com/watch?movieId=abc123"/>
<meta itemprop="target" content="ios://12345/movieapp/watch-movies.com/watch?movieId=abc123"/>
</div>
</div>
Si l'utilisateur n'a pas votre application, l'action le redirige vers l'URL Web que vous fournissez.
Actions dans l'application
Les actions dans l'application sont gérées sur place, dans Gmail, sans rediriger l'utilisateur vers un autre site Web. Les actions dans l'application sont déclarées comme des actions directement dans l'application, mais elles contiennent des informations supplémentaires qui permettent aux user-agents (comme Gmail) de gérer facilement l'action intégrée.
Au lieu de déclarer une action avec un target
, vous devez déclarer un HttpActionHandler
pour l'action avec la configuration appropriée.
Par exemple, vous pouvez ajouter un bouton de confirmation aux e-mails qui demandent aux utilisateurs d'approuver ou de confirmer un élément. Lorsque l'utilisateur clique sur le bouton, Google envoie une requête HTTP à votre service pour enregistrer la confirmation. Vous ne pouvez interagir avec ConfirmAction
qu'une seule fois.
L'exemple suivant ajoute un bouton ConfirmAction
à un e-mail concernant une note de frais:
JSON-LD
<script type="application/ld+json">
{
"@context": "http://schema.org",
"@type": "EmailMessage",
"potentialAction": {
"@type": "ConfirmAction",
"name": "Approve Expense",
"handler": {
"@type": "HttpActionHandler",
"url": "https://myexpenses.com/approve?expenseId=abc123"
}
},
"description": "Approval request for John's $10.13 expense for office supplies"
}
</script>
Microdonnées
<div itemscope itemtype="http://schema.org/EmailMessage">
<div itemprop="potentialAction" itemscope itemtype="http://schema.org/ConfirmAction">
<meta itemprop="name" content="Approve Expense"/>
<div itemprop="handler" itemscope itemtype="http://schema.org/HttpActionHandler">
<link itemprop="url" href="https://myexpenses.com/approve?expenseId=abc123"/>
</div>
</div>
<meta itemprop="description" content="Approval request for John's $10.13 expense for office supplies"/>
</div>
Actions arrivant à expiration
Dans de nombreux cas, les actions ne sont pertinentes que pendant une période limitée. Les actions associées aux entités dont les dates sont connues, comme les réservations de voyage, expireront automatiquement. Gmail n'affiche pas l'action une fois le trajet terminé.
Les délais d'expiration peuvent également être explicitement ajoutés aux actions. Par exemple, une action visant à ajouter un clip à un bon de réduction ou à enregistrer un code promotionnel peut n'être valable que pendant une durée limitée. Pour définir la période d'affichage d'une action, définissez les propriétés startTime
et endTime
de l'action:
JSON-LD
<script type="application/ld+json">
{
"@context": "http://schema.org",
"@type": "EmailMessage",
"potentialAction": {
"@type": "ConfirmAction",
"name": "Save coupon",
"handler": {
"@type": "HttpActionHandler",
"url": "https://my-coupons.com/approve?couponId=abc123"
},
"startTime": "2015-06-01T12:00:00Z",
"endTime": "2015-06-05T12:00:00Z"
}
}
</script>
Microdonnées
<div itemscope itemtype="http://schema.org/EmailMessage">
<div itemprop="potentialAction" itemscope itemtype="http://schema.org/ConfirmAction">
<meta itemprop="name" content="Save coupon"/>
<div itemprop="handler" itemscope itemtype="http://schema.org/HttpActionHandler">
<link itemprop="url" href="https://my-coupons.com/approve?couponId=abc123"/>
</div>
<meta itemprop="startTime" content="2015-06-01T12:00:00Z" />
<meta itemprop="endTime" content="2015-06-05T12:00:00Z" />
</div>
</div>
Documentation complémentaire
Pour en savoir plus sur les actions, consultez les pages suivantes: