JavaScript - 根据表单选择显示/隐藏Div(回发)

时间:2011-04-25 09:39:55

标签: javascript css forms

我有一个表单,用于更新数据库中的现有信息集。在它内部是一个选择框,当选择选项'B'时它显示一个隐藏的部分,而在选项'A'它将隐藏该部分。这很好用。

但是,当我从数据库加载一个记录集并且选择框设置为选项'B'以显示隐藏的div时,它不会显示。

这是因为我正在使用'onchange'切换DIV标签。

如何让JS正确显示记录集的DIV标记?目前要查看数据我必须在两个选项之间切换选择框。

我对JS几乎一无所知,下面的JS不是我的,我会感激一些帮助。

由于

<!--- show / hide DIV based on select --->

<script type="text/javascript"><!--
var lastDiv = "";
function showDiv(divName) {
    // hide last div
    if (lastDiv) {
        document.getElementById(lastDiv).className = "hiddenDiv";
    }
    //if value of the box is not nothing and an object with that name exists, then change the class
    if (divName && document.getElementById(divName)) {
        document.getElementById(divName).className = "visibleDiv";
        lastDiv = divName;
    }
}
//-->
</script>
<style type="text/css" media="screen"><!--
.hiddenDiv {
    display: none;
    }
.visibleDiv {
    display: block;
    border: 0px grey solid;
    }

--></style>
<!--- end DIV hide --->



--------------snip----------



  <select name="ad_i" id="ad_i" onchange="showDiv(this.value);">
      <option value="in" <? echo $adtypea; ?> >Option A </option>
      <option value="ba" <? echo $adtypeb; ?> >Option B</option>
   </select>

   <!--- start hiding DIV --->

  <div class="hiddenDiv" id="ba">

  <br /><br />Coding for Ad<br />

<select name="ad_type" id="ad_type">
      <option value="html" <? echo $codestylea; ?> >HTML</option>
      <option value="adsense"<? echo $codestylef; ?>>Adsense / Other JavaScript Code</option>
      <option value="img" default="default" <? echo $codestyleb; ?>>Image</option>
      <option value="swf" <? echo $codestylec; ?>>Flash</option>
   </select>


   </div>
   <!--- end Div for hidden--->

2 个答案:

答案 0 :(得分:0)

在您渲染了选择框并且想要显示/隐藏呼叫的div之后:

<script type="text/javascript">
var selectbox = document.getElementById("ad_i");
showDiv(selectbox.options[selectbox.selectedIndex].value);
</script>

所以我认为应该追求

<!--- end Div for hidden--->

答案 1 :(得分:-2)

<script type="text/javascript">

    $(document).ready(function(){
    $('#bl_cat').on('change', function() {
      if ( this.value == 'vid')
      //.....................^.......
      {
        $("#dis-vid").show();
        $("#dis-img").hide();  
      }
      else
      {
        $("#dis-img").show();  
        $("#dis-vid").hide();
      }
    });
});
</script>