4

我正在使用一个简单的 javascript 代码来切换 div onclick。您可以在此链接上看到它的实际效果:k-prim.biz/Untitled-2.html - 这是一个非常简单的演示页面。我想做的是不仅在单击“链接”时隐藏div,而且在单击div外部时也隐藏div。另外,当显示 div 时,如何更改“链接”的 css 样式?先感谢您!

<script type="text/javascript" language="javascript"> 
   function showHide() {
   var ele = document.getElementById("showHideDiv");
if(ele.style.display == "block") {
        ele.style.display = "none";
  }
else {
    ele.style.display = "block"; }
}
</script> 
<a href="#" onClick="return showHide();" >link</a>
<div id="showHideDiv" style="display:none;">hello!</div>    
4

3 回答 3

5

你没有给我任何代码,所以你必须修改它以满足你的需要:

$(document).click(function() {
    if(this != $("#the_div")[0]) {
        $("#the_div").hide();
    }
});

如果用户单击页面上不是该 div 的任何位置,这将隐藏该 div。

于 2013-02-01T18:28:15.603 回答
3

HTML:

<div id="settings">
<input/><select></select><span>text</span>
</div> 

Javascript:

var settings = document.getElementById('settings');

document.onclick = function(e){

    var target = (e && e.target) || (event && event.srcElement);
    var display = 'none';

    while (target.parentNode) {

        if (target == settings) {
            display ='block';
            break;
        }
        target = target.parentNode;
    }

settings.style.display = display;

}
于 2014-03-05T15:47:52.730 回答
1

这是我写的一个快速破解。我不确定您为什么要通过单击文档上的任意位置来执行相同的活动。如果您想这样做,请将 jQuery('#link') 替换为 jQuery(document)。

    <html>
        <head>
           <script type="text/javascript">
               $(document).ready(function(){
                  jQuery('#link').click(function(){
                       if(jQuery('#showHideDiv').hasClass('hide')) {
                          jQuery('#showHideDiv').removeClass('hide');
                          jQuery('#link').css('color', 'red');
                       } else {
                           jQuery('#showHideDiv').addClass('hide');
                           jQuery('#link').css('color', 'blue');
                       }
                    });            
                });
            </script>
        </head>
       <body>
            <a href="#" id="link" >link</a>
            <div id="showHideDiv" class="hide">hello!</div>    
       </body>
    </html>

这是 jsfiddle 的链接

http://jsfiddle.net/EUScV/9/

并添加 css 规则

   .hide {
        display:none;
    }
于 2013-02-01T19:15:47.880 回答