Réalisation : Van Lancker Luc
Bref préambuleAprès le Html et le Javascript, il était logique de s'intéresser à cet autre langage de script qu'est le VBscript. Plutôt qu'un long tutorial, ce chapitre consacré au VBscript est surtout à considérer comme un tour d'horizon des possibilités de Vbscript. Bien que la tentation fut grande, j'ai évité de faire de ce qui suit, un match Javascript contre VBscript ou même Netscape contre Microsoft. D'autres s'en chargent... Le VBscript
VBscript est un langage de scripts
qui incorporé aux balises html
permet d'améliorer la présentation
et l'interactivité des pages Web.
VBscript est donc une extension du code Html des pages Web. Les scripts sont en quelque sorte des ajoutes au code Html. Ces scripts vont être interprétés et exécutés par le navigateur (donc côté client) sans devoir faire appel aux ressources du serveur. VBscript (pour Microsoft Visual Basic Scripting Edition) a été développé par Microsoft qui a repris la logique et la syntaxe de son Visual Basic (d'où le VB). Bien que quelques fonctions lui soient propres, on peut considérer VBscript comme un sous-ensemble de Visual Basic. Pour l'instant, les seuls browsers qui reconnaissent le VBscript sont les navigateurs de la firme Microsoft, soit Internet Explorer. VBscript ouvre la porte aux différents produits de Microsoft dédiés au Web et principalement aux ActiveX et autres ASP. Ce qui peut être particulièrement adapté dans le cas d'un réseau Intranet. Dans l'inévitable compétition avec cet autre langage de script qu'est Javascript, l'avenir de VBscript dépendra en grande partie des autres navigateurs qui adopteront les routines VBscript. Vous pensez du côté de Netscape ? Moi aussi ! VBscript ou JavascriptPour le moins qu'on puisse dire, VBscript et Javascript sont très semblables quant à leur philosophie et leur mode de fonctionnement. Heureusement quelques différences, et non des moindres, en font deux outils totalement différents.
Même sans comprendre (à ce stade de cette introduction) les scripts, il peut être intéressant de comparer deux scripts identiques en VBscript et Javascript.
VBscript et Javascript sont donc assez semblables. Ils diffèrent surtout par le langage dont ils sont dérivés, soit Visual Basic pour le VBscript et le langage C et C++ pour le Javascript. Pour terminer, je voudrais ajouter qui si VBscript ressemble à du Javascript, il n'est en rien comparable à du Java. Cette confusion entre Javascript et Java est assez classique. En deux mots, Java est un langage du programmation à part entière, il forme un module (applet) distinct de la page Html et son code source est compilé avant son exécution. VBscript et ActiveXComme pour l'utilisateur le résultat final est identique, on serait tenté de dire que ActiveX est à VBscript ce que les applets Java sont à Javascript. Mais ceci est une approche trop simpliste car le concept d'ActiveX est une technologie sensiblement différente. ActiveX est une plate-forme d'intégration ouverte qui fournit aux développeurs, aux utilisateurs et aux réalisateurs de Web le moyen le plus rapide et le plus facile de créer de nouvelles applications et de nouveaux contenus pour Internet et pour les Intranets." Microsoft présente donc son produit ActiveX comme un outil d'intégration de technologies permettant de créer des pages interactives sur le Web. L'idée de départ à été de profiter de l'expérience de Microsoft en matière de partage entre diverses applications (la technologie des Dll, Ole et autres VBX) pour la transposer sur le Web en recréant un tout un environnement dédié (au départ) à Windows. Les contrôles ActiveX peuvent être écrits dans différents langages de programmation comme le C, le C++, Pascal (Delphi), Visual Basic 5 ou Microsoft Visual J++. Ainsi, au contraire d'un langage de script comme VBscript, on évolue ici dans le monde de la programmation ce qui ne rend pas les choses particulièrement simples. L'appel à ses composants ActiveX est inséré dans une page Web par une combinaison de Html et de VBscript et spécialement par la balise <OBJECT> ... </OBJET> qui comprend de nombreux attributs. Nous y reviendrons plus loin dans cette introduction à VBscript sur l'incorporation des contrôles ActiveX dans vos pages Html. Lorsque Internet Explorer rencontre un appel à un contrôle ActiveX, celui-ci, situé initialement sur un serveur, explore votre machine [je n'aime pas trop ...] pour voir si le contrôle n'est pas déjà présent. Si le contrôle est absent ou d'une version plus ancienne, tous les fichiers nécessaires seront téléchargés et copiés sur votre disque dur [je n'aime pas trop ...]. Et à la différence des applets Java, les composants ActiveX resteront sur le disque dur de l'utilisateur et feront partie intégrante de son environnement Windows [je n'aime pas trop ...]. Vous aurez deviné que ce fonctionnement peut poser des problèmes de sécurité. Microsoft utilise un système de source "sûre" ou "d'autorité certifiée" (Certificate Authority). Chaque composant est en quelque manière "signé" de manière à garantir son origine. De toute façon, Internet Explorer vous demande si vous acceptez les composants provenant de cette source. Dans la pratique, l'utilisateur moyen ou tout simplement prudent d'Internet rechignera à laisser librement installer des composants sur sa machine. En reprenant mot à mot un extrait d'une documentation de Microsoft : "Avec Internet, en revanche, les utilisateurs reçoivent généralement votre composant comme un effet de l'exploration et ne feront fonctionner aucun programme d'installation". Tout ceci rejoint notre opinion que le tandem VBscript et ActiveX est, pour l'instant du moins, plutôt une solution pour Intranet que pour Internet. Terminons en signalant que si VBscript n'est pas accepté par Netscape, les contrôles ActiveX par contre peuvent être lus par Netscape par l'entremise d'un plug-in fourni par Microsoft. Les outils pour VBscriptPour apprendre et utiliser le VBscript, il vous faut :
Un browser compatible VBscriptLe choix est limité aux seuls browsers de la firme Microsoft. Ce sera soit Microsoft Internet Explorer 3, soit Microsoft Internet Explorer 4 et aucun autre !
Pour les accros des versions : Une solide connaissance du HtmlVBscript ne remplace pas le langage Html. Au contraire, comme VBscript vient s'ajouter aux codes Html, une connaissance approfondie des balises et tags Html est souhaitable sinon indispensable. Les utilisateurs assidus des éditeurs Html "wysiwyg" risquent de devoir retourner à leurs chères études. Je ne peux que vous recommander le tutorial : "Le point sur les balises HTML". Un simple éditeur de texteUne page Html n'est que du texte. Le code VBscript n'est lui aussi que du texte. Quoi de plus simple que d'utiliser un éditeur de ... texte. Le bloc-notes de Windows, fera parfaitement l'affaire (vous resterez ainsi dans la famille Microsoft). Un éditeur Html de la première génération (un bon vieil éditeur qui n'est pas whsiwyg et qui fait apparaître les balises) fait également bien l'affaire. Un peu de théorie objetLes objets et leur hiérarchie En bon internaute, vous voyez sur votre écran une page Web. VBscript va diviser cette page en objets et surtout va vous permettre d'accéder à ces objets, d'en retirer des informations et de les manipuler. Voyons d'abord une illustration des différents objets qu'une page peut contenir. Vous avez chargé la page suivante : Dans votre browser, il y a une page Web qui n'est rien d'autre qu'un document Html. C'est l'objet document. Dans ce document, on trouve un formulaire au sens Html du terme. C'est l'objet formulaire. Autrement dit (et c'est là que l'on voit apparaître la notion de la hiérarchie des objets VBscript), l'objet document contient un objet formulaire. Dans ce document, on trouve deux objets. Des boutons checkbox et une zone de texte. Ce sont respectivement l'objet checkbox et l'objet texte. Autrement dit l'objet document contient l'objet formulaire qui contient à son tour l'objet radio et l'objet document contient aussi l'objet formulaire qui contient à son tour l'objet texte. La hiérarchie des objets de cet exemple est donc :
Pour accéder à un objet (vous l'avez peut-être déjà deviné), il faudra donner le chemin complet de l'objet (ou la généalogie complète de l'objet) en allant du contenant le plus extérieur à l'objet à l'objet référencé. Soit par exemple pour le bouton checkbox : document.formulaire.checkbox ou pour la zone de texte document.formulaire.texte. Le VBscript minimumLa balise <SCRIPT>Le langage Html utilise des balises pour "dire" au navigateur d'afficher du texte en gras, des images, des liens, etc. Dans la logique du Html, il faut donc signaler au browser par un tag que ce qui suit est un script et que c'est du VBscript (et non du Javascript). C'est la balise <SCRIPT language="VBscript">. De même, il faudra informer le browser de la fin du script. C'est la balise </SCRIPT>. Les commentairesIl vous sera peut-être utile d'inclure de commentaires personnels dans vos codes VBscript. VBscript utilise les conventions de Visual Basic, soit : ' commentaires
ou
Rem commentaires
Tout ce qui est écrit après l'apostrophe ou le mot clé Rem sera ignoré.
Masquer le script pour les autres browsersLes browsers qui ignorent la balise <script>, vont afficher le code VBscript comme du texte. Pour éviter l'affichage de ce charabia, on utilise les balises de commentaire du Html soit <!-- et -->. Votre premier VBscript ressemblera à ceci :
Où inclure la balise de scriptLe browser traite votre page Html, y compris vos ajoutes en VBscript de haut en bas. Toute instruction ne pourra être exécutée que si le browser possède à ce moment précis tous les éléments nécessaire à son exécution. Au moment de l'exécution. La balise de script apparaît alors à l'intérieur des tags <BODY> </BODY>. Pour s'assurer que le programme VBscript est bien chargé et prêt à fonctionner à toute intervention de votre visiteur, on prendra l'habitude de déclarer systématiquement (lorsque cela sera possible) un maximum d'éléments dans les balises d'en-tête soit entre <HEAD> et </HEAD> et avant la balise <BODY>. Ce sera le cas par exemple pour les procédures ou fonctions. Dans certains cas, la balise de script ne devra même pas être utilisée. Ce sera le cas pour les ajouts de script dans les contrôles de formulaire. Nous y reviendrons plus tard. Rien n'interdit d'inclure plusieurs scripts dans la même page Html. Attention : VBscript est case sensitive. Ainsi il faudra écrire write et non Write. Pour l'écriture des instructions VBscript, on utilisera l'alphabet ASCII classique (à 128 caractères) comme en Html. Les caractères accentués comme é ou à ne peuvent être employés que dans les chaînes de caractères c.-à-d. dans votre texte de notre exemple. Votre première page Html avec du VBscript
<HTML> <HEAD> </HEAD> <BODY> ... Html normal ... Les boites de messageLa boite de message - MsgBox -Petite boite d'un usage simple mais au combien utile. Cette boite affiche votre message et reste à l'écran aussi longtemps que le lecteur ne clique sur le bouton OK pour confirmer la bonne réception du message. La syntaxe est de plus simple :
MsgBox "votre texte"
Voici un exemple :
MsgBox "Message reçu ?"
Cette boite de message sera souvent utilisée pour corriger les scripts présentant des erreurs. Ainsi, MsgBox variable, affichera le contenu de la variable à cet endroit du script ou MsgBox "jusqu'ici", vous permettra de voir jusqu'où se déroule le script erroné. Nous y reviendrons dans le chapitre intitulé "Les messages d'erreurs". Vous pouvez aussi afficher du texte sur plusieurs lignes. Pour se faire, il suffit d'employer le mot-clé vbCrLf ou Chr (13) ou Chr (13) & Chr (10). Ainsi
MsgBox "Ligne 1" & vbCrLf & "Ligne 2" & Chr(13) & "Ligne 3"
affichera dans la boite de message :
Ligne 1
Ligne 2
Ligne 3
La boite de message - Alert -Assurément un emprunt au Javascript, la fonction Alert permet également d'afficher un boite de message. Tout comme MsgBox, Alert ouvre une petite fenêtre avec votre texte et un bouton OK. Aussi longtemps que le lecteur n'aura pas confirmé par un clic sur ce bouton, le processus sera bloqué. La syntaxe est :
Alert "votre texte"
Un exemple ?
Alert "Message reçu ?"
Votre oeil perspicace aura remarqué que la fenêtre s'intitule "Microsoft Internet Explorer" ou lieu de Visual Basic. A mon sens, plus joli. La boite de saisie - InputBox -Avec la boite de saisie, vous pouvez accroître l'interactivité avec votre lecteur et obtenir de sa part d'autres réponses que oui, non, etc. La syntaxe est simple :
InputBox "votre texte" , "le titre de la boite" , "la valeur par défaut"
Voici un exemple :
InputBox "Quel est votre prénom?", "Demande d'information", "Luc"
La boite de saisie ne comporte pas d'icônes et les seuls boutons sont OK et Cancel. La valeur ainsi entrée par le lecteur pourra être récupérée dans une variable qui sera traitée dans d'autres lignes de code VBscript. La boite de message - MsgBox - évoluéeOn peut utiliser la boite MsgBox pour une plus grande interactivité qu'un simple (stupide?) bouton de confirmation. C'est le premier attribut (attribut-bouton), celui du choix des boutons.
On peut modifier la petite icône qui accompagne la boite de message. C'est l'attribut-icône.
Et si la mention "Visual Basic" de la fenêtre par défaut ne vous enchante guère, le titre de cette fenêtre peut aussi être modifié. La syntaxe bien entendu, évolue :
MsgBox "votre texte" , attribut-bouton + attribut-icône, "titre de la fenêtre"
MsgBox renvoie une valeur de retour qui indique que le lecteur a cliqué sur tel ou tel bouton. Selon l'évaluation de ce code retour (voir Chapitre "Les conditions") telle ou telle action pourra être programmée. Ces codes sont 1 pour le bouton OK, 2 pour le bouton Cancel, 3 pour le bouton Abort, 4 pour le bouton Retry, 5 pour le bouton Ignore, 6 pour le bouton Yes et enfin 7 pour le bouton No. On mettra ce code retour dans une variable (ici code). L'écriture prendra la forme :
Dim code
code = MsgBox("texte" , attribut-bouton ) Afficher du texteMéthode de l'objet documentRappelez-vous... Nous avions montré que ce qui apparaît sur votre écran, peut être "découpé" en objets et que VBscript allait vous donner la possibilité d'accéder à ces objets. La page Html qui s'affiche dans la fenêtre du browser est un objet de type document. A chaque objet VBscript, le concepteur du langage a prévu un ensemble de méthodes (ou fonctions dédiées à cet objet) qui lui sont propres. A l'objet document, VBscript a dédié la méthode "écrire dans le document", c'est la méthode write. Pour appeler la méthode write du document, on notera
document.write
La méthode writeLa syntaxe est assez simple soit
document.write "votre texte"
On peut aussi écrire une variable, soit la variable resultat,
document.write resultat
Pour associer du texte (chaînes de caractères) et des variables, on utilise l'instruction
document.write ''Le résultat est " & resultat
On peut utiliser les balises Html pour agrémenter ce texte
document.write ''Le résultat est" & resultat
où & est un opérateur de concaténation qui relie les "wagons" de ce que vous voulez écrire. Nous y reviendrons au chapitre consacré aux opérateurs.
document.write ''" & "Le résultat est "& "" & resultat Exemple (classique !)On va écrire du texte en Html et en VBscript. <HTML> <BODY> <H1>Ceci est du Html</H1> Ce qui donnera comme résultat : Les variablesLes variables contiennent des données qui peuvent être modifiées lors de l'exécution d'un programme. On y fait référence par le nom de cette variable. Les noms de variablesIls ne doivent pas dépasser 255 caractères, doivent commencer par une lettre (caractère alphabétique), ne peuvent contenir une virgule, un point ou un espace, ne peuvent reprendre des mots clés de VBscript, doivent être uniques à l'intérieur de leur portée (voir variables globales et locales). Ajoutons pour nous les francophones, qu'il faut employer l'alphabet ASCII donc les lettres sans accents. Pour rappel VBscript est sensible à la case. Attention donc aux majuscules et minuscules! La déclaration de variableLes variables peuvent se déclarer de deux façons : soit de façon explicite. On dit à VBscript que ceci est une variable. La commande qui permet de déclarer une variable est le mot clé Dim suivi du nom de la variable (et ce généralement en début de script). Par exemple :
Dim Numero
Dim x, y, z soit de façon implicite. On écrit directement dans le code VBscript, le nom de la variable suivi de la valeur que l'on lui attribue et VBscript s'en accommode. Par exemple
Numero = 1
Si ce mélange possible de variables implicites et explicites vous ennuie, vous pouvez exiger la méthode de déclaration explicite et empêcher les déclarations implicites. Cela se réalise par la commande
Prenom = "Luc"
Option Explicit
Cette commande se place dans la première ligne de code de votre VBscript :
Les types de données sous VBscriptVBscript utilise un seul type de données nommée Variant (rappel du Visual Basic). Ce type Variant est véritablement un fourre-tout de différents types d'information. En voici quelques-uns :
Variables locales et variables globalesLes variables déclarées dans les procédures (voir plus loin) ont une portée dite locale c-à-d qu'elle ne sera valable que dans le cadre de cette seule procédure. Une variable est dite globale lorsqu'elle pourra être partagée partout dans le code du script. Pour qu'une variable soit globale, elle doit être déclarée en dehors de toutes procédures. Pour ce faire, on les déclare tout au début du script. Ainsi, la variable compteur définie comme suit sera globale :
Les opérateursAprès les variables, abordons le chapitre, toujours follement passionnant (sic), des opérateurs. Les opérateurs arithmétiquesDans tous les exemples, y est égal à 11.
Il faut noter que la division sans décimale renvoie la partie entière de la division et ne fonctionne en aucun cas comme un arrondi du nombre. Opérateurs de comparaisonCes opérateurs de comparaison seront surtout utilisés dans les tests de conditionnels. Nous y reviendrons dans le chapitre intitulé "Les conditions".
En VBscript, il n'y a pas de signe différent pour = valeur d'attribution et = comparaison. C'est le sens du script qui l'indique. Ce qui peut poser certains problèmes. En Javascript, on a = pour la valeur d'attribution et == comparaison. Opérateurs logiques
Opérateur de concaténation
Préférez cependant & à + car ce dernier est fait pour les valeurs numériques et l'interpréteur être troublé par la concaténation de nombres et de strings. La concaténation avec l'opérateur +, ne fournit pas toujours un résultat garanti. Les procéduresLes procédures (généralités)Une procédure (ou fonction) est un groupe de ligne(s) de code de programmation destiné à exécuter une tâche bien spécifique et que l'on pourra, si besoin est, utiliser à plusieurs reprises. De plus, l'usage des procédures améliorera grandement la lisibilité et la maintenance de votre script. En VBscript, il existe trois types de fonctions ou de procédures :
Déclaration d'un sous-programmePour déclarer ou définir un sous-programme (Subroutine), on utilise le mot (réservé) Sub. La syntaxe d'une déclaration de sous-routine est la suivante :
Sub nom-du-sous-programme(arguments)
... code des instructions ... End Sub Le nom du sous-programme suit les mêmes règles que celles qui régissent le nom de variables (nombre de caractères 255, commencer par une lettre, peuvent inclure des chiffres...). Pour rappel, VBscript est sensible à la case. Ainsi Calcul() ne sera pas égal à calcul(). En outre, Tous les noms des fonctions dans un script doivent être uniques. La mention des arguments est facultative mais dans ce cas les parenthèses doivent rester. C'est d'ailleurs grâce à ces parenthèses que l'interpréteur VBscript distingue les variables des fonctions. Nous reviendrons plus en détail sur les arguments et autres paramètres. Lorsqu'un sous-programme a été ouvert par un Sub, il doit impérativement, sous peine de message d'erreur, être refermé par un End Sub. Prenez la bonne habitude de fermer directement vos sous-routines et d'écrire votre code entre elles. Le fait de définir une fonction n'entraîne pas l'exécution des commandes qui la composent. Ce n'est que lors de l'appel de la fonction que le code de programme est exécuté. L'appel d'un sous-programmeL'appel d'un sous-programme se fait le plus simplement du monde par le nom du sous-programme (sans les parenthèses même s'il y a des arguments). Soit par exemple
nom-du-sous-programme
nom-du-sous-programme argument1, argument2 Vous pouvez aussi (mais ce n'est pas obligatoire) utiliser l'instruction call
Call nom-du_sous-programme
Call nom-du-sous-programme(argument1, argument2) Si le sous-programme a des arguments, il faut ici mettre des parenthèses. Il faudra veuillez en toute logique (car l'interpréteur lit votre script de haut vers le bas) que votre fonction soit bien définie avant d'être appelée. Déclaration d'une fonctionPour rappel, la fonction retourne une valeur. Pour le reste, les règles sont assez proche de celles vues pour les sous-programmes. Pour déclarer ou définir une fonction, on utilise le mot clé Function . La syntaxe d'une déclaration de fonction est la suivante :
Function nom-de-la-fonction(arguments)
... code des instructions ... End Function Ce qui été dit pour les sous-programmes concernant le nom, l'usage des parenthèses, L'emploi de End Function reste valable pour les fonctions. Le fait de définir une fonction n'entraîne pas l'exécution des commandes qui la composent. Ce n'est que lors de l'appel de la fonction que le code de programme est exécuté. Retour de la valeur dans une fonctionPour retourner une valeur, la fonction utilise un petit artifice. On affectera la valeur à une variable dans une des lignes de code de la fonction et cette variable portera le même nom que la fonction. Ainsi, la syntaxe serait :
Function nom-de-la-fonction(arguments)
... code des instructions ... nom-de-la-fonction = expression ... code des instructions ... End Function Vbscript sait alors automatiquement que vous voulez renvoyer la valeur de la "variable" nom-de-la-fonction au programme qui l'a appelé. Cette façon de faire remplace le return d'autres langages de programmation ou de scripts. Voici un exemple : La valeur retournée sera celle de "cube" soit nombre au cube. Appel d'une fonctionPour appeler une fonction, on fait apparaître le nom de la fonction à droite d'une affectation de variable souvent appelée variable de retour. La syntaxe est :
variable-retour = nom-de-la-fonction(arguments)
Dans le cadre de notre exemple, cela pourrait être :
resultat = cube(nombre)
Les parenthèses sont optionnelles même si on transmet des arguments à la fonction. |