Maison >interface Web >Questions et réponses frontales >Comment créer des formulaires dynamiques en javascript

Comment créer des formulaires dynamiques en javascript

PHPz
PHPzoriginal
2023-05-12 16:17:071091parcourir

Avec le développement continu des applications Internet, les utilisateurs ont des exigences de plus en plus élevées en matière d'expérience interactive des sites Web. Les formulaires dynamiques sont l’un des moyens importants d’améliorer l’expérience d’interaction des utilisateurs. En tant que compétence essentielle pour le développement front-end, JavaScript peut également très bien réaliser des effets de formulaire dynamiques. Cet article présentera comment utiliser JavaScript pour créer des formulaires dynamiques, du point de vue de l'ajout dynamique, de la suppression et du rendu conditionnel des éléments de formulaire.

1. Ajout dynamique d'éléments de formulaire

Normalement, les formulaires sur le site Web sont complétés avec du code HTML, mais les formulaires créés avec du code HTML sont statiques et les données saisies par l'utilisateur sont également statiques, donc l'ajout dynamique ne peut pas être atteint. Suppression dynamique et autres fonctions. En JavaScript, les éléments de formulaire peuvent être ajoutés dynamiquement via des opérations DOM.

Voici un exemple simple qui montre comment ajouter dynamiquement une zone de texte à un formulaire à l'aide de JavaScript :

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>动态表单</title>
    <script type="text/javascript">
      function addInput() {
        var form = document.getElementById("myForm");
        var input = document.createElement("input");
        input.type = "text";
        form.appendChild(input);
      }
    </script>
  </head>
  <body>
    <form id="myForm">
      <input type="button" value="添加文本框" onclick="addInput()">
    </form>
  </body>
</html>

Dans cet exemple, une zone de texte est créée via JavaScript et ajoutée au formulaire. Les utilisateurs peuvent ajouter dynamiquement de nouvelles zones de texte en cliquant sur le bouton « Ajouter une zone de texte ».

2. Suppression dynamique des éléments de formulaire

Dans les applications pratiques, en plus d'ajouter des éléments de formulaire, il est parfois également nécessaire de supprimer des éléments de formulaire. De même, les éléments de formulaire peuvent être facilement supprimés via la manipulation du DOM.

Voici un exemple simple qui montre comment supprimer une zone de texte dans un formulaire à l'aide de JavaScript :

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>动态表单</title>
    <script type="text/javascript">
      function removeInput() {
        var form = document.getElementById("myForm");
        var inputs = form.getElementsByTagName("input");
        form.removeChild(inputs[inputs.length-1]);
      }
    </script>
  </head>
  <body>
    <form id="myForm">
      <input type="text"><br>
      <input type="text"><br>
      <input type="button" value="删除最后一个文本框" onclick="removeInput()">
    </form>
  </body>
</html>

Dans cet exemple, récupérez tous les éléments de la zone de texte du formulaire via JavaScript, puis supprimez la dernière zone de texte. Notez que lors de la suppression d'éléments de formulaire, utilisez la méthode removeChild(). removeChild() 方法。

三、表单元素的条件渲染

有时候需要根据用户输入的内容,动态改变表单的显示内容。比如说,在注册表单中,当用户选择“企业用户”时,需要显示企业相关的表单元素;当用户选择“个人用户”时,需要显示个人相关的表单元素。这个时候,就需要用到表单元素的条件渲染功能。

下面是一个简单的例子,展示了如何用 JavaScript 实现表单元素的条件渲染:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>动态表单</title>
    <script type="text/javascript">
      function showFields() {
        var userType = document.getElementById("userType").value;
        var personalFields = document.getElementById("personalFields");
        var companyFields = document.getElementById("companyFields");
        if (userType === "personal") {
          personalFields.style.display = "block";
          companyFields.style.display = "none";
        } else {
          personalFields.style.display = "none";
          companyFields.style.display = "block";
        }
      }
    </script>
  </head>
  <body>
    <form>
      <label>
        用户类型:
        <select id="userType" onchange="showFields()">
          <option value="personal">个人用户</option>
          <option value="company">企业用户</option>
        </select>
      </label>
      <br><br>
      <fieldset id="personalFields">
        <legend>个人用户信息</legend>
        姓名:<input type="text"><br>
        年龄:<input type="text"><br>
      </fieldset>
      <fieldset id="companyFields" style="display: none;">
        <legend>企业用户信息</legend>
        公司名称:<input type="text"><br>
        职位:<input type="text"><br>
      </fieldset>
    </form>
  </body>
</html>

在这个例子中,定义了一个表单,包含了一个下拉菜单和两个字段集。通过下拉菜单,用户可以选择“个人用户”或“企业用户”,然后显示相应的字段集。

在代码中,通过 getElementById() 方法获取了下拉菜单和两个字段集的元素,并分别存储在了变量 userTypepersonalFieldscompanyFields 中。在 showFields() 函数中,根据下拉菜单的值,判断应该显示哪个字段集。这里使用了 style.display

3. Rendu conditionnel des éléments du formulaire

Parfois, il est nécessaire de modifier dynamiquement le contenu d'affichage du formulaire en fonction du contenu saisi par l'utilisateur. Par exemple, dans le formulaire d'inscription, lorsque l'utilisateur sélectionne « Utilisateur entreprise », les éléments de formulaire liés à l'entreprise doivent être affichés ; lorsque l'utilisateur sélectionne « Utilisateur individuel », les éléments de formulaire liés à l'entreprise doivent être affichés ; À ce stade, vous devez utiliser la fonction de rendu conditionnel des éléments du formulaire.

Ce qui suit est un exemple simple qui montre comment utiliser JavaScript pour implémenter le rendu conditionnel des éléments de formulaire : 🎜rrreee🎜Dans cet exemple, un formulaire est défini et contient un menu déroulant et deux ensembles de champs. Un menu déroulant permet à l'utilisateur de sélectionner « Utilisateur individuel » ou « Utilisateur professionnel » et l'ensemble de champs correspondant s'affiche. 🎜🎜Dans le code, les éléments du menu déroulant et les deux ensembles de champs sont obtenus grâce à la méthode getElementById(), et sont stockés dans les variables userType et personalFields et <code>companyFields. Dans la fonction showFields(), déterminez quel ensemble de champs doit être affiché en fonction de la valeur du menu déroulant. L'attribut style.display est utilisé ici pour contrôler l'affichage ou le masquage des éléments. 🎜🎜Résumé🎜🎜Cet article présente comment JavaScript implémente les formulaires dynamiques, y compris l'ajout dynamique, la suppression et le rendu conditionnel des éléments de formulaire. Grâce aux opérations DOM, ces fonctions peuvent être facilement implémentées, améliorant ainsi l'expérience interactive de l'utilisateur. Si vous souhaitez obtenir des effets d'interaction de formulaire plus complexes, vous pouvez également envisager d'utiliser jQuery ou d'autres frameworks frontaux. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn