Добавление и удаление элементов из списков
Меня интересует практическое использование JS. Я написал программу для изобретателей "Функционально-стоимостный анализ технических систем" на VB. Немного ознакомившись с JS, понял, что кое-что можно сделать и здесь. Представляю один из этапов ФСА в виде скрипта. Такой скрипт является основой всей программы и нужен на всех ее этапах. Следующий скрипт, который является развитием этого скрипта, смотрите Здесь
С уважением,
invem
<HTML>
<HEAD>
<TITLE>Добавление и удаление элементов из списков</TITLE>
<meta http-equiv="Content-Type" content="text/html; charset=windows-1251">
<script type="text/javascript">
function focusElement() {
var elem = document.forms[0].myInput;
elem.focus();
}
function addList(){
valid = true;
document.forms[0].myInput.focus()
var list1 = document.getElementsByTagName('select')[0];
var li = document.createElement('option');
/*Запрещение ввода пустой строки */
if (document.forms[0].myInput.value<1)
return valid;
/* Ввод в список из текстового поля */
li.innerHTML =document.forms[0].myInput.value
/* Очистка текстового поля */
document.forms[0].myInput.value=""
list1.appendChild(li);
}
</script>
</HEAD>
<BODY onload='focusElement()'>
<form name="form1">
<br /><b>Ввод элементов технической системы</b><br />
<input name="myInput" value= "" size="42"> <br /><br />
<input onclick='addList()' type='button'
value='Добавить элемент ТС в список'><br />
<input type=button value='Удалить элемент ТС из списка'
onClick="for(i=0;i<form.elements[3].length;i++)
if(form.elements[3].options[i].selected==true)
form.elements[3].options[i] = null;"><br /><br />
<b>Элементы ТС<br /><br />
<select size="5" multiple id="list1"></<select>
</form>
</BODY>
</HTML>
|
надо бы изменить:
1. когда поле пустое, то в список ничего добавлять не нужно
2. сначала выбрать из списка удаляемый элемент, а потом удалять
Спасибо за замечания.
Ввод пустого списка устранил и выборку сделал. Только через select.
Здравствуйте!
Возможно удобнее было бы использовать Google Apps, который позволяет использовать Java.
Есть один косячек:
при попытке удалить более одного элемента удаление происходит неправильно.
в данном коде производится обращение по индексу элемента и потом он "зануляется", но при "заулении" индексация всех элементов меняется, и удление происходит "половинчато", т.е. имея 4-е элемента в списке, и при попыте удалить их все удалится сначала 2-а, потом 1...
решение:
при занулении возвращаем инденкс и все удаляется без проблем.