Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Создание елементов из формы. (https://javascript.ru/forum/dom-window/35275-sozdanie-elementov-iz-formy.html)

romaalupka 05.02.2013 21:17

Создание елементов из формы.
 
Добрый вечер, есть форма, человек вписывает цифровое значение и создаеться столько html елементов, сколько он вписал. Я в js слобоват, прошу вашей помощи. :thanks:

Deff 05.02.2013 21:22

Цитата:

Сообщение от romaalupka
и создаеться столько html елементов

Выложите минимальное HTML для формы и одного создаваемого элемента
(Используйте для вставки HTML кнопку

romaalupka 05.02.2013 21:52

<script>
    	var num_track = days_calc(getElementById('submit').value);
		        function days_calc() {
		        	var	track_list = document.createElement('div');
		        	track_list.innerHTML = '<p> Название песни <input type="text">   url: <input type="text"></p>';
		        	document.body.appendChild(track_list);
		        }
        </script>


<p><input type="text" id="num_track"> Введите кол-во песен</p>
       		<p><input type="submit" value="Продолжить" onclick="days_calc()" id="submit"></p>

Deff 05.02.2013 22:03

romaalupka,
:) А где сама форма ? <form
И второе - по клику на субмит(если форма есть) смениться страница ? Cмысл в элементах ?

romaalupka 05.02.2013 22:10

Ну дело в том что мне нужен типо как калькулятор, есть форма, в ней поле, я ввожу число, потом сабмит, создаються еще поля, я их заполняю, клик самбмит, генериться текст ареа внутри с html кодом. Не знаю, понятно обьяснил или нет :)

Deff 05.02.2013 22:15

romaalupka,
А как форма не переадресует у Вас по субмиту (или это уже все осуществлено ?
И я так и не понял - какой элемент нужно создавать(копировать) и вставлять (нужное количество) - поясните

romaalupka 05.02.2013 22:18

Сказать честно, не совсем понял вас :) Переадресовывать это вы про action="" ?? я этот весь фунционал хочу реализовать на js.

Deff 05.02.2013 22:20

romaalupka,
фиг с ней с формой - я тоже не понял -- у Вас было:
Цитата:

Сообщение от romaalupka
Добрый вечер, есть форма,

- Забить...
================================================== ===

Где дублируемый элемент ?
Цитата:

Сообщение от romaalupka
и создаеться столько html елементов,


romaalupka 05.02.2013 22:35

<p> Название песни <input type="text"> url: <input type="text"></p>

romaalupka 05.02.2013 22:36

Вот эту строку нужно дублировать.

Deff 06.02.2013 01:09

<!DOCTYPE HTML>
<html>
  <head>
<script>
    	function Num_calc(a) {
    	    	var Max_track = 20; //Максимальное кол-во, вводимое за один раз;
    	    	var b = a.value.replace(/^(\d*)$/,'$1');//alert( +b)
    	    	a.value=a.value.replace(/\s|[^\d]/g,'');
    	    	if((a.value!=''&& b=='')||b.replace(/^\d*$/,'')!=''){alert('Неверный Ввод!');return;}
    	    	if(+b%(Max_track+1)!=b){alert('Число более '+Max_track+'!');a.value=(+a.value)%(Max_track);return;}
    	}
    	function days_calc() {
    	    	var a = document.getElementById('num_track');
    	    	var N = +a.value;
    	    	a.value='';
    	    	for(var i=0; i<N; i++) {
    	    	   var track_list = document.createElement('div');
    	    	   var DigLen=3;if(i+1>9){DigLen=1;}; DigLen = 'xxx'.substr(0,(DigLen)).replace(/x/g,'&nbsp;')
    	    	   track_list.innerHTML = '<p> Название песни №'+(i+1)+DigLen+'<input type="text">   url: <input type="text"></p>';
    	    	   document.getElementById('Wrp_Track_List').appendChild(track_list);
    	    	}
    	}

</script>
 </head>
  <body>



<div id="Wrp_Track_List"></div>

<div style="color:#7F9DB9;max-width:400px;float:left;"><hr style="color:#7F9DB9;width:400px;"></div><br>
<p><input type="text" maxlength="3" size="3" id="num_track" onkeyup="Num_calc(this)" oninput="Num_calc(this)"> Введите кол-во песен (не более 20 за раз)</p>


    <p><input type="submit" value="Продолжить" onclick="days_calc()" id="submit"></p>


  </body>
</html>

рони 06.02.2013 01:29

Deff,
как вариант без RegExp
function Num_calc(a) {
    	    	var Max_track = 20; //Максимальное кол-во, вводимое за один раз;
    	    	var b = parseInt(a.value, 10)
    	    	if(!b){alert('Неверный Ввод!');a.value = '';return;}
    	    	if(b > Max_track){alert('Число более '+Max_track+'!');a.value=b%Max_track;return;}
    	}

Deff 06.02.2013 01:36

рони,
Не заморачивался, хотя изящнее
----------------------------
Вот это (a.value!=''&& b=='') Важно - иначе стереть нельзя при неправильном вводе
а при parseInt(a.value, 10) - данного равенства не будет


Часовой пояс GMT +3, время: 08:31.