WML - Guide rapide

La couche supérieure de l'architecture WAP (Wireless Application Protocol) est constituée de WAE (Wireless Application Environment), qui se compose de langage de script WML et WML.

  • WML signifie Wirrésistible MArkup Language

  • WML est une application de XML, qui est définie dans une définition de type de document.

  • WML est basé sur HDML et est modifié pour pouvoir être comparé au HTML.

  • WML prend soin du petit écran et de la faible bande passante de transmission.

  • WML est le langage de balisage défini dans la spécification WAP.

  • Les sites WAP sont écrits en WML, tandis que les sites Web sont écrits en HTML.

  • WML est très similaire au HTML. Les deux utilisent des balises et sont écrits au format texte brut.

  • Les fichiers WML ont l'extension ".wml". Le type MIME de WML est "text / vnd.wap.wml".

  • WML prend en charge les scripts côté client. Le langage de script pris en charge est appelé WMLScript.

Versions WML:

WAP Forum a publié une dernière version WAP 2.0. Le langage de balisage défini dans WAP 2.0 est XHTML Mobile Profile (MP). Le MP WML est un sous-ensemble du XHTML. Une feuille de style appelée WCSS (WAP CSS) a été introduite avec XHTML MP. Le WCSS est un sous-ensemble du CSS2.

La plupart des nouveaux modèles de téléphones mobiles lancés sont compatibles WAP 2.0. Étant donné que WAP 2.0 est rétrocompatible avec WAP 1.x, les appareils mobiles compatibles WAP 2.0 peuvent afficher à la fois des documents XHTML MP et WML.

WML 1.x est une technologie antérieure. Cependant, cela ne signifie pas que cela ne sert à rien, car de nombreux appareils sans fil qui ne prennent en charge que WML 1.x sont toujours utilisés. La dernière version de WML est 2.0 et est créée à des fins de compatibilité descendante. Les développeurs de sites WAP n'ont donc pas à se soucier de WML 2.0.

Decks et cartes WML:

Une différence principale entre HTML et WML est que l'unité de base de navigation en HTML est une page, tandis que celle en WML est une carte. Un fichier WML peut contenir plusieurs cartes et elles forment un jeu.

Lorsqu'une page WML est accédée à partir d'un téléphone mobile, toutes les cartes de la page sont téléchargées à partir du serveur WAP. Ainsi, si l'utilisateur se rend sur une autre carte du même deck, le navigateur mobile n'a pas à envoyer de requêtes au serveur puisque le fichier qui contient le deck est déjà stocké dans l'appareil sans fil.

Vous pouvez mettre des liens, du texte, des images, des champs de saisie, des cases d'options et de nombreux autres éléments dans une carte.

Structure du programme WML:

Voici la structure de base d'un programme WML:

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card id="one" title="First Card">
<p>
This is the first card in the deck
</p>
</card>

<card id="two" title="Second Card">
<p>
Ths is the second card in the deck
</p>
</card>

</wml>

La première ligne de ce texte indique qu'il s'agit d'un document XML et que la version est 1.0. La deuxième ligne sélectionne le type de document et donne l'URL de la définition du type de document (DTD).

Un deck WML (c'est-à-dire une page) peut avoir une ou plusieurs cartes comme indiqué ci-dessus. Nous verrons des détails complets sur la structure des documents WML dans le chapitre suivant.

Contrairement à HTML 4.01 Transitional, le texte ne peut pas être inclus directement dans la paire de balises <card> ... </card>. Vous devez donc mettre un contenu dans <p> ... </p> comme indiqué ci-dessus.

Considérations relatives à la conception du site WAP:

Les appareils sans fil sont limités par la taille de leurs écrans et claviers. Il est donc très important d'en tenir compte lors de la conception d'un site WAP.

Lors de la conception d'un site WAP, vous devez vous assurer que les choses restent simples et faciles à utiliser. Vous devez toujours garder à l'esprit qu'il n'y a pas de comportement de microbrowser standard et que la liaison de données peut être relativement lente, à environ 10 Kbps. Cependant, avec GPRS, EDGE et UMTS, cela peut ne pas être le cas longtemps, selon l'endroit où vous vous trouvez.

Voici des conseils de conception généraux que vous devez garder à l'esprit lors de la conception d'un service:

  • Gardez les jeux et images WML à moins de 1,5 Ko.

  • Gardez le texte bref et significatif et, dans la mesure du possible, essayez de précoder les options pour minimiser l'expérience plutôt pénible de la saisie des données utilisateur.

  • Gardez les URL brèves et faciles à rappeler.

  • Réduisez les niveaux de menu pour éviter que les utilisateurs ne se perdent et que le système ne ralentisse.

  • Utilisez des balises de mise en page standard telles que <big> et <b>, et structurez logiquement vos informations.

  • N'exagérez pas avec l'utilisation de graphiques, car de nombreux périphériques cibles peuvent ne pas les prendre en charge.

Pour développer des applications WAP, vous aurez besoin des éléments suivants:

  • A WAP enabled Web Server: Vous pouvez activer votre Apache ou Microsoft IIS pour traiter toutes les demandes du client WAP.

  • A WAP Gateway Simulator: Ceci est nécessaire pour interagir avec votre serveur WAP.

  • A WAP Phone Simulator: Ceci est nécessaire pour tester vos pages WAP et afficher toutes les pages WAP.

Vous pouvez rédiger vos pages WAP dans les langues suivantes:

  • Wireless Markup Language (WML) pour développer une application WAP.
  • Script WML pour améliorer les fonctionnalités de l'application WAP.

Configuration du serveur Web:

Dans les applications Web normales, le type MIME est défini sur text / html, désignant le code HTML normal. Les images, en revanche, peuvent être spécifiées comme image / gif ou image / jpeg, par exemple. Avec cette spécification de type de contenu, le navigateur Web connaît le type de données renvoyé par le serveur Web.

Pour rendre votre Apache compatible WAP, vous n'avez rien à faire. Vous devez simplement ajouter la prise en charge des types et extensions MIME répertoriés ci-dessous.

Extension de fichier Type MIME
WML (.wml) text / vnd.wap.wml
WMLScript (.wmls) text / vmd.wap.wmlscript
WMLScriptc (.wmlsx) application / vnd.wap.wmlscriptc
WMLC (.wmlc) application / vnd.wap.wmlc
WBMP (.wbmp) image / vnd.wap.wbmp

Configurez Apache Web Server pour WAP:

En supposant que le serveur Web Apache soit installé sur votre machine. Nous allons maintenant vous dire comment activer la fonctionnalité WAP sur votre serveur Web Apache.

Recherchez donc le fichier d'Apache httpd.conf qui se trouve généralement dans / etc / httpd / conf, et ajoutez les lignes suivantes au fichier et redémarrez le serveur:

AddType text/vnd.wap.wml .wml
AddType text/vnd.wap.wmlscript .wmls
AddType application/vnd.wap.wmlc .wmlc
AddType application/vnd.wap.wmlscriptc .wmlsc
AddType image/vnd.wap.wbmp .wbmp

Dans les applications dynamiques, le type MIME doit être défini à la volée, tandis que dans les applications WAP statiques, le serveur Web doit être configuré de manière appropriée.

Configurez Microsoft IIS pour WAP:

Pour configurer un serveur Microsoft IIS pour fournir du contenu WAP, vous devez effectuer les opérations suivantes:

  1. Ouvrez la console Gestionnaire des services Internet et développez l'arborescence pour afficher l'entrée de votre site Web. Vous pouvez ajouter les types WAP MIME à un serveur entier ou à des répertoires individuels.
  2. Ouvrez la boîte de dialogue Propriétés en cliquant avec le bouton droit sur le serveur ou le répertoire approprié, puis choisissez Propriétés dans le menu.
  3. Dans la boîte de dialogue Propriétés, choisissez l'onglet En-têtes HTTP, puis sélectionnez le bouton Types de fichiers en bas à droite.
  4. Pour chaque type MIME répertorié précédemment dans le tableau ci-dessus, indiquez l'extension avec ou sans le point (elle sera automatiquement ajoutée pour vous), puis cliquez sur OK dans la boîte de dialogue Propriétés pour accepter vos modifications.

Installation du simulateur de passerelle WAP:

Il existe de nombreux simulateurs de passerelle WAP disponibles sur Internet, alors téléchargez-les et installez-les sur votre PC. Vous devrez exécuter cette passerelle avant de démarrer le simulateur WAP Mobile.

La passerelle WAP prendra votre demande et la transmettra au serveur Web et quelle que soit la réponse reçue du serveur Web qui sera transmise au simulateur mobile.

Vous pouvez le télécharger sur le site Web de Nokia:

  • Nokia WAP Gateway simulator - Téléchargez le simulateur Nokia WAP Gateway.

Installation du simulateur de téléphone WAP:

Il existe de nombreux simulateurs WAP disponibles sur Internet, alors téléchargez-les et installez-les sur votre PC que vous utiliserez comme client WAP. Voici les liens populaires pour télécharger le simulateur:

  • Simulateur Nokia WAP - Téléchargez le simulateur Nokia WAP.

  • Simulateur WinWAP - Téléchargez le navigateur WinWAP depuis leur site officiel.

NOTE:Si vous avez un téléphone compatible WAP, vous n'avez pas besoin d'installer ce simulateur. Mais lors du développement, il est plus pratique et économique d'utiliser un simulateur.

Le modèle WAP:

Je donne cette section juste pour votre référence, si vous n'êtes pas intéressé, vous pouvez sauter cette section.

La figure ci-dessous montre le modèle de programmation WAP. Notez les similitudes avec le modèle Internet. Sans la passerelle / proxy WAP, les deux modèles auraient été pratiquement identiques.

La passerelle / proxy WAP est l'entité qui connecte le domaine sans fil à Internet. Notez que la demande envoyée par le client sans fil à la passerelle / proxy WAP utilise le protocole de session sans fil (WSP). Dans son essence, WSP est une version binaire de HTTP.

Un langage de balisage - le Wireless Markup Language (WML) a été adapté pour développer des applications WAP optimisées. Afin d'économiser une bande passante précieuse dans le réseau sans fil, WML peut être codé dans un format binaire compact. L'encodage WML est l'une des tâches exécutées par la passerelle / proxy WAP.

Comment fonctionne le modèle WAP?

En ce qui concerne l'utilisation réelle, le WAP fonctionne comme ceci:

  1. L'utilisateur sélectionne une option sur son appareil mobile à laquelle une URL avec un contenu WML (Wireless Markup Language) lui est attribué.

  2. Le téléphone envoie la demande d'URL via le réseau téléphonique à une passerelle WAP, en utilisant le protocole WAP codé en binaire.

  3. La passerelle traduit cette requête WAP en une requête HTTP conventionnelle pour l'URL spécifiée et l'envoie sur Internet.

  4. Le serveur Web approprié récupère la requête HTTP.

  5. Le serveur traite la demande, comme il le ferait pour toute autre demande. Si l'URL fait référence à un fichier WML statique, le serveur le délivre. Si un script CGI est demandé, il est traité et le contenu est renvoyé comme d'habitude.

  6. Le serveur Web ajoute l'en-tête HTTP au contenu WML et le renvoie à la passerelle.

  7. La passerelle WAP compile le WML sous forme binaire.

  8. La passerelle renvoie ensuite la réponse WML au téléphone.

  9. Le téléphone reçoit le WML via le protocole WAP.

  10. Le micro-navigateur traite le WML et affiche le contenu à l'écran.

Un programme WML est généralement divisé en deux parties: le prologue du document et le corps. Considérez le code suivant:

Voici la structure de base d'un programme WML:

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card id="one" title="First Card">
<p>
This is the first card in the deck

</p>
</card>

<card id="two" title="Second Card">
<p>
Ths is the second card in the deck
</p>
</card>

</wml>

Document Prologue WML:

La première ligne de ce texte indique qu'il s'agit d'un document XML et que la version est 1.0. La deuxième ligne sélectionne le type de document et donne l'URL de la définition du type de document (DTD). La DTD référencée est définie dans WAP 1.2, mais cet en-tête change avec les versions du WML. L'en-tête doit être copié exactement pour que les kits d'outils génèrent automatiquement ce prologue.

Les composants du prologue ne sont pas des éléments WML et ils ne doivent pas être fermés, c'est-à-dire que vous ne devez pas leur donner de balise de fin ou les terminer avec />.

Corps du document WML:

Le corps est inclus dans une paire de balises <wml> </wml>. Le corps d'un document WML peut comprendre un ou plusieurs des éléments suivants:

  • Deck

  • Card

  • Contenu à afficher

  • Instructions de navigation

Contrairement à HTML 4.01 Transitional, le texte ne peut pas être inclus directement dans la paire de balises <card> ... </card>. Vous devez donc mettre un contenu dans <p> ... </p> comme indiqué ci-dessus.

Tester votre programme:

Mettez le code ci-dessus dans un fichier appelé fichier test.wml et placez ce fichier WML localement sur votre disque dur, puis affichez-le à l'aide d'un émulateur.

C'est de loin le moyen le plus efficace de développer et de tester des fichiers WML. Cependant, comme votre objectif est de développer un service qui sera disponible pour les utilisateurs de téléphones WAP, vous devez télécharger vos fichiers WML sur un serveur une fois que vous les avez développés localement et les tester via une véritable connexion Internet. Au fur et à mesure que vous commencez à développer des services WAP plus complexes, c'est ainsi que vous identifierez et corrigerez les problèmes de performances, qui pourraient, s'ils étaient laissés seuls, perdre les visiteurs de votre site.

En téléchargeant le fichier test.wml sur un serveur, vous testerez votre émulateur WML pour voir à quoi il ressemble et se comporte, et vous vérifierez votre serveur Web pour voir qu'il est correctement configuré. Maintenant, démarrez votre émulateur et utilisez-le pour accéder à l'URL de test.wml. Par exemple, l'URL peut ressembler à ceci:

http://websitename.com/wapstuff/test.wml

NOTE: Avant d'accéder à une URL, assurez-vous que WAP Gateway Simulator est en cours d'exécution sur votre PC.

Lorsque vous téléchargerez votre programme WAP, vous ne verrez alors que la première carte sur votre mobile. Voici la sortie de l'exemple ci-dessus sur Nokia Mobile Browser 4.0. Ce mobile prend en charge le défilement horizontal. Vous pouvez voir le texte hors de l'écran en appuyant sur le bouton «Gauche» ou «Droite».

Lorsque vous appuyez sur le bouton droit, la deuxième carte sera visible comme suit:

WML est défini par un ensemble d' éléments qui spécifient toutes les informations de balisage et de structure pour un deck WML. Les éléments sont identifiés par des balises, qui sont chacune entourées d'une paire de crochets angulaires.

Contrairement au HTML, WML adhère strictement à la structure hiérarchique XML et, par conséquent, les éléments doivent contenir une balise de début; tout contenu tel que du texte et / ou d'autres éléments; et une étiquette de fin. Les éléments ont l'une des deux structures suivantes:

  • <tag> content </tag> : Ce formulaire est identique au HTML.

  • <tag />:Ceci est utilisé lorsqu'un élément ne peut pas contenir de contenu visible ou est vide, comme un saut de ligne. La partie prologue du document WML n'a aucun élément qui a un élément de fermeture.

Le tableau suivant répertorie la majorité des éléments valides. Un détail complet de tous ces éléments est donné dans la référence des balises WML .

Éléments de deck et de carte

Éléments WML Objectif
<! ->  Définit un commentaire WML
<wml>  Définit un deck WML (racine WML)
<head> Définit les informations de la tête
<meta> Définit les méta-informations
<card> Définit une carte dans un deck
<accès> Définit les informations sur le contrôle d'accès d'un deck
<modèle> Définit un modèle de code pour toutes les cartes d'un jeu

Éléments de texte

Éléments WML Objectif
<br> Définit un saut de ligne
<p>  Définit un paragraphe
<table> Définit une table
<td> Définit une cellule de tableau (données de table)
<tr> Définit une ligne de tableau
<pre> Définit le texte préformaté

Balises de formatage de texte

Éléments WML Objectif
<b> Définit le texte en gras
<big>  Définit le gros texte
<em> Définit le texte mis en évidence
<i> Définit le texte en italique
<petit> Définit le petit texte
<strong> Définit le texte fort
<u> Définit le texte souligné

Éléments d'image

Éléments WML Objectif
<img> Définit une image

Éléments d'ancrage

Éléments WML Objectif
<a> Définit une ancre
<ancre>  Définit une ancre

Éléments d'événement

Éléments WML Objectif
<do> Définit un gestionnaire d'événements do
<un événement> Définit un gestionnaire d'événements onevent
<champ postal> Définit un gestionnaire d'événements postfield
<ontimer> Définit un gestionnaire d'événements ontimer
<onenterforward> Définit un gestionnaire onenterforward
<onenterbackward> Définit un gestionnaire onenterbackward
<onpick> Définit un gestionnaire d'événements onpick

Éléments de tâche

Éléments WML Objectif
<go> Représente l'action de passer à une nouvelle carte
<noop> Dit que rien ne devrait être fait
<prév> Représente l'action de revenir à la carte précédente
<refresh> Actualise certaines variables de carte spécifiées.

Éléments d'entrée

Éléments WML Objectif
<entrée>  Définit un champ de saisie
<select> Définit un groupe de sélection
<option> Définit une option dans une liste sélectionnable
<fieldset> Définit un ensemble de champs de saisie
<optgroup> Définit un groupe d'options dans une liste sélectionnable

Éléments variables

Éléments WML Objectif
<setvar> Définit et définit une variable
<horloge> Définit une minuterie

Comme avec la plupart des langages de programmation, WML fournit également un moyen de placer du texte de commentaire dans le code.

Les commentaires sont utilisés par les développeurs comme moyen de documenter les décisions de programmation dans le code afin de faciliter la maintenance du code.

Les commentaires WML utilisent le même format que les commentaires HTML et utilisent la syntaxe suivante:

<!-- This will be assumed as a comment -->

Un commentaire multiligne peut être donné comme suit:

<!-- This is a multi-line
     comment -->

L'auteur WML peut utiliser des commentaires n'importe où, et ils ne sont pas affichés à l'utilisateur par l'agent utilisateur. Certains émulateurs peuvent se plaindre si des commentaires sont placés avant le prologue XML.

Notez que les commentaires ne sont ni compilés ni envoyés à l'agent utilisateur, et n'ont donc aucun effet sur la taille du deck compilé.

Étant donné que plusieurs cartes peuvent être contenues dans un même jeu, un mécanisme doit être en place pour conserver les données lorsque l'utilisateur passe de carte en carte. Ce mécanisme est fourni via des variables WML.

WML est sensible à la casse. Aucun pliage de cas n'est effectué lors de l'analyse d'un deck WML. Toutes les valeurs d'attribut énumérées sont sensibles à la casse. Par exemple, les valeurs d'attribut suivantes sont toutes différentes: id = "Card1", id = "card1" et id = "CARD1".

Les variables peuvent être créées et définies à l'aide de plusieurs méthodes différentes. Voici deux exemples:

L'élément <setvar>:

L'élément <setvar> est utilisé suite à l'exécution par l'utilisateur d'une tâche. L'élément> setvar> peut être utilisé pour définir l'état d'une variable dans les éléments suivants: <go>, <prev> et <refresh>.

Cet élément prend en charge les attributs suivants:

Attribut Valeur La description
Nom chaîne Définit le nom de la variable
valeur chaîne Définit la valeur de la variable
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

L'élément suivant créerait une variable nommée a avec une valeur de 1000:

<setvar name="a" value="1000"/>

Les éléments d'entrée:

Les variables sont également définies via n'importe quel élément d' entrée comme input, select, option, etc. Une variable est automatiquement créée qui correspond à l'attribut nommé d'un élément d'entrée.

Par exemple, l'élément suivant créerait une variable nommée b :

<select name="b">
<option value="value1">Option 1</option>
<option value="value2">Option 2</option>
</select>

Utilisation de variables:

L'expansion des variables se produit au moment de l'exécution, dans le microbrowser ou l'émulateur. Cela signifie qu'il peut être concaténé ou incorporé dans un autre texte.

Les variables sont référencées avec un signe dollar précédent et tout signe dollar unique dans votre présentation WML est interprété comme une référence de variable.

<p> Selected option value is $(b) </p>

Cette section décrit les éléments de formatage de texte de base de WML.

Saut de ligne:

L'élément <br /> définit un saut de ligne et presque tous les navigateurs WAP prennent en charge une balise de saut de ligne.

L'élément <br /> prend en charge les attributs suivants:

Attribut Valeur La description
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <br />.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Line Break Example">
<p align="center">
This is a <br /> paragraph with a line break.
</p>
</card>

</wml>

Cela produira le résultat suivant:

Paragraphes de texte:

L'élément <p> définit un paragraphe de texte et les navigateurs WAP affichent toujours un paragraphe dans une nouvelle ligne.

Un élément <p> est nécessaire pour définir tout texte, image ou tableau en WML.

L'élément <p> prend en charge les attributs suivants:

Attribut Valeur La description
aligner
  • left
  • right
  • center
Ceci est utilisé pour modifier l'alignement horizontal d'un paragraphe.
mode
  • wrap
  • nowrap
Définit si un paragraphe doit encapsuler des lignes ou non.
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <p>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Paragraph Example">
<p align="center">
This is first  paragraph
</p>
<p align="right">
This is second  paragraph
</p>
</card>

</wml>

Cela produira le résultat suivant:

Tables WML:

L'élément <table> avec <tr> et <td> est utilisé pour créer une table en WML. WML n'autorise pas l'imbrication des tables

Un élément <table> doit être placé avec des éléments <p> ... </p>.

L'élément <table /> prend en charge les attributs suivants:

Attribut Valeur La description
Colonnes nombre Définit le nombre de colonnes dans le tableau
aligner
  • L
  • C
  • R
Pour spécifier l'alignement horizontal du texte des colonnes, vous devez attribuer trois lettres à l'attribut align. Chaque lettre représente l'alignement horizontal du texte d'une colonne. La lettre peut être L, C ou R. Par exemple, si vous souhaitez que les paramètres suivants soient appliqués à votre tableau:
  • Première colonne du tableau - alignée à gauche

  • Deuxième colonne du tableau - alignée au centre

  • Troisième colonne du tableau - alignée à droite

Ensuite, vous devez définir la valeur de l' attribut align sur LCR.

xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <table>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="WML Tables">
<p>
<table columns="3" align="LCR">
	<tr>
	  <td>Col 1</td>
	  <td>Col 2</td>
	  <td>Col 3</td>
	</tr>

	<tr>
	  <td>A</td>
	  <td>B</td>
	  <td>C</td>
	</tr>

	<tr>
	  <td>D</td>
	  <td>E</td>
	  <td>F</td>
	</tr>
</table>
</p>
</card>

</wml>

Cela produira le résultat suivant:

Texte préformaté:

L'élément <pre> est utilisé pour spécifier du texte préformaté en WML. Le texte préformaté est un texte dont le format suit la manière dont il est saisi dans le document WML.

Cette balise préserve tous les espaces blancs contenus à l'intérieur de cette balise. Assurez-vous de ne pas mettre cette balise à l'intérieur <p> ... </p>

L'élément <pre> prend en charge les attributs suivants:

Attribut Valeur La description
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <pre>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Preformatted Text">
   <pre>
   This is     preformatted
        text and will appear
 as it it.
</pre>
</card>

</wml>

Cela produira le résultat suivant:

WML ne prend pas en charge l'élément <font>, mais il existe d'autres éléments WML que vous pouvez utiliser pour créer différents effets de police tels que le texte souligné, le texte en gras et le texte en italique, etc.

Ces balises sont données dans le tableau suivant:

Éléments WML Objectif
<b> Définit le texte en gras
<big>  Définit le gros texte
<em> Définit le texte mis en évidence
<i> Définit le texte en italique
<petit> Définit le petit texte
<strong> Définit le texte fort
<u> Définit le texte souligné

Ces éléments prennent en charge les attributs suivants:

Attribut Valeur La description
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de ces éléments.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Text Formatting">
<p>
  <b>bold text</b><br/>
  <big>big text</big><br/>
  <em>emphasized text</em><br/>
  <i>italic text</i><br/>
  <small>small text</small><br/>
  <strong>strong text</strong><br/>
  <u>underlined text</u>
</p>
</card>

</wml>

Cela produira le résultat suivant:

L'élément <img> est utilisé pour inclure une image dans une carte WAP. Les périphériques sans fil compatibles WAP ne prennent en charge que le format d'image Wireless Bitmap (WBMP).

Les images WBMP ne peuvent contenir que deux couleurs: noir et blanc. L'extension de fichier de WBMP est ".wbmp" et le type MIME de WBMP est "image / vnd.wap.wbmp".

L'élément <img> prend en charge les attributs suivants:

Attribut Valeur La description
aligner
  • top
  • middle
  • bottom
Alignement de l'image
alt Texte alternatif Définit un autre texte à afficher si l'image n'est pas affichée.
la taille
  • px
  • %
Hauteur de l'image en pixels ou en pourcentage. Si vous spécifiez la valeur en pixels, la syntaxe est "140" au lieu de "140px".
hspace
  • px
  • %
Définit l'espace blanc à gauche et à droite de l'image. Si vous spécifiez la valeur en pixels, la syntaxe est "140" au lieu de "140px".
localsrc cdata Définit une représentation alternative pour l'image. Si cet attribut est défini, le navigateur l'utilisera à la place de l'attribut "src".
src URL de l'image Un chemin vers l'image wbmp.
vspace
  • px
  • %
Définit un espace blanc au-dessus et en dessous de l'image. Si vous spécifiez la valeur en pixels, la syntaxe est "140" au lieu de "140px".
largeur
  • px
  • %
Définit la largeur de l'image. Si vous spécifiez la valeur en pixels, la syntaxe est "140" au lieu de "140px".
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Comment créer des images ".wbmp"

Il existe des outils gratuits disponibles sur Internet pour créer des images ".wbmp".

Le Nokia Mobile Internet Toolkit (NMIT) est fourni avec un éditeur d'images WBMP que vous pouvez utiliser. Vous pouvez convertir des fichiers image GIF ou JPG existants en fichier WBMP à l'aide de NMIT.

Un autre outil gratuit est ImageMagick , qui peut vous aider à créer des images WBMP.

Voici l'exemple montrant l'utilisation de l'élément <img>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="WML Images">
<p>
This is Thumb image
<img src="/images/thumb.wbmp" alt="Thumb Image"/>
</p>

<p>
This is Heart image
<img src="/images/heart.wbmp" alt="Heart Image"/>
</p>

</card>

</wml>

Cela produira le résultat suivant:

L'élément <table> avec <tr> et <td> est utilisé pour créer une table en WML. WML n'autorise pas l'imbrication des tables

Un élément <table> doit être placé avec des éléments <p> ... </p>.

L'élément <table /> prend en charge les attributs suivants:

Attribut Valeur La description
Colonnes nombre Définit le nombre de colonnes dans le tableau
aligner
  • L
  • C
  • R
Pour spécifier l'alignement horizontal du texte des colonnes, vous devez attribuer trois lettres à l'attribut align. Chaque lettre représente l'alignement horizontal du texte d'une colonne. La lettre peut être L, C ou R. Par exemple, si vous souhaitez que les paramètres suivants soient appliqués à votre tableau:
  • Première colonne du tableau - alignée à gauche

  • Deuxième colonne du tableau - alignée au centre

  • Troisième colonne du tableau - alignée à droite

Ensuite, vous devez définir la valeur de l' attribut align sur LCR.

xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <table>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="WML Tables">
<p>
<table columns="3" align="LCR">
	<tr>
	  <td>Col 1</td>
	  <td>Col 2</td>
	  <td>Col 3</td>
	</tr>

	<tr>
	  <td>A</td>
	  <td>B</td>
	  <td>C</td>
	</tr>

	<tr>
	  <td>D</td>
	  <td>E</td>
	  <td>F</td>
	</tr>
</table>
</p>
</card>

</wml>

Cela produira le résultat suivant:

WML vous offre la possibilité de lier diverses cartes à l'aide de liens, puis de parcourir différentes cartes.

Il existe deux éléments WML, <anchor> et <a>, qui peuvent être utilisés pour créer des liens WML.

Élément <anchor> WML:

La paire de balises <anchor> ... </anchor> est utilisée pour créer un lien d'ancrage. Il est utilisé avec d'autres éléments WML appelés <go />, <refresh> ou <prev />. Ces éléments sont appelés éléments de tâche et indiquent aux navigateurs WAP quoi faire lorsqu'un utilisateur sélectionne le lien d'ancrage

Vous pouvez insérer du texte ou une image avec une balise de tâche dans la paire de balises <anchor> ... </anchor>.

L'élément <anchor> prend en charge les attributs suivants:

Attribut Valeur La description
Titre cdata Définit un texte identifiant le lien
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <anchor>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Anchor Element">
<p>
   <anchor>
      <go href="nextpage.wml"/>
   </anchor>
</p>
<p>
   <anchor>
      <prev/>
   </anchor>
</p>
</card>

</wml>

Cela produira le résultat suivant:

Élément WML <a>:

La paire de balises <a> ... </a> peut également être utilisée pour créer un lien d'ancrage et toujours une manière préférée de créer des liens.

Vous pouvez insérer du texte ou une image dans des balises <a> ... </a>.

L'élément <a> prend en charge les attributs suivants:

Attribut Valeur La description
href URL Définit l'URL de la page aimée
Titre cdata Définit un texte identifiant le lien
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <a>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="A Element">
<p> Link to Next Page: 
   <a href="nextpage.wml">Next Page</a>
</p>
</card>

</wml>

Cela produira le résultat suivant:

Une tâche WML est un élément qui spécifie une action à effectuer par le navigateur, plutôt qu'un élément à afficher. Par exemple, l'action de passer à une nouvelle carte est représentée par un élément de tâche <go>, et l'action de retour à la carte précédente visitée est représentée par un élément de tâche <prev>. Les éléments de tâche encapsulent toutes les informations requises pour exécuter l'action.

WML fournit les quatre éléments suivants pour gérer quatre tâches WML appelées tâche aller, tâche préalable, tâche d'actualisation et tâches noop.

La tâche <go>:

Comme son nom l'indique, la tâche <go> représente l'action d'aller sur une nouvelle carte.

L'élément <go> prend en charge les attributs suivants:

Attribut Valeur La description
href URL Donne l'URL de la nouvelle carte. Les URL relatives sont résolues par rapport à la carte actuelle
méthode
  • get
  • post
Spécifie la méthode à utiliser pour récupérer le deck. Il doit s'agir de l'une des valeurs get ou post, correspondant aux méthodes GET et POST de HTTP.

Lors de l'utilisation method="get", les données sont envoyées sous forme de demande avec? données ajoutées à l'url. La méthode présente un inconvénient, car elle ne peut être utilisée que pour une quantité limitée de données, et si vous envoyez des informations sensibles, elles seront affichées à l'écran et enregistrées dans les journaux du serveur Web. N'utilisez donc pas cette méthode si vous envoyez un mot de passe, etc.

Avec method="post", les données sont envoyées sous forme de requête avec les données envoyées dans le corps de la requête. Cette méthode n'a pas de limite et les informations sensibles ne sont pas visibles dans l'URL

Sendreferer
  • true
  • false
S'il est défini sur true, le navigateur envoie l'URL du deck actuel avec la requête. Cette URL est envoyée en tant qu'URL relative si possible. Le but de ceci est de permettre aux serveurs d'effectuer un contrôle d'accès simple sur les decks, en fonction des decks qui leur sont liés. Par exemple, en utilisant HTTP, cet attribut est envoyé dans l'en-tête HTTP Referer.
accept-charset charset_list Spécifie une liste de jeux de caractères séparés par des virgules ou des espaces pouvant coder les données envoyées au serveur dans une requête POST. La valeur par défaut est "inconnue".
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <go>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="GO Element">
<p>
   <anchor>
       Chapter 2 : <go href="chapter2.wml"/>
   </anchor>
</p>
</card>
</wml>

Un autre exemple montrant comment télécharger des données à l'aide de la méthode Get

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="GO Element">
<p>
   <anchor>
      Using Get Method 
      <go href="chapter2.wml?x=17&y=42" method="get"/>
   </anchor>
</p>
</card>
</wml>

Un autre exemple montrant comment télécharger des données à l'aide de l'élément <setvar>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="GO Element">
<p>
   <anchor>
      Using setvar:
	  <go href="chapter2.wml"> 
	      <setvar name="x" value="17"/> 
  	      <setvar name="y" value="42"/> 
	  </go>
   </anchor>
</p>
</card>
</wml>

Un autre exemple montrant comment télécharger des données à l'aide de l'élément <postfiled>

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="GO Element">
<p>
   <anchor>
      Using setvar:
	  <go href="chapter2.wml" method="get"> 
              <postfield name="x" value="17"/>
              <postfield name="y" value="42"/>
	  </go>
   </anchor>
</p>
</card>
</wml>

La tâche <prev>:

La tâche <prev> représente l'action de revenir à la carte précédemment visitée sur la pile d'historique. Lorsque cette action est effectuée, l'entrée supérieure est supprimée de la pile d'historique et cette carte est à nouveau affichée, après que toutes les affectations de variable <setvar> dans la tâche <prev> ont pris effet.

Si aucune URL précédente n'existe, la spécification de <prev> n'a aucun effet.

L'élément <prev> prend en charge les attributs suivants:

Attribut Valeur La description
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <prev>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Prev Element">
<p>
   <anchor>
        Previous Page :<prev/>
   </anchor>
</p>
</card>
</wml>

Une situation où il peut être utile d'inclure des variables dans une tâche <prev> est une page de connexion, qui demande un nom d'utilisateur et un mot de passe. Dans certaines situations, vous souhaiterez peut-être effacer le champ du mot de passe lors du retour à la carte de connexion, obligeant l'utilisateur à le saisir à nouveau. Cela peut être fait avec une construction telle que:

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Prev Element">
<p>
   <anchor>
        <prev>
           <setvar name="password" value=""/>
        </prev>
   </anchor>
</p>
</card>
</wml>

La tâche <refresh>:

La tâche <refresh> est la tâche la plus simple qui fait réellement quelque chose. Son effet est simplement d'effectuer les affectations de variables spécifiées par ses éléments <setvar>, puis de réafficher la carte courante avec les nouvelles valeurs. Les tâches <go> et <prev> effectuent la même action juste avant d'afficher la nouvelle carte.

La tâche <refresh> est le plus souvent utilisée pour effectuer une sorte d'action "reset" sur la carte.

L'élément <refresh> prend en charge les attributs suivants:

Attribut Valeur La description
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <refresh>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Referesh Element">
<p>
   <anchor>
         Refresh this page:
          <go href="test.wml"/>
          <refresh>
            <setvar name="x" value="100"/>
          </refresh>
   </anchor>
</p>
</card>
</wml>

La tâche <noop>:

Le but de la tâche <noop> est de ne rien faire (aucune opération).

La seule réelle utilisation de cette tâche est en relation avec des modèles

L'élément <noop> prend en charge les attributs suivants:

Attribut Valeur La description
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <noop>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Noop Element">
<p>
  <do type="prev" label="Back">
      <noop/>
  </do>
</p>
</card>
</wml>

WML fournit diverses options pour permettre à un utilisateur d'entrer des informations via l'application WAP.

Tout d'abord, nous allons examiner les différentes options permettant à l'utilisateur de faire des choix directs entre les éléments. Ceux-ci se présentent généralement sous la forme de menus et de sous-menus, permettant aux utilisateurs d'accéder aux données exactes qu'ils souhaitent.

Élément <select> WML:

Les éléments <select> ... </select> WML sont utilisés pour définir une liste de sélection et les balises <option> ... </option> sont utilisées pour définir un élément dans une liste de sélection. Les éléments sont présentés sous forme de boutons radio dans certains navigateurs WAP. La paire de balises <option> ... </option> doit être incluse dans les balises <select> ... </select>.

Cet élément prend en charge les attributs suivants:

Attribut Valeur La description
mon nom texte Nomme la variable définie avec le résultat d'index de la sélection
ivalue texte Définit l'élément d'option présélectionné
plusieurs
  • true
  • false
Définit si plusieurs éléments peuvent être sélectionnés. La valeur par défaut est "false"
Nom texte Nomme la variable définie avec le résultat de la sélection
tabindex nombre Définit la position de tabulation de l'élément sélectionné
Titre texte Définit un titre pour la liste
valeur texte Définit la valeur par défaut de la variable dans l’attribut "nom"
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de ces deux éléments.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Selectable List">
<p> Select a Tutorial :
 <select>
  <option value="htm">HTML Tutorial</option>
  <option value="xml">XML Tutorial</option>
  <option value="wap">WAP Tutorial</option>
 </select>
</p>
</card>

</wml>

Lorsque vous chargerez ce programme, il vous montrera l'écran suivant:

Une fois que vous mettez en surbrillance et entrez les options, il affichera l'écran suivant:

Vous souhaitez fournir une option pour sélectionner plusieurs options, puis définir plusieurs attributs sur true comme suit:

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Selectable List">
<p> Select a Tutorial :
 <select multiple="true">
  <option value="htm">HTML Tutorial</option>
  <option value="xml">XML Tutorial</option>
  <option value="wap">WAP Tutorial</option>
 </select>
</p>
</card>

</wml>

Cela vous donnera un écran pour sélectionner plusieurs options comme suit:

Élément <input> WML:

L'élément <input /> est utilisé pour créer des champs d'entrée et les champs d'entrée sont utilisés pour obtenir des données alphanumériques des utilisateurs.

Cet élément prend en charge les attributs suivants:

Attribut Valeur La description
Nom texte Le nom de la variable qui est défini avec le résultat de l'entrée de l'utilisateur
longueur maximale nombre Définit le nombre maximum de caractères que l'utilisateur peut saisir dans le champ
emptyok
  • true
  • false
Définit si l'utilisateur peut laisser le champ de saisie vide ou non. La valeur par défaut est "false"
format A
a
N
X
x
M
m
* f
nf
Définit le format de données pour le champ de saisie. La valeur par défaut est "* M".

A = caractères alphabétiques ou de ponctuation majuscules a = caractères alphabétiques ou de ponctuation
minuscules
N = caractères numériques
X = caractères majuscules
x = caractères minuscules
M = tous les caractères
m = tous les caractères
* f = tout nombre de caractères. Remplacez le f par l'une des lettres ci-dessus pour spécifier les caractères que l'utilisateur peut saisir
nf = Remplacez le n par un nombre de 1 à 9 pour spécifier le nombre de caractères que l'utilisateur peut saisir. Remplacez le f par l'une des lettres ci-dessus pour spécifier les caractères que l'utilisateur peut saisir

Taille nombre Définit la largeur du champ de saisie
tabindex nombre Définit la position de tabulation de l'élément sélectionné
Titre texte Définit un titre pour la liste
type
  • text
  • password
Indique le type du champ de saisie. La valeur par défaut est "texte". Le champ de mot de passe est utilisé pour prendre le mot de passe à des fins d'authentification.
valeur texte Définit la valeur par défaut de la variable dans l’attribut "nom"
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de cet élément.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Input Fields">
<p> Enter Following Information:<br/> 
 Name: <input name="name" size="12"/>
 Age :  <input name="age" size="12" format="*N"/>
 Sex :  <input name="sex" size="12"/> 
</p>
</card>

</wml>

Cela vous fournira l'écran suivant pour saisir les informations requises:

Élément <fieldset> WML:

L'élément <fieldset /> est utilisé pour regrouper divers champs de saisie ou listes sélectionnables.

Cet élément prend en charge les attributs suivants:

Attribut Valeur La description
Titre texte Définit un titre pour la liste
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de cet élément.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Grouped Fields">
<p> 
<fieldset title="Personal Info">
 Name: <input name="name" size="12"/>
 Age :  <input name="age" size="12" format="*N"/>
 Sex :  <input name="sex" size="12"/> 
</fieldset>
</p>
</card>

</wml>

Cela vous fournira l'écran suivant pour saisir les informations requises. Ce résultat peut différer d'un navigateur à l'autre.

Élément <optgroup> WML

L'élément <optgroup /> est utilisé pour regrouper diverses options dans une liste sélectionnable.

Cet élément prend en charge les attributs suivants:

Attribut Valeur La description
Titre texte Définit un titre pour la liste
xml: lang language_code Définit la langue utilisée dans l'élément
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de cet élément.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Selectable List"> 
<p>
 <select>
   <optgroup title="India">
    <option value="delhi">Delhi</option>
    <option value="mumbai">Mumbai</option>
    <option value="hyderabad">Hyderabad</option>
   </optgroup>
   <optgroup title="USA">
    <option value="ohio">Ohio</option>
    <option value="maryland">Maryland</option>
    <option value="washington">Washingtone</option>
   </optgroup>
 </select>
</p>
</card>

</wml>

Lorsqu'un utilisateur charge le code ci-dessus, deux options seront alors sélectionnées:

Lorsqu'un utilisateur sélectionne l'une des options, alors seulement il donnera les options finales à sélectionner. Donc, si l'utilisateur sélectionne l'Inde, il vous montrera les options suivantes à sélectionner:

Plusieurs fois, vous souhaiterez que vos utilisateurs soumettent des données à votre serveur. Semblable au formulaire HTML, WML fournit également un mécanisme pour soumettre les données utilisateur au serveur Web.

Pour soumettre des données au serveur en WML, vous avez besoin des balises <go> ... </go> ainsi que des balises <postfield />. La balise <postfield /> doit être incluse dans la paire de balises <go> ... </go>.

Pour soumettre des données à un serveur, nous collectons toutes les variables WML définies et utilisons les éléments <postfield> pour les envoyer au serveur. Les éléments <go> ... </go> sont utilisés pour définir la méthode de publication sur POST ou GET et pour spécifier un script côté serveur pour gérer les données téléchargées.

Dans les chapitres précédents, nous avons expliqué différentes manières de recevoir des contributions des utilisateurs. Ces éléments d'entrée définissent les variables WML sur les valeurs entrées. Nous savons également comment prendre des valeurs à partir de variables WML. Alors maintenant, l'exemple suivant montre comment soumettre trois champs nom, âge et sexe au serveur.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card id="card1" title="WML Form">
<p>
   Name: <input name="name" size="12"/>
   Sex : <select name="sex">
      <option value="male">Male</option>
      <option value="female">Female</option>
      </select>
   Age :  <input name="age" size="12" format="*N"/>
   <anchor>
      <go method="get" href="process.php">
          <postfield name="name" value="$(name)"/>
          <postfield name="age" value="$(age)"/> <postfield name="sex" value="$(sex)"/>
      </go>
      Submit Data
    </anchor>
</p>
</card>

</wml>

Lorsque vous téléchargez le code ci-dessus sur votre appareil WAP, il vous donnera la possibilité de saisir trois champs nom, âge et sexe et un lien Soumettre les données . Vous entrerez trois champs, puis vous sélectionnerez enfin le lien Soumettre les données pour envoyer les données saisies au serveur.

L' attribut method de la balise <go> spécifie la méthode HTTP à utiliser pour envoyer les données du formulaire.

Si la méthode HTTP POST est utilisée, les données du formulaire à envoyer seront placées dans le corps du message de la requête. Si la méthode HTTP GET est utilisée, les données du formulaire à envoyer seront ajoutées à l'URL. Étant donné qu'une URL ne peut contenir qu'un nombre limité de caractères, la méthode GET présente l'inconvénient de limiter la taille des données à envoyer. Si les données utilisateur contiennent des caractères non ASCII, vous devez utiliser la méthode POST pour éviter les problèmes de codage.

Il existe une différence majeure entre HTML et WML. En HTML, l'attribut name des balises <input> et <select> est utilisé pour spécifier le nom du paramètre à envoyer, tandis qu'en WML l'attribut name de la balise <postfield> est utilisé pour faire la même chose. En WML, l'attribut name de <input> et <select> est utilisé pour spécifier le nom de la variable pour stocker les données du formulaire.

Le chapitre suivant vous apprendra comment gérer les données téléchargées à l'extrémité du serveur.

Si vous savez déjà comment écrire des scripts côté serveur pour une application Web, il est très simple pour vous d'écrire un programme côté serveur pour les applications WML. Vous pouvez utiliser votre technologie côté serveur préférée pour effectuer le traitement requis par votre application Internet mobile.

Côté serveur, le nom du paramètre sera utilisé pour récupérer les données du formulaire.

Prenons l'exemple suivant du chapitre précédent pour soumettre le nom, l'âge et le sexe d'une personne:

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card id="card1" title="WML Form">
<p>
   Name: <input name="name" size="12"/>
   Sex : <select name="sex">
      <option value="male">Male</option>
      <option value="female">Female</option>
      </select>
   Age :  <input name="age" size="12" format="*N"/>
   <anchor>
      <go method="get" href="process.php">
          <postfield name="name" value="$(name)"/> <postfield name="age" value="$(age)"/>
          <postfield name="sex" value="$(sex)"/>
      </go>
      Submit Data
    </anchor>
</p>
</card>

</wml>

WML et PHP

Maintenant, nous pouvons écrire un script côté serveur pour gérer ces données soumises en utilisant PHP, PERL, ASP ou JSP. Je vais vous montrer un script côté serveur écrit en PHP avec la méthode HTTP GET.

Placez le code PHP suivant dans le fichier process.php dans le même répertoire où vous avez votre fichier WML.

<?php echo 'Content-type: text/vnd.wap.wml'; ?>
<?php echo '<?xml version="1.0"?'.'>'; ?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>
  
  <card id="card1" title="WML Response">
    <p>
      Data received at the server:<br/>
      Name: <?php echo $_GET["name"]; ?><br/>
      Age: <?php echo $_GET["age"]; ?><br/> Sex: <?php echo $_GET["sex"]; ?><br/>
    </p>
  </card>

</wml>

Si vous utilisez la méthode HTTP POST, vous devez écrire un script PHP en conséquence pour gérer les données reçues. Lors de l'envoi de la sortie au navigateur, n'oubliez pas de définir le type MIME du document sur "text / vnd.wap.wml".

De cette façon, vous pouvez écrire une application Web à part entière où de nombreuses transactions de base de données sont impliquées.

Vous pouvez utiliser PERL CGI Concepts pour écrire un site WAP dynamique.

Un événement en langage ordinaire peut être défini comme quelque chose qui s'est passé. En programmation, eventest identique dans le sens, mais avec une différence majeure. Quand quelque chose se produit dans un système informatique, le système lui-même doit(1) détecter que quelque chose s'est passé et (2) savoir quoi faire à ce sujet.

Le langage WML prend également en charge les événements et vous pouvez spécifier une action à entreprendre chaque fois qu'un événement se produit. Cette action peut être en termes de WMLScript ou simplement en termes de WML.

WML prend en charge les quatre types d'événements suivants:

  • onenterbackward : cet événement se produit lorsque l'utilisateur frappe une carte par des moyens normaux de navigation arrière. Autrement dit, l'utilisateur appuie sur la touche Retour sur une carte ultérieure et revient à cette carte dans la pile d'historique.

  • onenterforward : cet événement se produit lorsque l'utilisateur frappe une carte par des moyens de navigation avant normaux.

  • onpick : Cela ressemble plus à un attribut mais il est utilisé comme un événement. Cet événement se produit lorsqu'un élément d'une liste de sélection est sélectionné ou désélectionné.

  • ontimer : Cet événement est utilisé pour déclencher un événement après une période donnée.

Ces noms d'événements sont sensibles à la casse et doivent être en minuscules.

Élément WML <onevent>:

Les balises <onevent> ... </onevent> sont utilisées pour créer des gestionnaires d'événements. Son utilisation prend la forme suivante:

<onevent type="event_type">
   A task to be performed.
</onevent>

Vous pouvez utiliser la tâche go, prev ou refresh dans les balises <onevent> ... </onevent> par rapport à un événement.

L'élément <onevent> prend en charge les attributs suivants:

Attribut Valeur La description
type
  • onenterbackward
  • onenterforward
  • onpick
  • ontimer
Définit un type d'événement survenu.
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <onevent>. Dans cet exemple, chaque fois que vous essayez de revenir de la deuxième carte à la première carte,onenterbackwardse produit ce qui vous amène à la carte numéro trois. Copiez et collez ce programme et essayez de jouer avec.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>
<onevent type="onenterbackward">
  <go href="#card3"/>
</onevent>

<card id="card1" title="Card 1">
<p>
  <anchor>
     <go href="#card2"/>
     Go to card 2
  </anchor>
</p>
</card>
<card id="card2" title="Card 2">
<p>
   <anchor>
   <prev/>
      Going backwards
   </anchor>
</p>
</card>
<card id="card3" title="Card 3">
<p>
Hello World!
</p>
</card>
</wml>

Le chapitre précédent a décrit comment les événements sont déclenchés par les utilisateurs et comment les gérons à l'aide de gestionnaires d'événements.

Parfois, vous voudrez peut-être que quelque chose se passe sans que l'utilisateur n'ait à activer explicitement un contrôle. Oui, WML vous offreontimer événement pour gérer cela.

L'événement ontimer est déclenché lorsque le minuteur d'une carte compte à rebours de un à zéro, ce qui signifie qu'il ne se produit pas si le minuteur est initialisé à un délai d'expiration de zéro.

Vous pouvez lier une tâche à cet événement avec l'élément <onevent>. Voici la syntaxe:

<onevent type="ontimer">
   A task to be performed.
</onevent>

Ici, une tâche peut être <go>, <prev> ou <refresh>.

Élément <timer> WML:

Un timer est déclaré dans une carte WML avec l'élément <timer>. Il doit suivre les éléments <onevent> s'ils sont présents. (S'il n'y a aucun élément <onevent>, le <timer> doit être le premier élément à l'intérieur de la <card>.) Il ne peut y avoir plus d'un <timer> dans une carte.

L'élément <timer> prend en charge les attributs suivants:

Attribut Valeur La description
Nom texte Définit un nom pour l'élément.
valeur nombre Spécifie la minuterie après laquelle la minuterie sera expirée. Les délais d'attente sont spécifiés en unités d'un dixième de seconde.
classe class_data Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <timer>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card id="splash" title="splash">
  <onevent type="ontimer">
    <go href="#welcome"/>
  </onevent>
  <timer value="50"/>
<p>
  <a href="#welcome">Enter</a>
</p>
</card>

<card id="welcome" title="Welcome">
<p>
Welcome to the main screen.
</p>
</card>
</wml>

Lorsque vous chargez ce programme, il vous montre l'écran suivant:

Si vous ne sélectionnez pas donné Enter option puis après 5 secondes, vous serez dirigé vers Welcome La page et l'écran suivant s'affichent automatiquement.

Le <template> est utilisé pour appliquer les éléments <do> et <onevent> à toutes les cartes d'un deck. Cet élément définit un modèle pour toutes les cartes d'un jeu et le code de la balise <template> est ajouté à chaque carte du jeu.

Vous pouvez remplacer un élément <do> d'un modèle en définissant un autre élément <do> avec la même valeur d'attribut de nom dans une carte WML.

L'élément <template> prend en charge les attributs suivants:

Attribut Valeur La description
onenterbackward URL Se produit lorsque l'utilisateur navigue dans une carte à l'aide d'une tâche "prev"
onenterforward URL Se produit lorsque l'utilisateur navigue dans une carte à l'aide d'une tâche "go"
au chronomètre URL Se produit lorsque le "minuteur" expire
classe données de classe Définit un nom de classe pour l'élément.
id ID d'élément Un identifiant unique pour l'élément.

Voici l'exemple montrant l'utilisation de l'élément <go>.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.3//EN" 
"http://www.wapforum.org/DTD/wml13.dtd">

<wml>
  <template>
    <do name="main_menu" type="accept" label="Chapters">
      <go href="chapters"/>
    </do>
    <do name="menu_1" type="accept" label="Chapter 1">
      <go href="#chapter1"/>
    </do>
    <do name="menu_2" type="accept" label="Chapter 2">
      <go href="#chapter2"/>
    </do>
    <do name="menu_3" type="accept" label="Chapter 3">
      <go href="#chapter3"/>
    </do>
    <do name="menu_4" type="accept" label="Chapter 4">
      <go href="#chapter4"/>
    </do>
  </template>

  <card id="chapters" title="WML Tutorial">
    <p>
      Select One Chapter:<br/>
      <anchor>
        <go href="#chapter1"/>
        Chapter 1: WML Overview
      </anchor><br />

      <anchor>
        <go href="#chapter2"/>
        Chapter 2: WML Environment
      </anchor><br />

      <anchor>
        <go href="#chapter3"/>
        Chapter 3: WML Syntax
      </anchor><br />

      <anchor>
        <go href="#chapter4"/>
        Chapter 4: WML Elements
      </anchor><br />
    </p>
  </card>

  <card id="chapter1" title="WML Tutorial Ch1">
    <p>
      <em>Chapter 1: WML Introduction</em><br/>
      ...
    </p>
  </card>

  <card id="chapter2" title="WML Tutorial Ch2">
    <p>
      <em>Chapter 2: WML Environment</em><br/>
      ...
    </p>
  </card>

  <card id="chapter3" title="WML Tutorial Ch3">
    <p>
      <em>Chapter 3: WML Syntax</em><br/>
      ...
    </p>
  </card>

  <card id="chapter4" title="WML Tutorial Ch4">
    <p>
      <em>Chapter 4: WML Elements</em><br/>
      ...
    </p>
  </card>
</wml>

Cela produira le menu suivant et maintenant vous pouvez naviguer à travers tous les chapitres:

Voici la DTD complète tirée de W3.org. Pour une dernière DTD, veuillez consulter la section Ressources utiles WML de ce didacticiel.

<!--
Wireless Markup Language (WML) Document Type Definition.
WML is an XML language. Typical usage:
   <?xml version="1.0"?>
   <!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
   "http://www.wapforum.org/DTD/wml12.dtd">
   <wml>
   ...
   </wml>

   Terms and conditions of use are available from the WAP Forum
   Ltd. web site at http://www.wapforum.org/docs/copyright.htm.
-->
<!ENTITY % length  "CDATA">         
   <!-- [0-9]+ for pixels or [0-9]+"%" for
   percentage length -->
<!ENTITY % vdata   "CDATA">         
   <!-- attribute value possibly containing
   variable references -->
<!ENTITY % HREF    "%vdata;">       
   <!-- URI, URL or URN designating a hypertext
   node. May contain variable references -->
<!ENTITY % boolean "(true|false)">
<!ENTITY % number  "NMTOKEN">       
   <!-- a number, with format [0-9]+ -->
<!ENTITY % coreattrs   "id     ID     #IMPLIED
                        class  CDATA  #IMPLIED">
<!ENTITY % ContentType "%vdata;">   
<!-- media type. May contain variable references -->

<!ENTITY % emph     "em | strong |b |i |u |big |small">
<!ENTITY % layout   "br">

<!ENTITY % text     "#PCDATA | %emph;">

<!-- flow covers "card-level" elements, 
                          such as text and images -->
<!ENTITY % flow     "%text; | %layout; | img | anchor |a |table">

<!-- Task types -->
<!ENTITY % task "go | prev | noop | refresh">

<!-- Navigation and event elements -->
<!ENTITY % navelmts "do | onevent">

<!--================ Decks and Cards ================-->

<!ELEMENT wml ( head?, template?, card+ )>
<!ATTLIST wml
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!-- card intrinsic events -->
<!ENTITY % cardev
  "onenterforward  %HREF;      #IMPLIED
  onenterbackward  %HREF;      #IMPLIED
  ontimer          %HREF;      #IMPLIED"
>

<!-- card field types -->
<!ENTITY % fields "%flow; | input | select | fieldset">
<!ELEMENT card (onevent*, timer?, (do | p | pre)*)>
<!ATTLIST card
  title            %vdata;     #IMPLIED
  newcontext       %boolean;   "false"
  ordered          %boolean;   "true"
  xml:lang         NMTOKEN     #IMPLIED
  %cardev;
  %coreattrs;
>

<!--================ Event Bindings ================-->

<!ELEMENT do (%task;)>
<!ATTLIST do
  type             CDATA       #REQUIRED
  label            %vdata;     #IMPLIED
  name             NMTOKEN     #IMPLIED
  optional         %boolean;   "false"
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT onevent (%task;)>
<!ATTLIST onevent
  type             CDATA       #REQUIRED
  %coreattrs;
>

<!--================ Deck-level declarations ================-->

<!ELEMENT head ( access | meta )+>
<!ATTLIST head
  %coreattrs;
>

<!ELEMENT template (%navelmts;)*>
<!ATTLIST template
  %cardev;
  %coreattrs;
>

<!ELEMENT access EMPTY>
<!ATTLIST access
  domain           CDATA       #IMPLIED
  path             CDATA       #IMPLIED
  %coreattrs;
>

<!ELEMENT meta EMPTY>
<!ATTLIST meta
  http-equiv       CDATA       #IMPLIED
  name             CDATA       #IMPLIED
  forua            %boolean;   "false"
  content          CDATA       #REQUIRED
  scheme           CDATA       #IMPLIED
  %coreattrs;
>

<!--================ Tasks ================-->

<!ELEMENT go (postfield | setvar)*>
<!ATTLIST go
  href             %HREF;          #REQUIRED
  sendreferer      %boolean;       "false"
  method           (post|get)      "get"
  enctype %ContentType; "application/x-www-form-urlencoded"
  accept-charset   CDATA           #IMPLIED
  %coreattrs;
>

<!ELEMENT prev (setvar)*>
<!ATTLIST prev
  %coreattrs;
>

<!ELEMENT refresh (setvar)*>
<!ATTLIST refresh
  %coreattrs;
>

<!ELEMENT noop EMPTY>
<!ATTLIST noop
  %coreattrs;
>

<!--================ postfield ================-->

<!ELEMENT postfield EMPTY>
<!ATTLIST postfield
  name             %vdata;     #REQUIRED
  value            %vdata;     #REQUIRED
  %coreattrs;
>

<!--================ variables ================-->

<!ELEMENT setvar EMPTY>
<!ATTLIST setvar
  name             %vdata;     #REQUIRED
  value            %vdata;     #REQUIRED
  %coreattrs;
>

<!--================ Card Fields ================-->

<!ELEMENT select (optgroup|option)+>
<!ATTLIST select
  title            %vdata;     #IMPLIED
  name             NMTOKEN     #IMPLIED
  value            %vdata;     #IMPLIED
  iname            NMTOKEN     #IMPLIED
  ivalue           %vdata;     #IMPLIED
  multiple         %boolean;   "false"
  tabindex         %number;    #IMPLIED
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT optgroup (optgroup|option)+ >
<!ATTLIST optgroup
  title            %vdata;     #IMPLIED
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT option (#PCDATA | onevent)*>
<!ATTLIST option
  value            %vdata;     #IMPLIED
  title            %vdata;     #IMPLIED
  onpick           %HREF;      #IMPLIED
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT input EMPTY>
<!ATTLIST input
  name             NMTOKEN         #REQUIRED
  type             (text|password) "text"
  value            %vdata;         #IMPLIED
  format           CDATA           #IMPLIED
  emptyok          %boolean;       "false"
  size             %number;        #IMPLIED
  maxlength        %number;        #IMPLIED
  tabindex         %number;        #IMPLIED
  title            %vdata;         #IMPLIED
  accesskey        %vdata;         #IMPLIED
  xml:lang         NMTOKEN         #IMPLIED
  %coreattrs;
>

<!ELEMENT fieldset (%fields; | do)* >
<!ATTLIST fieldset
  title           %vdata;      #IMPLIED
  xml:lang        NMTOKEN      #IMPLIED
  %coreattrs;
>

<!ELEMENT timer EMPTY>
<!ATTLIST timer
  name             NMTOKEN     #IMPLIED
  value            %vdata;     #REQUIRED
  %coreattrs;
>

<!--================ Images ================-->

<!ENTITY % IAlign "(top|middle|bottom)" >
<!ELEMENT img EMPTY>
<!ATTLIST img
  alt              %vdata;     #REQUIRED
  src              %HREF;      #REQUIRED
  localsrc         %vdata;     #IMPLIED
  vspace           %length;    "0"
  hspace           %length;    "0"
  align            %IAlign;    "bottom"
  height           %length;    #IMPLIED
  width            %length;    #IMPLIED
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!--================ Anchor ================-->

<!ELEMENT anchor ( #PCDATA | br | img | go | prev | refresh )*>
<!ATTLIST anchor
  title            %vdata;     #IMPLIED
  accesskey        %vdata;     #IMPLIED
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>
<!ELEMENT a ( #PCDATA | br | img )*>
<!ATTLIST a
  href             %HREF;      #REQUIRED
  title            %vdata;     #IMPLIED
  accesskey        %vdata;     #IMPLIED
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!--================ Tables ================-->

<!ELEMENT table (tr)+>
<!ATTLIST table
  title            %vdata;     #IMPLIED
  align            CDATA       #IMPLIED
  columns          %number;    #REQUIRED
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT tr (td)+>
<!ATTLIST tr
  %coreattrs;
>
<!ELEMENT td ( %text; | %layout; | img | anchor |a )*>
<!ATTLIST td
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!--============ Text layout and line breaks =============-->

<!ELEMENT em (%flow;)*>
<!ATTLIST em
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT strong (%flow;)*>
<!ATTLIST strong
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT b (%flow;)*>
<!ATTLIST b
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT i (%flow;)*>
<!ATTLIST i
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT u (%flow;)*>
<!ATTLIST u
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT big (%flow;)*>
<!ATTLIST big
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT small (%flow;)*>
<!ATTLIST small
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ENTITY % TAlign    "(left|right|center)">
<!ENTITY % WrapMode  "(wrap|nowrap)" >

<!ELEMENT p (%fields; | do)*>
<!ATTLIST p
  align            %TAlign;    "left"
  mode             %WrapMode;  #IMPLIED
  xml:lang         NMTOKEN     #IMPLIED
  %coreattrs;
>

<!ELEMENT br EMPTY>
<!ATTLIST br
  %coreattrs;
>

<!ELEMENT pre (#PCDATA | a | br | i | b | em | strong | 
                                         input | select )*>
<!ATTLIST pre
  xml:space        CDATA       #FIXED    "preserve"
  %coreattrs;
>

<!ENTITY quot """>       <!-- quotation mark -->
<!ENTITY amp  "&#38;">   <!-- ampersand -->
<!ENTITY apos "'">       <!-- apostrophe -->
<!ENTITY lt   "&#60;">   <!-- less than -->
<!ENTITY gt   ">">       <!-- greater than -->
<!ENTITY nbsp " ">      <!-- non-breaking space -->
<!ENTITY shy  "­"> <!-- soft hyphen (discretionary hyphen) -->

WML2 est un langage qui étend la syntaxe et la sémantique des éléments suivants:

  • XHTML Basic [ XHTMLBasic ]
  • CSS Mobile Profile [ CSSMP ]
  • Unique semantics of WML1.0 [ WML1.0 ]

WML2 est optimisé pour spécifier la présentation et l'interaction de l'utilisateur sur des appareils à capacité limitée tels que les téléphones mobiles et autres terminaux mobiles sans fil.

Ce didacticiel donne des détails sur la version 2 du langage de balisage sans fil (WML). Ce didacticiel fait référence à la version 2.0 de WML en tant que WML2.

Le XHTML Basic défini par le W3C est un sous-ensemble approprié de XHTML, qui est une reformulation du HTML en XML.

Objectifs de base de WML2:

Il y a cinq objectifs majeurs pour WML2:

  • Backward compatibility: L'application WML2 doit également être exécutée sur d'anciens appareils.

  • Convergence with existing and evolving Internet standards: XHTML Basic [XHTMLBasic] et CSS Mobile Profile [CSSMP]

  • Optimisation of access from small, limited devices:Les appareils compatibles WAP sont généralement petits et alimentés par batterie et ils ont une mémoire et une puissance CPU relativement limitées. Donc, WML2 doit être suffisamment optimisé pour fonctionner sur ces appareils.

  • Allowance for the creation of distinct user interfaces: Le WAP permet la création d'interfaces homme-machine (MMI) avec une flexibilité et une capacité maximales pour un fournisseur d'améliorer l'expérience utilisateur.

  • Internationalisation of the architecture:Le WAP cible les codes de caractères communs à usage international. Cela comprend les symboles internationaux et les jeux de pictogrammes pour les utilisateurs finaux, ainsi que le codage de caractères à usage local pour les développeurs de contenu.

Vision WML2:

La vision de WML2 est de créer un langage qui étend la syntaxe et la sémantique du profil XHTML Basic et CSS Mobile avec la sémantique unique de WML1. L'utilisateur ne doit pas savoir comment la compatibilité WML1 est obtenue.

La structure du langage WML2:

WML2 est un nouveau langage avec les composants suivants:

(1) XHTML basique:

Ce groupe d'éléments est destiné à la convergence W3C. Pour certains des éléments, des attributs d'extension WML sont ajoutés afin d'obtenir la fonctionnalité WML1.

(1a) Éléments de base XHTML:

a abbr acronyme adresse base blockquote br légende cite code dd dfn div dl dt em formulaire h1 h2 h3 h4 h5 h6 tête kbd label li lien objet ol param pre q samp span table forte td th titre tr ul var

(1b) Éléments XHTML Basic avec attributs d'extension WML:

body html img entrée méta option p sélectionnez style textarea

(2) Éléments de modularisation XHTML:

Ce groupe d'éléments se compose de certains éléments de ces modules de XHTML non inclus dans XHTML Basic. La plupart des éléments sont inclus pour la compatibilité WML1. Un élément est inclus comme une amélioration qui s'adapte aux capacités limitées du combiné.

(2a) Modularisation XHTML pour la rétrocompatibilité avec WML1:

b big i small (à partir du module de présentation) u (à partir du module hérité) fieldset optgroup (à partir du module Forms)

(2b) Éléments de modularisation XHTML pour l'amélioration des fonctionnalités:

heure

(3) Éléments d'extensions WML:

Certains éléments sont importés de WML1, car les capacités équivalentes ne sont pas fournies dans XHTML Basic ou XHTML Modularization. Un élément est inclus pour l'amélioration des capacités WML1.

(3a) Eléments d'extensions WML (pour la compatibilité WML1):

wml: accès wml: ancre wml: carte wml: do wml: getvar wml: go wml: noop wml: onevent wml: postfield wml: prev wml: actualiser wml: setvar wml: timer

(3b) Éléments d'extensions WML (pour l'amélioration des fonctionnalités):

wml: widget

Modules de structure de document WML:

Les éléments suivants du module Structure sont utilisés pour spécifier la structure d'un document WML2:

  • body
  • html
  • wml:card
  • head
  • title

L'élément corps:

L'attribut wml: newcontext spécifie si le contexte du navigateur est initialisé à un état bien défini lorsque le document est chargé. Si la valeur de l'attribut wml: newcontext est "true", le navigateur DOIT réinitialiser le contexte du navigateur lors de la navigation vers cette carte.

L'élément html:

L'attribut xmlns: wml fait référence à l'espace de noms WML par exemple: http://www.wapforum.org/2001/wml.

L'attribut wml: use-xml-fragments est utilisé pour spécifier la manière dont un identificateur de fragment est interprété par l'agent utilisateur. Pour plus de détails sur l'utilisation de wml: use-xml-fragments dans la tâche go et la tâche prev.

L'élément wml: card:

L'élément wml: card spécifie un fragment du corps du document. Plusieurs éléments wml: card peuvent apparaître dans un seul document. Chaque élément wml: card représente une présentation individuelle et / ou une interaction avec l'utilisateur.

Si la valeur d'attribut newcontext de l'élément wml: card est "true", le navigateur DOIT réinitialiser le contexte du navigateur lors de la navigation vers cette carte.

L'élément de tête:

Cet élément conserve les informations d'en-tête du document comme le méta-élément et la feuille de style, etc.

L'élément titre:

Cet élément sert à mettre un titre de document

NOTE:Les développeurs WML peuvent utiliser le style de document XHTML, c'est-à-dire la structure du corps, ou ils peuvent utiliser une collection de cartes. Lorsque la structure du corps est utilisée, un document est construit à l'aide d'un élément du corps. L'élément body contient le contenu du document. Lorsqu'une collection de cartes est utilisée, un document est construit à l'aide d'un ou plusieurs éléments wml: card.

Tâches WML2

Les tâches suivantes sont définies dans WML2.0. Ces tâches sont très similaires à WML1.0

  • La tâche aller
  • La tâche précédente
  • La tâche noop
  • La tâche de rafraîchissement

Événements WML2:

Les types d'événements suivants sont définis dans WML2:

  • Intrinsic event: Un événement généré par l'agent utilisateur et comprend les événements suivants similaires à WML1.0

    • ontimer
    • onenterforward
    • onenterbackward
    • onpick
  • Extrinsic event:Un événement envoyé à l'agent utilisateur par un agent externe. La spécification WML 2 ne spécifie aucune classe d'événements extrinsèques. Les événements WTA sont un exemple de classe d'événements extrinsèques WML

Type de document WML2:

Les documents WML2 sont identifiés par le type de support MIME "application / wml + xml". Le type "application / xhtml + xml" peut être utilisé pour identifier des documents à partir de n'importe quel langage de balisage basé sur XHTML, y compris XHTML Basic.

La déclaration DOCTYPE peut inclure l'identificateur public formel de base XHTML et peut également inclure l'URI de la DTD de base XHTML comme spécifié ci-dessous:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.0//EN"
"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd">

Feuilles de style avec WML2

Les feuilles de style peuvent être utilisées pour styliser les documents WML2. Les informations de style peuvent être associées à un document de 3 manières:

Feuille de style externe:

Une feuille de style externe peut être associée à un document à l'aide d'une instruction de traitement XML spéciale ou de l'élément link. L'utilisation de l'instruction de traitement XML peut également être utilisée.

Dans l'exemple suivant, l'instruction de traitement XML est utilisée pour associer la feuille de style externe "mobile.css".

<?xml-stylesheet href="mobile.css" 
                    media="handheld" type="text/css" ?>

Dans l'exemple suivant, l'élément link est utilisé pour associer la feuille de style externe "mystyle.css":

<html>
<head>
<link href="mystyle.css" type="text/css" rel="stylesheet"/>
...
</head>
...
</html>

Feuilles de style internes:

Les informations de style peuvent être localisées dans le document à l'aide de l'élément style. Cet élément, comme le lien, doit être situé dans l'en-tête du document.

Voici un exemple de feuille de style interne:

<html>
<head>
<style type="text/css">
p { text-align: center; }
</style>
...
</head>
...
</html>

Style en ligne:

Vous pouvez spécifier des informations de style pour un seul élément à l'aide de l' attribut style . C'est ce qu'on appelle le style en ligne.

Dans l'exemple suivant, les informations de style en ligne sont appliquées à un élément de paragraphe spécifique:

<p style="text-align: center">...</p>

La feuille de style par défaut WML2:

Voici un exemple de feuille de style pour WML 2.0:

body, card, div, p, center, hr, h1, h2, h3, h4, h5, h6,
address, blockquote, pre, ol, ul, dl, dt, dd,
form, fieldset, object { display: block }
li      { display: list-item }
head    { display: none }
table   { display: table }
tr      { display: table-row }
td, th  { display: table-cell }
caption { display: table-caption }
th      { font-weight: bolder; text-align: center }
caption { text-align: center }
h1, h2, h3, h4, h5, h6, b, strong { font-weight: bolder }
i, cite, em, var,address { font-style: italic }
pre, code, kbd, pre { white-space: pre }
big     { font-size: larger}
small   { font-size: smaller}
hr      { border: 1px inset }
ol      { list-style-type: decimal }
u       { text-decoration: underline }

Les éléments WML2:

Voici un lien vers une liste complète de tous les éléments WML2. La plupart des éléments sont disponibles dans la spécification XHTML à l'exception de quelques éléments commençant par WML: Ces éléments sont spécifiques à WML.

Tous les éléments ont ici la même signification que ce qu'ils ont dans la spécification XHTML.

Référence des balises WML2

Sommaire:

Nous pouvons conclure que si vous connaissez XHTML et WML1.0, vous n'avez rien à faire pour apprendre WML2.0

Si vous souhaitez en savoir plus, vous trouverez ici les spécifications complètes pour WAP2.0 et WML2.0

Les entités WML doivent représenter des symboles qui ne peuvent pas être facilement saisis ou qui ont une signification particulière dans WML.

Par exemple, si vous mettez normalement un caractère <dans votre texte, le navigateur pense que c'est le début d'une balise; le navigateur se plaint alors lorsqu'il ne trouve pas le caractère> correspondant pour terminer la balise.

Le tableau suivant affiche les trois formes d'entités dans WML. Les entités nommées sont quelque chose que vous connaissez peut-être en HTML: elles ressemblent à & amp; ou & lt ;, et ils représentent un seul caractère nommé via un nom mnémonique. Les entités peuvent également être saisies sous l'une des deux formes numériques (décimale ou hexadécimale), vous permettant de saisir n'importe quel caractère Unicode dans votre WML.

Entité nommée Entité décimale Entité hexa Personnage
& quot; & # 34; & # x22; Double citation (")
& amp; & # 38; & # x26; Esperluette (&)
& apos; & # 39; & # x27; Apostrophe (')
& lt; & # 60; & # x3C; Moins de (<)
& gt; & # 62; & # x3E; Supérieur à (>)
& nbsp; & # 160; & # xA0; Espace non-cassant
&timide; & # 173; & # xAD; Trait d'union souple

Notez que toutes les entités commencent par une esperluette (&) et se terminent par un point-virgule (;). Ce point-virgule est très important: certaines pages Web l'oublient et posent des problèmes aux navigateurs qui veulent du HTML correct. Les navigateurs WAP sont également susceptibles d'être plus stricts sur les erreurs comme celles-ci.

Le tableau suivant répertorie tous les éléments WML valides. Cliquez sur les liens pour en savoir plus sur cet élément

Éléments de deck et de carte

Éléments WML Objectif
  Définit un commentaire WML
Définit un deck WML (racine WML)
Définit les informations de la tête
Définit les méta-informations
Définit une carte dans un deck
Définit les informations sur le contrôle d'accès d'un deck
Définit un modèle de code pour toutes les cartes d'un jeu

Éléments de texte

Éléments WML Objectif

Définit un saut de ligne

 

Définit un paragraphe
Définit une table
Définit une cellule de tableau (données de table)
Définit une ligne de tableau
Définit le texte préformaté

Balises de formatage de texte

Éléments WML Objectif
Définit le texte en gras
  Définit le gros texte
Définit le texte mis en évidence
Définit le texte en italique
Définit le petit texte
Définit le texte fort
Définit le texte souligné

Éléments d'image

Éléments WML Objectif
Définit une image

Éléments d'ancrage

Éléments WML Objectif
Définit une ancre
  Définit une ancre

Éléments d'événement

Éléments WML Objectif
Définit un gestionnaire d'événements do
Définit un gestionnaire d'événements onevent
Définit un gestionnaire d'événements postfield
Définit un gestionnaire d'événements ontimer
Définit un gestionnaire onenterforward
Définit un gestionnaire onenterbackward
Définit un gestionnaire d'événements onpick

Éléments de tâche

Éléments WML Objectif
Représente l'action de passer à une nouvelle carte
Dit que rien ne devrait être fait
Représente l'action de revenir à la carte précédente
Actualise certaines variables de carte spécifiées.

Éléments d'entrée

Éléments WML Objectif
  Définit un champ de saisie
Définit un groupe de sélection
Définit une option dans une liste sélectionnable
Définit un ensemble de champs de saisie
Définit un groupe d'options dans une liste sélectionnable

Éléments variables

Éléments WML Objectif
Définit et définit une variable
Définit une minuterie

Au lieu d'installer un SDK WAP complet, vous pouvez installer un émulateur WML. Un émulateur vous permet simplement d'afficher le contenu de vos fichiers WML tel qu'il apparaîtrait sur l'écran d'un appareil compatible WAP.

Bien que les émulateurs fassent un excellent travail, ils ne sont pas parfaits. Essayez-en quelques-uns et vous déciderez rapidement ce que vous aimez le plus. Lorsque vient le temps de développer un vrai site WAP (commercial), vous devrez faire beaucoup plus de tests, d'abord avec d'autres SDK / émulateurs, puis avec tous les appareils compatibles WAP que vous prévoyez de prendre en charge.

La liste suivante répertorie certains des émulateurs WAP disponibles gratuitement:

  • Navigateur Klondike WAP : Il est produit par Apache Software. Klondike ressemble beaucoup à un navigateur Web et est donc très facile à utiliser pour les débutants. Vous pouvez accéder facilement aux fichiers WML locaux. Il prend également en charge le glisser-déposer, ce qui rend l'utilisation des fichiers locaux très facile.

  • Yospace : Ceci est produit par Yospace. Les développeurs WAP peuvent utiliser l'édition de bureau de l'émulateur pour prévisualiser les applications WAP à partir de leur bureau, en sachant que l'émulateur fournit une reproduction raisonnablement fidèle des produits réels du combiné.

  • Emulateur Ericsson R380 : il est produit par Ericsson. L'émulateur WAP R380 est destiné à être utilisé pour tester les applications WML développées pour le navigateur WAP dans l'Ericsson R380. L'émulateur contient le navigateur WAP et la fonctionnalité de paramètres WAP qui se trouvent dans le R380.

  • WinWAP : Ceci est produit par Slob-Trot Software. WinWAP est un navigateur WML qui fonctionne sur n'importe quel ordinateur avec Windows 32 bits installé. Vous pouvez parcourir les fichiers WML localement à partir de votre disque dur ou sur Internet avec HTTP (comme avec votre navigateur Web normal).

  • Simulateur Nokia WAP - Il est produit par Nokia et doté de presque toutes les fonctionnalités. Essaye celui-là.

Validez le contenu WML:

Copiez et collez le contenu WML dans la zone suivante, puis cliquez sur Valider WML pour voir le résultat au bas de cette page:

Validez le fichier WML:

Tapez l'URL de votre page WML, puis cliquez sur Valider WML pour voir le résultat au bas de cette page: