4

我需要从下拉选择选项框中切换 div。我希望它类似于 jquery 的asmselect,但不是列出选项标签,而是希望它显示一个隐藏的 div。外面有这样的东西吗?或者有谁知道怎么设置?谢谢,杰夫。

更新

基本上我想要的是上面 asmselect 链接的外观和交互,尽管切换 div 而不是生成列表。下面的示例代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script type="text/javascript" src="jQuery1.3.js"></script>
<script type="text/javascript">

$(document).ready(function(){

    $("#theSelect").change(function(){          
        $("#theSelect option:selected").click(function(){
            var value = $(this).val();
            var theDiv = $(".is" + value);

            $(theDiv).toggle(function(){
                $(this).removeClass("hidden");
            }),function(){
                $(this).addClass("hidden");
            }
        }); 
    });

});

</script>
<style type="text/css">
.hidden {
    display: none;
}
</style>
</head>

<body>
    <div class="selectContainer">
        <select id="theSelect">
            <option value="">- Select -</option>
            <option value="Patient">Patient</option>
            <option value="Physician">Physician</option>
            <option value="Nurse">Nurse</option>
        </select>
    </div>
    <div class="hidden isPatient">Patient</div>
    <div class="hidden isPhysician">Physician</div>
    <div class="hidden isNurse">Nurse</div>
</body>
</html>
4

3 回答 3

6

你在找这样的东西吗?http://jsfiddle.net/tYvQ8/

$("#theSelect").change(function() {          
    var value = $("#theSelect option:selected").val();
    var theDiv = $(".is" + value);

    theDiv.slideDown().removeClass("hidden");
    theDiv.siblings('[class*=is]').slideUp(function() { $(this).addClass("hidden"); });
});​

When the select option changes, you

  • 显示选中divslideDown()并删除它的hidden类。
  • 查找div类名中包含“is”的 s 个兄弟姐妹。(如果菜单不是同级菜单会更容易。)
  • 隐藏之前显示的兄弟姐妹,完成后slideUp()需要回调添加hiddenslideUp()

这是另一种(在我看来,更好的)方式:http: //jsfiddle.net/tYvQ8/1/

摆脱你的hidden类,并使用 jQuery 来隐藏它们。然后您不必担心添加和删除类。

没有隐藏类的 HTML

<body>
    <div class="selectContainer">
        <select id="theSelect">
            <option value="">- Select -</option>
            <option value="Patient">Patient</option>
            <option value="Physician">Physician</option>
            <option value="Nurse">Nurse</option>
        </select>
    </div>
    <div class="isPatient">Patient</div>
    <div class="isPhysician">Physician</div>
    <div class="isNurse">Nurse</div>
</body>​

jQuery

$('[class^=is]').hide();

$("#theSelect").change(function(){          
    var value = $("#theSelect option:selected").val();
    var theDiv = $(".is" + value);

    theDiv.slideDown();
    theDiv.siblings('[class^=is]').slideUp();
});​
于 2010-05-14T12:12:51.200 回答
2

列表选项和 div 标签可以以相同的方式识别和切换。

$('#div_id').toggle();

因此,不要像您引用的 asmselect 插件那样使用元素选择器来选择选项标签,只需修改元素选择器以选择页面上的 div 标签。

于 2010-05-04T17:04:46.910 回答
0

如前所述使用 .change() ,但使用 jquery 的 .show() 和/或 .hide() 方法:

    if($(this).val() == 'selected_option') {
        $('.selector1').show(); //displays element with display:none;        
    } else {
        $('.selector1').hide(); //hides element again
    }
于 2017-06-17T10:45:38.680 回答