Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

HTML+CSS+JavaScript

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: добавление елемента
 
 автор: Кирилл   (17.11.2005 в 19:00)   письмо автору
 
 

Не судите меня строго я только начинающий в Java.

<html>
<head>
  <title></title>
<script language="JavaScript" type="text/javascript">
 <!--
       var vuvod="";
      function dobav()
      {
      forma1.dob.value=forma1.dob.value;
      for (i=0;i<forma1.dob.value;i++) {
      vuvod=vuvod+"<input name='Name' type='text' value=''><br>\n";
      }
      p1.innerText=vuvod;
     }
 //-->
</script>
  </head>

<body>
<form name=forma1>
<input type="text" name=dob><br>
<input type=button name=but1 value=Send onclick="dobav()">
<p id=p1></p>
</form>
</body>
</html>

Что в етом коде не правильно?
По задуму ты вводиш в поле любое число и после того как ты нажимаеш на кнопку такое число полей должно появится после кнопки.
Зарание спасибо.

   
 
 автор: Crux   (17.11.2005 в 19:44)   письмо автору
 
   для: Кирилл   (17.11.2005 в 19:00)
 

всместо innerText надо использовать innerHTML

   
 
 автор: Кирилл   (17.11.2005 в 20:31)   письмо автору
 
   для: Crux   (17.11.2005 в 19:44)
 

А каким образом можно избавится от тега <p>. Мне надо чтобы после кнопки сразу выводились текстовые поля.

   
 
 автор: Crux   (18.11.2005 в 17:54)   письмо автору
 
   для: Кирилл   (17.11.2005 в 20:31)
 

например использовать тэг span

   
 
 автор: Кирилл   (18.11.2005 в 19:39)   письмо автору
 
   для: Crux   (18.11.2005 в 17:54)
 

А как можно зделать чтоб после нажатия на кнопку после неё дописывались поля в том количестве в котором они введены, а то выходит сечас при первом вводе появляется n количество полей, а при втором все данные перезаписываются тоесть всё что было введено первый раз удаляется.

   
 
 автор: Drago   (24.11.2005 в 23:36)   письмо автору
 
   для: Кирилл   (18.11.2005 в 19:39)
 

Такой же вопрос. Как в этом коде сделать так, чтобы при добавлении нового поля, введенный текст в существующие поля не стирался? Пробовал поставить return false; после вызова функции, но не помогает.

И еще вопрос сразу, как удалить поле?

   
 
 автор: Crux   (25.11.2005 в 18:07)   письмо автору
 
   для: Drago   (24.11.2005 в 23:36)
 

добавляем

<html> 
<head> 
  <title></title> 
<script language="JavaScript" type="text/javascript"> 
<!-- 
var vuvod=""; 
function dobav() 
    { 
    forma1.dob.value=forma1.dob.value; 
    var teg=document.getElementById("p1")
    for (i=0;i<forma1.dob.value;i++) 
        {
        var newElem=document.createElement("input")
        newElem.type="text"
        teg.appendChild(newElem)
        var newElem=document.createElement("br")
        teg.appendChild(newElem)
        }
     } 
//--> 
</script> 
  </head> 

<body> 
<form name=forma1> 
<input type="text" name=dob><br> 
<input type=button name=but1 value=Send onclick="dobav()"> <br>
<span id=p1></span> 
</form> 
</body> 
</html>

   
 
 автор: Crux   (25.11.2005 в 18:16)   письмо автору
 
   для: Drago   (24.11.2005 в 23:36)
 

при удалении узла используется метод removeChild() не удаляемого узла, а его родительского узла.

//elemId - это id того узла (элемета), который надо удалить
function removeElement(elemId)
{
var elem = document.getElementById(elemId)
elem.parentNode.removeChild(elem)
}


PS данная функция взята из книги, самому пользовться не приходилось

   
 
 автор: Drago   (26.11.2005 в 01:21)   письмо автору
 
   для: Crux   (25.11.2005 в 18:16)
 

Спасибо.
А как переделать вот этот код, чтобы возле каждого поля, появилась ссылка на удаление конкретно этого поля? И не оставалось пустого места, после удаления.

<html> 
<head> 
  <title></title> 
<script language="JavaScript" type="text/javascript"> 
<!-- 
function dobav() 
    { 
    var teg=document.getElementById("p1") 
    
        var newElem=document.createElement("input") 
        newElem.type="text"
        newElem.name="text[]" 
        newElem.id="pole"
        newElem.size=75
        newElem.maxlength=500
        teg.appendChild(newElem) 
        
        var newElem=document.createElement("br") 
        teg.appendChild(newElem) 
        
     } 
function removeElement(elemId) 

var elem = document.getElementById(elemId) 
elem.parentNode.removeChild(elem) 
}
//--> 
</script> 
  </head> 

<body> 
<a href="#"  name="dob1" onclick="removeElement('pole')">remove</a><br>
<a href="#"  name="dob" onclick="dobav()">add</a><br>
<form name=forma1>
<span id=p1></span> 
</form>
</body> 
</html>

   
 
 автор: Crux   (27.11.2005 в 19:55)   письмо автору
 
   для: Drago   (26.11.2005 в 01:21)
 


<html> 
<head> 
  <title></title> 
<script language="JavaScript" type="text/javascript"> 
<!-- 
var num=0
function dobav() 
    { 
    var teg=document.getElementById("p1") 
        var elm=document.createElement("span") 
        elm.id="id_"+num
        var newElem=document.createElement("input") 
        newElem.type="text" 
        newElem.name="text[]" 
        newElem.size=75 
        newElem.maxlength=500 
        elm.appendChild(newElem) 
        
        var newElem=document.createElement("a")
        newElem.href="#"
        
        newElem.onclick=function()
            {
            elemId=this.parentNode.attributes.id.value
            var elemDel = document.getElementById(elemId) 
            elemDel.parentNode.removeChild(elemDel)
            }
            
        var txt=document.createTextNode("delete")
        newElem.appendChild(txt)
        
        elm.appendChild(newElem)
        
        var newElem=document.createElement("br") 
        elm.appendChild(newElem)
        
        teg.appendChild(elm)
        
        num++         
     } 
//--> 
</script> 
  </head> 

<body> 
<a href="#"  name="dob" onclick="dobav()">add</a><br> 
<form name=forma1> 
<span id=p1></span> 
</form> 
</body> 
</html> 

   
 
 автор: Drago   (28.11.2005 в 01:16)   письмо автору
 
   для: Crux   (27.11.2005 в 19:55)
 

То, что нужно. Большое спасибо. :)

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования