używam funkcji jQuery sklonować DIV, który zawiera zestaw elementów wejściowych:Modyfikacja etykietę atrybutu
<div class="history-form-fields">
<div class="row">
<label for="History_0_type">Type</label>
<select name="History[0][type]" id="History_0_type">
<option value="">Select</option>
</select>
</div>
<div class="row">
<label for="History_0_name">Name</label>
<input type="text" name="History[0][name]" id="History_0_name" />
</div>
<div class="row">
<label for="History_0_year">Year</label>
<select name="History[0][year]" id="History_0_year">
<option value="">Select</option>
</select>
</div>
</div>
<input id="addAnother" type="button" value="Add Another" />
Kiedy ten DIV zostanie sklonowany elementy wejściowe Nazwa i numer znaczniki muszą zostać zmodyfikowane tak że możemy zidentyfikować dane w skrypcie po stronie serwera.
Mam następujący kod, który klonów DIV i modyfikuje INPUT i SELECT tagi:
var counter = 0;
$('#addAnother').click(function(){
var divCloned = $('.history-form-fields:first').clone();
divCloned.insertAfter('.history-form-fields:last');
initNewInputs(divCloned.children('.row'), ++counter);
});
function initNewInputs(divs, idNumber)
{
var inputs = divs.children('input, select').get(); // find all the INPUT and SELECT tags
for(var i in inputs)
{
inputs[i].id = inputs[i].id.replace(/\d+/, idNumber);
inputs[i].name = inputs[i].name.replace(/\d+/, idNumber);
}
}
Jednak mam problemy modyfikujący etykiecie atrybutów. Ktoś wie jak to zrobić?
Pozdrawiam kumpla. Czy "wejścia" dla pętli również mogą być wymienione w ten sposób? – GSTAR
@GSTAR: Tak, może. Jednak będziesz potrzebować dwóch wywołań 'attr'. Możesz napisać 'var replacer = function (index, old) {return old.replace (/ \ d + /, idNumber); }; 'i przekazać to. – SLaks
Hi SLaks - jeszcze jedno pytanie - w momencie modyfikowania atrybutu FOR Chciałbym dodać atrybut "class" do tego samego znacznika etykiety (używając funkcji attr()) - jakikolwiek sposób na zintegrowanie tego z nowym kodem? – GSTAR