Maison > interface Web > js tutoriel > JS implémente la génération dynamique de tables et soumet les données des tables aux compétences backend_javascript

JS implémente la génération dynamique de tables et soumet les données des tables aux compétences backend_javascript

WBOY
Libérer: 2016-05-16 15:17:30
original
2207 Les gens l'ont consulté

L'exemple de cet article présente le code JS pertinent pour générer dynamiquement des tables et soumettre les données des tables au backend. Il est partagé avec tout le monde pour votre référence. Le contenu spécifique est le suivant

.

Examinons d'abord les exigences : générer dynamiquement un tableau sur la page Web, modifier les données du tableau, puis soumettre les données du tableau au serveur principal pour stockage.

Ensuite, la première chose que nous devons résoudre est le problème de la génération dynamique de tables

1. Nous devons d’abord importer le fichier de la bibliothèque JS.

<script src="../js/jqui/jquery/jquery-1.5.2.min.js" type="text/javascript"></script>


Copier après la connexion

2. Créez ensuite un tableau vierge dans la page div à l'avance, qui peut être déterminé selon vos besoins. Voici un tableau avec un en-tête

.
<table border="0" style="text-align: center;" width="100%" id="myTable">
 <tr>
  <td width="150px;">表头1</td>
  <td width="150px;">表头2</td>
  <td width="150px;">表头3</td>
  <td width="150px;">表头4</td>
  <td width="150px;">表头5</td>
  <td width="150px;">操作</td>
 </tr>
</table>
Copier après la connexion

3. Une fois la table créée, nous pouvons écrire le code clé pour générer dynamiquement la table. Nous écrivons une méthode js pour le déclenchement

var num = 0;
  function addTable(){
    var tableHtml ="";
    tableHtml += '<tr id="tr'+num+'">'
         +'<td><input class="addtd" id="cnashu1'+num+'" style="width:150px;" type="text" name="cnashu1" /></td>'
         +'<td><input class="addtd" id="cnashu2'+num+'" style="width:150px;" type="text" name="cnashu2"/></td>'
         +'<td><input class="addtd" id="cnashu3'+num+'" style="width:150px;" type="text" name="cnashu3"/></td>'
         +'<td><input class="addtd" id="cnashu4'+num+'" style="width:150px;" type="text" name="cnashu4"/></td>'
         +'<td><input class="addtd" id="cnashu5'+num+'" style="width:150px;" type="text" name="cnashu5"/></td>'
         +'<td><a style="cursor: pointer; color: blue;" onclick="removeTr('+num+')">删除</a>'
           +'<a id="edit'+num+'" class="edit" style="cursor: pointer; color: blue;" onclick="editDataByOne('+num+')">修改</a>'
           +'<a id="save'+num+'" class="hide" style="cursor: pointer; color: blue;" onclick="saveByOne('+num+')">保存</a>'
         +'</td>'
         +'</tr>';
    
    var elements = $("#myTable").children().length;  //表示id为“mtTable”的标签下的子标签的个数
    
    $("#myTable").children().eq(elements - 1).after(tableHtml); //在表头之后添加空白行
    num++;   
  }
Copier après la connexion

Nous pouvons voir que nous avons ajouté la balise dans la balise , qui est principalement utilisée pour fournir les paramètres d'entrée de l'utilisateur, et la variable globale num est principalement utilisée pour distinguer l'identifiant de chaque paramètre ajouté. Exister en raison de son caractère unique.

4. Ensuite, nous faisons fonctionner la table

//删除行
function removeTr(trNum){
  $("#tr"+trNum).remove();
}
//编辑行
function editDataByOne(trNum){
  $this = $("#tr"+trNum);
  $(".addtd",$this).removeAttr("readonly");
}
//保存行
function saveByOne(trNum){
  $this = $("#tr"+trNum);
  $(".addtd",$this).attr("readonly","readonly");
}
Copier après la connexion

Nous avons supprimé, modifié, enregistré et autres opérations dans le tableau ci-dessus. Le contenu spécifique de l'opération peut être ajusté en fonction des besoins. (En fait, j'ai découvert plus tard que je n'avais pas besoin du numéro global et que je pouvais également implémenter l'opération d'ajout de lignes. Quant à la façon de l'implémenter, il s'agit principalement de certaines opérations js. Je l'étudierai quand j'aurai le temps)

À ce stade, notre code de page pour générer dynamiquement des tableaux est terminé.
Dans la première moitié de l'article, nous avons parlé de comment générer dynamiquement une table Ensuite, nous parlerons decomment obtenir plusieurs éléments de données dans. la table et soumettez-la au serveur backend.

Avant le développement, j'ai également trouvé des informations sur Internet. Elles étaient soit trop concises, soit incompréhensibles, mais la plupart d'entre elles mentionnaient l'utilisation de Json pour passer plusieurs paramètres en arrière-plan, j'ai donc écrit sur la base de cette idée. .

1. Voyons d’abord comment obtenir les données du tableau, ou les combiner avec l’exemple ci-dessus

<div>
  <form id="submitForm">
    <table border="0" style="text-align: center;" width="100%" id="myTable">
      <tr>
        <td width="150px;">表头1</td>
        <td width="150px;">表头2</td>
        <td width="120px;">表头3</td>
        <td width="120px;">表头4</td>
        <td width="80px;">表头5</td>
        <td width="100px;">操作</td>
      </tr>
    </table>
   </form>
   <input type="button" value="添加" onclick="addTable();">
   <input type="button" value="提交" onclick="save();">
 </div>
Copier après la connexion

Nous pouvons voir que nous avons ajouté une balise form en dehors de la balise Table et défini l'identifiant de la balise form.

2. Ensuite, nous obtenons les paramètres de la balise d'entrée sous le formulaire selon la méthode "serialize()" de jQuery

var msg = $("#submitForm").serialize();  //获得后的msg的值:canshu1=xxx&canshu2=xxx&canshu3=xxx&canshu4=xxx&canshu5=xxx
Copier après la connexion

3. Après avoir obtenu les données dans le tableau, nous les convertissons en données au format json selon leur forme de valeur

var json = "[{";
var msg2 = msg.split("&");   //先以“&”符号进行分割,得到一个key=value形式的数组
var t = false;
for(var i = 0; i<msg2.length; i++){
  var msg3 = msg2[i].split("=");  //再以“=”进行分割,得到key,value形式的数组
  for(var j = 0; j<msg3.length; j++){
    json+="\""+msg3[j]+"\"";
    if(j+1 != msg3.length){
      json+=":";
    }
    if(t){
      json+="}";
      if(i+1 != msg2.length){  //表示是否到了当前行的最后一列
        json+=",{";
      }
      t=false;
    }
    if(msg3[j] == "canshu5"){  //这里的“canshu5”是你的表格的最后一列的input标签的name值,表示是否到了当前行的最后一个input
      t = true;
    }
  }
  if(!msg2[i].match("canshu5")){  //同上
    json+=";";
  }
          
}
json+="]";
//最终msg的值就被转换为:[{"key":"value";"key":"value"},{"key":"value";"key":"value"}]格式的json数据<br />
Copier après la connexion

Grâce au code ci-dessus, nous avons réussi à convertir plusieurs éléments de données du tableau en données au format json, puis nous pouvons envoyer les données Json en arrière-plan pour les traiter via ajax.

À ce stade, nous avons fini d'écrire le code pour obtenir plusieurs éléments de données dans le formulaire et les soumettre au serveur. Nous espérons que cela sera utile à l'apprentissage de chacun.

source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal