4

単純な JavaScript コードを使用して、div onclick を切り替えています。次のリンクで動作を確認できます: k-prim.biz/Untitled-2.html - 非常にシンプルなデモ ページです。私が作りたいのは、「リンク」をクリックしたときだけでなく、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 に答える