Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Как реализовать? (https://javascript.ru/forum/dom-window/34738-kak-realizovat.html)

RodgerFox 17.01.2013 03:35

Как реализовать?
 
Доброй ночи, уважаемые пользователи форума. Я прошу вашей помощи. Прошу прощения, если разместил в неправильной ветки. Не знаю куда лучше отнести вопрос.
Как в у форм сделать что то вроде наследования...
Исправил, удалил лишнее оставил важный пример.
Предположим, имеется массив форм (идентичных) по своему составу:
<p>
<input id="1" type="text" name="label[]" value="текст из инпута 1" ../> <!-- название работы которая идет в список (select) -->
</p>
<p>
<input id="2" type="text" name="label[]" value="текст из инпута 2" ../> <!-- название работы которая идет в список (select) -->
<select multiple name="parent[]">
    <option disabled>выбор из уже описанных инпутов</option>
    <option value="1">текст из инпута 1</option>
   <option value="3">текст из инпута 3</option>
</select>
</p>
<p>
<input id="3" type="text" name="label[]" value="текст из инпута 3" ../> <!-- название работы которая идет в список (select) -->
<select multiple name="parent[]">
    <option disabled>выбор из уже описанных инпутов</option>
    <option value="1">текст из инпута 1</option>
    <option value="2">текст из инпута 2</option>
</select>
</p>
<!-- и так далее до бесконечности -->

как в селект, выбор запихнуть данные из инпутов со всех? и брать ихний ид? 1,2,3,++

ОлегА 17.01.2013 16:38

Вы опубликовали очень много кода.

Пожалуйста, локализуйте проблему!

Выделите фрагмент кода, по которому есть вопрос и опубликуйте его отдельно.

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

Спасибо.

P.S. код форматируют специальные теги [ js ] ... [/js], [ html ] ... [/html] и другие аналогичные, сам. http://javascript.ru/formatting

DjDiablo 18.01.2013 02:05

лучше всего сделать выборку по классу
или найти контейнер всех форм(formcontainer) и искать в нём по тегу <P> как в вашем случае.

пример ниже берёт данные из всех форм, поиск по классу.
дальше задачу я не понял.
поэтому просто собрал данные в массив, и вывел его
но вы вместо заполнения массива можете в этом цикле делать именно то что вам надо.

upd/
если я правильно сейчас догонять начал, то храните связь инпута и options в атрибутах. Это может быть id inputa в атрибуте option как пример, или атрибут в input с порядковым номером option, и 100500 других вариантов в придачу.
Если бы вы задачу точнее уточнили, то я бы точнее посоветовал.

<div id="formcontainer">
<p class="superform">
<input id="2" type="text" name="label[]" value="текст из инпута 2" ../> <!-- название работы которая идет в список (select) -->
<select multiple name="parent[]">
    <option disabled>выбор из уже описанных инпутов</option>
    <option value="1">текст из инпута 1</option>
   <option value="3">текст из инпута 3</option>
</select>
</p>
<p class="superform">
<input id="3" type="text" name="label[]" value="текст из инпута 3" ../> <!-- название работы которая идет в список (select) -->
<select multiple name="parent[]">
    <option disabled>выбор из уже описанных инпутов</option>
    <option value="1">текст из инпута 1</option>
    <option value="2">текст из инпута 2</option>
</select>
</p>
<!-- и так далее до бесконечности -->

</div>
<script>
    var  forms=document.getElementsByClassName('superform') ;
    var data=[];
    for (var i=0,length=forms.length;i<length;i++){
      data.push ( 
                forms[i].getElementsByTagName("input")[0].value
      );      
   }

   alert (data);
</script>

RodgerFox 18.01.2013 12:25

Вы правильно подумали, "то храните связь инпута и options в атрибутах. Это может быть id ..."

RodgerFox 19.01.2013 02:03

up Кто знает решение?

Deff 19.01.2013 02:19

<script src="http://code.jquery.com/jquery-latest.js"></script>

<div id="formcontainer">
<p class="superform">
<label for="2">инпут 2</label><br />
<input id="2" type="text" name="label[]" value="текст из инпута 2" ../> <!-- название работы которая идет в список (select) -->
<select multiple name="parent[]">
    <option disabled>выбор из уже описанных инпутов</option>
    <option value="1">текст из инпута 1</option>
   <option value="3">текст из инпута 3</option>
</select>
</p>
<p class="superform">
<label for="3">инпут 3</label><br />
<input id="3" type="text" name="label[]" value="текст из инпута 3" ../> <!-- название работы которая идет в список (select) -->
<select multiple name="parent[]">
    <option disabled>выбор из уже описанных инпутов</option>
    <option value="1">текст из инпута 1</option>
    <option value="2">текст из инпута 2</option>
</select>
</p>
<p class="superform">
<label for="4">инпут 4</label><br />
<input id="4" type="text" name="label[]" value="текст из инпута 4" ../> <!-- название работы которая идет в список (select) -->
<select multiple name="parent[]">
    <option disabled>выбор из уже описанных инпутов</option>
    <option value="2">текст из инпута 2</option>
    <option value="3">текст из инпута 3</option>
    <option value="4">текст из инпута 4</option>
</select>
</p>
<!-- и так далее до бесконечности -->

</div>





<script>
$(document).ready(function(){

 function PresetTxtOpt(){
  var a = 'parent[]';
  $("p.superform select[name='"+a+"'] option").each(function(i){
    if(!$(this).parent().find('option').index(this)){return true;}
     var ID=$(this).val();
    var TxtOpt=$("p.superform input[id='"+ID+"']").val();
    if(TxtOpt)TxtOpt=TxtOpt.replace(/^\s*/g,'');
     if(TxtOpt){
        $(this).removeAttr('disabled');
        $(this).text(TxtOpt);
     }
    var txt = '(не найден/не заполнен)';
     if(!TxtOpt){
        $(this).text($(this).text().replace(txt,'')+txt);
        $(this).attr('disabled',true);
     }
  });
 } PresetTxtOpt();

 $("p.superform select").change(function(){
    PresetTxtOpt();
 });
 $("p.superform input").bind('input keyup mouseup',function(){
    PresetTxtOpt();
 });

});
</script>

RodgerFox 19.01.2013 23:56

Вау... спасибо, только не много не так. на примере инпута 4, он показывает в выборе и свой тоже. А хотелось бы, что бы предлагали все варианты инпутов кроме того в котором список >.<

Deff 20.01.2013 00:00

RodgerFox,
Я показал что можно воткнуть любые, cкрипт смотрит по option в селекторе
Незаполненные или отсутствующие инпут - выбор блокируется,
Перерисовка контента option => при выборе option или заполнении инпут

RodgerFox 20.01.2013 00:11

Спасибо поиграюсь с этим сейчас, надеюсь что то из этого сооружу.

RodgerFox 20.01.2013 22:49

Посмотрите пожалуйста
http://algoritm.rodgerfox.jino.ru/index.html Первый селект обновляется только, если во второй инпут ввести что то и нажать или на первый инпут или на селект первый. почему так происходит?
Большое спасибо.


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