Java



Создание динамических форм с помощью JavaScript - часть 2


В итоге у нас должно получиться что-то вроде следующего HTML-кода:

<span id="table">

<table cellspacing=0 cellpadding=3>

<caption>Сведения о детях</caption>

<tr><td>Имя</td><td>Дата рождения</td><td>

<a href="#" onclick="return addline();">добавить</a></td></tr>

<tr id="newline" nomer="[0]">

<td><input type="text" name="name[0]"></td><td><input type="text" name="date[0]"></td>

<td valign="top"><a href="#" onclick="return rmline(0);">удалить</td></tr></table>

</span>

Чтобы вся эта конструкция заработала, необходимо еще написать две функции на JavaScript: добавление новой строки и удаление ошибочно добавленной строки. Причём, в данном примере предполагается, что количество строк с данными может быть и нулевым, кроме того, у данной реализации динамической формы есть недостаток: если удалить все строки, то добавить строки уже будет нельзя. Впрочем, далее в коде программы есть вариации, которые запрещают удалять строку, если она осталась одна.

<script>

var c=0; //счётчик количества строк

function addline() { c++; // увеличиваем счётчик строк

s=document.getElementById('table').innerHTML; // получаем HTML-код таблицы

s=s.replace(/[\r\n]/g,''); // вырезаем все символы перевода строк

re=/(.*)(<tr id=.*>)(<\/table>)/gi; // это регулярное выражение позволяет выделить последнюю строку таблицы

s1=s.replace(re,'$2'); // получаем HTML-код последней строки таблицы

s2=s1.replace(/\[\d+\]/gi,'['+c+']'); // заменяем все цифры к квадратных скобках

// на номер новой строки

s2=s2.replace(/(rmline\()(\d+\))/gi,'$1'+c+')'); // заменяем аргумент функции rmline на номер новой строки

s=s.replace(re,'$1$2'+s2+'$3'); // создаём HTML-код с добавленным кодом новой строки




Содержание  Назад  Вперед