Maison >interface Web >js tutoriel >jQuery implémente des exemples fonctionnels similaires à GridView

jQuery implémente des exemples fonctionnels similaires à GridView

小云云
小云云original
2018-01-22 13:57:042039parcourir

Cet article partage principalement avec vous jQuery pour implémenter une fonction d'édition, de mise à jour, d'annulation et de suppression de type GridView. Dans le projet, j'ai rencontré une telle exigence lorsque l'utilisateur clique sur Modifier, une ligne est générée dynamiquement sous la ligne cliquée. , et le bouton d'édition change. S'il est désactivé, la ligne nouvellement générée comporte des boutons de mise à jour et d'annulation. Cliquez sur le bouton "Annuler" pour supprimer la ligne générée dynamiquement et restaurer l'état du bouton d'édition. L'éditeur partagera l'exemple de code avec vous ci-dessous, jetons un coup d'œil.

Tout d'abord, jetons un coup d'œil à la démonstration d'effet en temps réel suivante :

Lorsque l'utilisateur clique sur Modifier, une ligne est générée dynamiquement sous la ligne cliquée. Le bouton Modifier devient désactivé.

La ligne nouvellement générée comporte des boutons de mise à jour et d'annulation. Cliquez sur le bouton "Annuler" pour supprimer la ligne générée dynamiquement. État du bouton Modifier restauré.

Il n'y a rien de spécial dans les fonctions des boutons de mise à jour et de suppression.

Le code html dans la vue ASP.NET MVC est le suivant, tableau ordinaire, balise html ordinaire :

Fonction du bouton supprimé :


$('.Delete').click(function () {
      var flag = confirm('你确认是否删除记录?');
      if (flag) {
        var tr = $(this).closest('tr');
        var obj = {};
        obj.Ltc_nbr = tr.find('.SelectSingle').val();
        $.ajax({
          type: 'POST',
          url: "/Highway/LandTransportationCityDelete",
          dataType: 'json',
          data: JSON.stringify(obj),
          contentType: 'application/json; charset=utf-8',
          success: function (data, textStatus) {
            if (data.Success) {
              window.location.href = data.RedirectUrl;
            }
            else {
              alert(data.ExceptionMessage);
              return;
            }
          },
          error: function (xhr, status, error) {
            alert("An error occurred: " + status + "nError: " + error);
          }
        });
      }
      return false;
    });

La fonction du bouton d'édition doit générer dynamiquement une nouvelle ligne. Traiter les balises html de chaque champ :


$('.Edit').click(function (e) {
      var tr = $(this).closest('tr')
      var row = $(&#39;<tr>&#39;);
      row.append($(&#39;<td><input class="city_key" type="hidden" value="&#39; + tr.find(&#39;.SelectSingle&#39;).val() + &#39;" /></td>&#39;));
      row.append($(&#39;<td></td>&#39;));
      $selectCity = $(&#39;<select />&#39;).attr({ name: &#39;city&#39;, class: &#39;selectcity&#39; });
      $("<option></option>", { value: "", text: "" }).appendTo($selectCity);
      $.getJSON("/Highway/GetCities", function (data) {
        $.each(data, function (i, item) {
          if (item.City_nbr == tr.find(&#39;.city_key&#39;).val()) {
            $("<option></option>", { value: item.City_nbr, text: item.City_Name,selected :"selected" }).appendTo($selectCity);
          }
          else {
            $("<option></option>", { value: item.City_nbr, text: item.City_Name}).appendTo($selectCity);
          }
        })
      });
      row.append($(&#39;<td></td>&#39;).append($selectCity));
      row.append($(&#39;<td></td>&#39;));
      row.append($(&#39;<td></td>&#39;));
      row.append($(&#39;<td></td>&#39;));
      $cb = $(&#39;<input/>&#39;).attr({ type: &#39;checkbox&#39;, class: &#39;ckbIsActived&#39;, checked: tr.find(&#39;.ckbIsActived&#39;).is(&#39;:checked&#39;) == true ? &#39;true&#39; : &#39;&#39; });
      row.append($(&#39;<td></td>&#39;).append($cb));
      var $btnUpdate = $(&#39;<input/>&#39;).attr({ type: &#39;button&#39;, class: &#39;Update&#39;, value: &#39;更新&#39; });
      row.append($(&#39;<td style="width:40px;"></td>&#39;).append($btnUpdate));
      var $btnCancel = $(&#39;<input/>&#39;).attr({ type: &#39;button&#39;, class: &#39;Cancel&#39;, value: &#39;取消&#39; });
      row.append($(&#39;<td style="width:40px;"></td>&#39;).append($btnCancel));
      tr.after(row);
      $(this).attr("disabled", "disabled");
    });

Mettre à jour la fonction du bouton ammonium :


$(&#39;table.city-list&#39;).delegate(&#39;.Update&#39;, &#39;click&#39;, function (event) {
      var tr = $(this).closest("tr");
      var obj = {};
      obj.Ltc_nbr = tr.find(&#39;.city_key&#39;).val();
      obj.City_nbr = tr.find(&#39;.selectcity&#39;).val();
      obj.IsActived = tr.find(&#39;.ckbIsActived&#39;).is(&#39;:checked&#39;);
      $.ajax({
        type: &#39;POST&#39;,
        url: "/Highway/LandTransportationCityUpdate",
        dataType: &#39;json&#39;,
        data: JSON.stringify(obj),
        contentType: &#39;application/json; charset=utf-8&#39;,
        success: function (data, textStatus) {
          if (data.Success) {
            alert("陆运城市更新成功。");
            window.location.href = data.RedirectUrl;
          }
          else {
            alert(data.ExceptionMessage);
            return;
          }
        },
        error: function (xhr, status, error) {
          alert("An error occurred: " + status + "nError: " + error);
        }
      });
    });

Il existe également une fonction de bouton d'annulation :


$(&#39;table.city-list&#39;).delegate(&#39;.Cancel&#39;, &#39;click&#39;, function (event) {
      var tr = $(this).closest("tr");
      tr.prev().find(&#39;.Edit&#39;).removeAttr(&#39;disabled&#39;);
      tr.remove();
    });

L'avez-vous déjà appris ? Récupérez-le si vous le trouvez utile.

Recommandations associées :

Utilisation de l'effet de boîte contextuelle bootstrap modal+gridview pour implémenter un exemple de didacticiel

Implémentation du défilement automatique GridView function

Comment ajouter, supprimer et modifier DataGridView ?


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