21

これは私を夢中にさせています。私が見落としているのは、単純でばかげたものでなければなりません。フォームに複数選択ボックスがあります。選択された値を取得しようとしています。私のループでは、アラートを使用しても問題ありません。値を連結しようとするとすぐに、エラー 'SelBranch[...].selected' is null or not an object が表示されます

      <form name="InventoryList" method="post" action="InventoryList.asp">
          <select name="SelBranch" class="bnotes" size="5" multiple="multiple">
          <option value="All">All</option>
          <option value="001 Renton">001 Renton</option>
          <option value="002 Spokane">002 Spokane</option>
          <option value="003 Missoula">003 Missoula</option>
          <option value="004 Chehalis">004 Chehalis</option>
          <option value="005 Portland">005 Portland</option>
          <option value="006 Anchorage">006 Anchorage</option>
          <option value="018 PDC">018 PDC</option>
          </select>

         <input type="button" name="ViewReport" value="View" class="bnotes" onclick="GetInventory();">

   </form>


   <script language="JavaScript">
       function GetInventory()
       {
         var InvForm = document.forms.InventoryList;
         var SelBranchVal = "";
         var x = 0;

         for (x=0;x<=InvForm.SelBranch.length;x++)
         {
            if (InvForm.SelBranch[x].selected)
            {
             //alert(InvForm.SelBranch[x].value);
             SelBranchVal = SelBranchVal + "," + InvForm.SelBranch[x].value;
            }
         }
         alert(SelBranchVal);
       }


  </script>
4

4 に答える 4

17

for ループが 1 回余分に実行されています。変化する

for (x=0;x<=InvForm.SelBranch.length;x++)

for (x=0; x < InvForm.SelBranch.length; x++)
于 2011-03-16T18:40:49.847 に答える
3

HTMLSelectElement.selectedOptionsを見てください。

HTML

<select name="north-america" multiple>
  <option valud="ca" selected>Canada</a>
  <option value="mx" selected>Mexico</a>
  <option value="us">USA</a>
</select>

JavaScript

var elem = document.querySelector("select");

console.log(elem.selectedOptions);
//=> HTMLCollection [<option value="ca">Canada</option>, <option value="mx">Mexico</option>]

これは非multiple <select>要素でも機能します


警告:これに対するサポートはselectedOptions、現時点ではあまり知られていないようです

于 2014-09-17T19:25:32.223 に答える
3

ここでは、役に立つかもしれない参考のために回答を投稿しています。

<!DOCTYPE html>
<html>
<head>
<script>
function show()
{
     var InvForm = document.forms.form;
     var SelBranchVal = "";
     var x = 0;
     for (x=0;x<InvForm.kb.length;x++)
         {
            if(InvForm.kb[x].selected)
            {
             //alert(InvForm.kb[x].value);
             SelBranchVal = InvForm.kb[x].value + "," + SelBranchVal ;
            }
         }
         alert(SelBranchVal);
}
</script>
</head>
<body>
<form name="form">
<select name="kb" id="kb" onclick="show();" multiple>
<option value="India">India</option>
<option selected="selected" value="US">US</option>
<option value="UK">UK</option>
<option value="Japan">Japan</option>
</select>
<!--input type="submit" name="cmdShow" value="Customize Fields"
 onclick="show();" id="cmdShow" /-->
</form>
</body>
</html>
于 2013-01-25T11:37:53.903 に答える
2

また、これを変更します。

    SelBranchVal = SelBranchVal + "," + InvForm.SelBranch[x].value;

    SelBranchVal = SelBranchVal + InvForm.SelBranch[x].value+ "," ;

その理由は、初めて変数SelBranchValが空になるためです

于 2012-08-04T17:03:11.737 に答える