Partager via


Élément d’interface utilisateur Microsoft.Common.TextBox

L’élément d’IU (interface utilisateur) TextBox peut être utilisé pour ajouter du texte non mis en forme. L’élément est un champ d’entrée monoligne, mais il prend en charge l’entrée multiligne avec la propriété multiLine.

Exemple d’interface utilisateur

L’élément TextBox utilise une zone de texte d’une ou de plusieurs lignes.

Exemple de zone de texte monoligne.

Capture d'écran d'une zone de texte sur une seule ligne utilisant l'élément d'interface utilisateur Microsoft.Common.TextBox.

Exemple de zone de texte multiligne.

Capture d'écran d'une zone de texte multiligne utilisant l'élément d'interface utilisateur Microsoft.Common.TextBox.

schéma

{
  "name": "nameInstance",
  "type": "Microsoft.Common.TextBox",
  "label": "Name",
  "defaultValue": "contoso123",
  "toolTip": "Use only allowed characters",
  "placeholder": "",
  "multiLine": false,
  "constraints": {
    "required": true,
    "validations": [
      {
        "regex": "^[a-z0-9A-Z]{1,30}$",
        "message": "Only alphanumeric characters are allowed, and the value must be 1-30 characters long."
      },
      {
        "isValid": "[startsWith(steps('resourceConfig').nameInstance, 'contoso')]",
        "message": "Must start with 'contoso'."
      }
    ]
  },
  "visible": true
}

Exemple de sortie

"contoso123"

Notes

  • Utilisez la propriété toolTip pour afficher le texte relatif à l’élément quand le curseur de la souris est positionné sur le symbole d’informations.
  • La propriété placeholder est un texte d’aide qui disparaît lorsque l’utilisateur commence à modifier. Si les placeholder et defaultValue sont définis, le defaultValue est prioritaire et est affiché.
  • La propriété multiLine est booléenne, true ou false. Pour utiliser une zone de texte de plusieurs lignes, définissez la valeur de la propriété sur true . Si vous n’avez pas besoin d’une zone de texte de plusieurs lignes, définissez la valeur de la propriété sur false ou excluez la propriété. Pour les nouvelles lignes, la sortie JSON affiche \n pour le saut de ligne. La zone de texte de plusieurs ligne accepte \r en tant que retour chariot (CR) et \n en tant que saut de ligne (LF). Par exemple, une valeur par défaut peut inclure \r\n pour spécifier le retour chariot et le flux de ligne (CRLF).
  • Si constraints.required est défini sur true, la zone de texte doit contenir une valeur pour permettre la réussite de la validation. La valeur par défaut est false.
  • La propriété validations est un tableau dans lequel vous ajoutez des conditions pour vérifier la valeur fournie dans la zone de texte.
  • La propriété regex est un modèle d’expression régulière JavaScript. Si elle est spécifiée, la valeur de la zone de texte doit correspondre au modèle pour que la validation réussisse. La valeur par défaut est null. Pour plus d’informations sur la syntaxe d’expression régulière, consultez Référence rapide des expressions régulières.
  • La propriété isValid contient une expression qui prend la valeur true ou false. Dans l’expression, vous définissez la condition qui détermine si la zone de texte est valide.
  • La propriété message est une chaîne à afficher en cas d’échec de la validation de la valeur de la zone de texte.
  • Il est possible de spécifier une valeur pour regex lorsque required est défini sur false. Dans ce scénario, aucune valeur n’est requise dans la zone de texte pour que la validation réussisse. Si elle est spécifiée, celle-ci doit correspondre au modèle d’expression régulière.

Exemples

Les exemples montrent comment utiliser une zone de texte d’une ligne et une zone de texte de plusieurs lignes.

Une ligne

L’exemple suivant utilise une zone de texte avec le contrôle Microsoft.Solutions.ArmApiControl pour vérifier la disponibilité d’un nom de ressource.

Dans cet exemple, quand vous entrez un nom de compte de stockage et que vous quittez la zone de texte, le contrôle vérifie si le nom est valide et s’il est disponible. Si le nom n’est pas valide ou s’il existe déjà, un message d’erreur s’affiche. Un nom de compte de stockage valide et disponible s’affiche dans la sortie.

{
  "$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
  "handler": "Microsoft.Azure.CreateUIDef",
  "version": "0.1.2-preview",
  "parameters": {
    "basics": [
      {
        "name": "nameApi",
        "type": "Microsoft.Solutions.ArmApiControl",
        "request": {
          "method": "POST",
          "path": "[concat(subscription().id, '/providers/Microsoft.Storage/checkNameAvailability?api-version=2021-09-01')]",
          "body": {
            "name": "[basics('txtStorageName')]",
            "type": "Microsoft.Storage/storageAccounts"
          }
        }
      },
      {
        "name": "txtStorageName",
        "type": "Microsoft.Common.TextBox",
        "label": "Storage account name",
        "constraints": {
          "validations": [
            {
              "isValid": "[basics('nameApi').nameAvailable]",
              "message": "[basics('nameApi').message]"
            }
          ]
        }
      }
    ],
    "steps": [],
    "outputs": {
      "textBox": "[basics('txtStorageName')]"
    }
  }
}

Plusieurs lignes

Cet exemple utilise la propriété multiLine pour créer une zone de texte de plusieurs lignes avec un texte d’espace réservé.

{
  "$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
  "handler": "Microsoft.Azure.CreateUIDef",
  "version": "0.1.2-preview",
  "parameters": {
    "basics": [
      {
        "name": "demoTextBox",
        "type": "Microsoft.Common.TextBox",
        "label": "Multi-line text box",
        "defaultValue": "",
        "toolTip": "Use 1-60 alphanumeric characters, hyphens, spaces, periods, and colons.",
        "placeholder": "This is a multi-line text box:\nLine 1.\nLine 2.\nLine 3.",
        "multiLine": true,
        "constraints": {
          "required": true,
          "validations": [
            {
              "regex": "^[a-z0-9A-Z -.:\n]{1,60}$",
              "message": "Only 1-60 alphanumeric characters, hyphens, spaces, periods, and colons are allowed."
            }
          ]
        },
        "visible": true
      }
    ],
    "steps": [],
    "outputs": {
      "textBox": "[basics('demoTextBox')]"
    }
  }
}

Étapes suivantes