最初のフィールドから2番目のフィールドにデータを入力する汎用関数があります。ラベルがある場合、問題が発生します。
next()
エレメント。
だから、私は次のようになります:
function buildoptions(el){
var element = el.id;
var $flda = $('#'+element);
var $fldb = $flda.next().next(); //double here to skip the label
.....
}
もちろん、ラベルのないフィールドがいくつかあるので、これは壊れます...
私が考えていた
var $fldb = $flda.next().not(label);
動作しますが、動作しません。それは実際にエラーをスローします
Error: 'label' is undefined
アイデア?
HTML は次のようになります。
<label for="inp_29">Select drives next</label>
<select id="inp_29" name="driver1" onchange="buildoptions(this);">
<option value="" selected="selected">Select</option>
<option value="option1">option1</option>
<option value="option2">option2</option>
</select>
<!--* SOMETIMES OPTIONAL LABEL*-->
<label for="inp_30">No default options</label>
<!--* END SOMETIMES OPTIONAL LABEL*-->
<select id="inp_30" name="filler1">
<option value="Select Driver First">Select Driver First</option>
</select>
表形式のケースもあります:
<TR id="dynrow_table35_1" class="">
<TD class="odd">
<LABEL for="inp_331">absel</LABEL>
<SELECT id="inp_331" onchange="buildoptions(this);" name="absel_1">
<OPTION value="">Select</OPTION>
<OPTION value="option1">option1</OPTION>
<OPTION value="option2">option2</OPTION>
</SELECT></TD>
<TD class="odd"><LABEL for="inp_341">No default options</LABEL>
<SELECT id="inp_341" name="abfil1">
<OPTION value="Select Driver First">Select Driver First</OPTION>
</SELECT> </TD>
</TR>
ID は動的に構築され、実際の ID はわかりません。