2012-01-12 3 views
0

Мне нужна форма для генерации элементов формы динамически. До сих пор я модифицировал скрипт, чтобы добавить другое поле txtEmail1, и он отлично работает и генерирует поля, когда пользователь нажимает кнопку добавления.Создайте поля формы jQuery вместе со sno в метке

Теперь мне нужно префиксную надпись «Полное имя» серийным номером. 1, 2, 3, 4 и т. Д. Я пробовал, но я не в состоянии правильно это сделать, чтобы помочь специалистам.

<script type="text/javascript"> 
     $(document).ready(function() { 
      $('#btnAdd').click(function() { 
       var num  = $('.clonedInput').length; // how many "duplicatable" input fields we currently have 
       var newNum = new Number(num + 1);  // the numeric ID of the new input field being added 

       // create the new element via clone(), and manipulate it's ID using newNum value 
       var newElem = $('#input' + num).clone().attr('id', 'input' + newNum); 

       // manipulate the name/id values of the input inside the new element 
       newElem.children(':first').attr('id', 'name' + newNum).attr('name', 'name' + newNum); 

       newElem.children(':first').attr('id', 'txtEmail' + newNum).attr('txtEmail', 'txtEmail' + newNum); 

       // insert the new element after the last "duplicatable" input field 
       $('#input' + num).after(newElem); 

       // enable the "remove" button 
       $('#btnDel').attr('disabled',''); 

       // business rule: you can only add 5 names 
       if (newNum == 5) 
        $('#btnAdd').attr('disabled','disabled'); 
      }); 

      $('#btnDel').click(function() { 
       var num = $('.clonedInput').length; // how many "duplicatable" input fields we currently have 
       $('#input' + num).remove();  // remove the last element 

       // enable the "add" button 
       $('#btnAdd').attr('disabled',''); 

       // if only one element remains, disable the "remove" button 
       if (num-1 == 1) 
        $('#btnDel').attr('disabled','disabled'); 
      }); 

      $('#btnDel').attr('disabled','disabled'); 
     }); 
    </script> 
</head> 
<body> 
    <div> 
     <input type="button" id="btnAdd" value="add another name" /> 
     <input type="button" id="btnDel" value="remove name" /> 
    </div> 
    <div id="input1" style="margin-bottom:4px;" class="clonedInput"> 
        <label id="lblSno1"></label> Full Name 
        <input name="name1" type="text" class="TextBoxNext" id="name1" /></td> 
        <input name="txtEmail1" type="text" class="TextBoxNext" id="txtEmail1" /></td> 
    </div> 
</form> 
</body> 

мне также нужно назначить количество какой-то скрытое поле, так что я могу выполнить запрос вставки на количество полей, созданных пользователем.

+0

Не было бы проще назвать входы 'fullname []' (искать «нотацию массива»), чтобы вы могли легко перебирать их после отправки? – bububaba

+0

До сих пор я не добился успеха, я пытался в течение последних 4 часов ... я знаю, в конце концов, это будет очень просто, но он все еще не работает, я попробовал код $ ('# name' + num) .before (num + «Полное имя»); он добавляется только при первом щелчке, но после – Learning

ответ

0

Попробуйте следующее: Я сделал несколько изменений в структуру коды, а именно:
* Создание скрытого шаблона, который все видимые клоны будут клонированными из
* Получения добавить/удалить кнопки работает по желанию
* Добавлено скрытое поле, которое держит количество элементов
* Ввод большой части кода в функцию для повторного использования

<script type="text/javascript"> 

    // document - on load 
    $(document).ready(function() { 

     // add the first item 
     AddInput(); 
     UpdateButtons(); 

     // add button - click 
     $('#btnAdd').click(function() { 
      AddInput(); 
      UpdateButtons(); 
     }); 

     // delete button - click 
     $('#btnDel').click(function() { 
      $('.clonedInput:last').remove(); 
      UpdateButtons(); 
     }); 

    }); 

    function AddInput() 
    { 
     // how many cloned input fields we currently have 
     var numItems = $('.clonedInput').length; 
     var newNum = new Number(numItems + 1); 

     // create the new element via clone() based on hidden template 
     var newElem = $('.templateInput').clone(); 

     // update attributes on parent tag 
     newElem.attr('id', 'input' + newNum); 
     newElem.attr('class', 'clonedInput'); 
     newElem.show();   

     // update child elements 
     newElem.children('#lblSno').html(newNum + ' ' + newElem.children('#lblSno').html()); 
     newElem.children('#lblSno').attr('id', 'lblSno' + newNum); 
     newElem.children('#name').attr('id', 'name' + newNum); 
     newElem.children('#txtEmail').attr('id', 'txtEmail' + newNum); 

     // insert the new element 
     $('#allInputs').append(newElem); 
    } 

    function UpdateButtons() 
    { 
     // get number of items 
     var numItems = $('.clonedInput').length; 

     // only enable delete button when there is more than 1 item 
     if (numItems > 1) 
      $('#btnDel').removeAttr('disabled'); 
     else 
      $('#btnDel').attr('disabled', 'disabled'); 

     // only enable add button when there are less than 5 items 
     if (numItems < 5) 
      $('#btnAdd').removeAttr('disabled'); 
     else 
      $('#btnAdd').attr('disabled', 'disabled'); 

     // update the hidden field 
     $('#hdnNumItems').val(numItems);     
    } 
</script> 

 

<form> 
    <div> 
     <input type="button" id="btnAdd" value="add another name" /> 
     <input type="button" id="btnDel" value="remove name" /> 
     <input type="hidden" id="hdnNumItems" value="0" /> 
    </div> 
    <div id="allInputs"> 
     <div class="templateInput" style="margin-bottom:4px; display:none;"> 
      <label id="lblSno">Full Name</label> 
      <input name="name" type="text" class="TextBoxNext" id="name1" /></td> 
      <input name="txtEmail" type="text" class="TextBoxNext" id="txtEmail1" /></td> 
     </div> 
    <div> 
</form> 
0

Есть тысячи способов сделать то, что вы пытаетесь сделать, и все это полностью зависит от вашего выбора, который нужно использовать. Таким образом, не баловаться с вашей логикой и просто идти с вашим собственным кодом, чтобы добавить серийные номера, просто добавьте одну строку:

newElem.text(newNum + ") Full Name "); 

Вот и все. У вас есть серийный номер.