10

您好,我有以下 2 个 JavaScript 函数来打开和关闭 div。

<script>
    function show() {
        if(document.getElementById('benefits').style.display=='none') {
          document.getElementById('benefits').style.display='block';
        }
    }
</script>



<script>
    function close() {
        if(document.getElementById('benefits').style.display=='block') {
          document.getElementById('benefits').style.display='none';
        }
    }  
</script>

这是html:

<div id="opener"><a href="#1" name="1" onclick=show()>click here</a></div>
<div id="benefits" style="display:none;">
   some input in here plus the close button
   <div id="upbutton"><a onclick=close()></a></div>
</div>

由于某种原因,显示功能按应有的方式工作,但关闭按钮不起作用。因此,如果有人可以帮助我,我将不胜感激。非常感谢。

4

8 回答 8

23
<script> 
    function show() { 
        if(document.getElementById('benefits').style.display=='none') { 
            document.getElementById('benefits').style.display='block'; 
        } 
        return false;
    } 
    function hide() { 
        if(document.getElementById('benefits').style.display=='block') { 
            document.getElementById('benefits').style.display='none'; 
        } 
        return false;
    }   
</script> 


 <div id="opener"><a href="#1" name="1" onclick="return show();">click here</a></div> 
    <div id="benefits" style="display:none;">some input in here plus the close button 
           <div id="upbutton"><a onclick="return hide();">click here</a></div> 
    </div> 
于 2012-07-09T13:04:06.880 回答
5

我通常用类来做这件事,这似乎迫使浏览器重新评估所有的样式。

.hiddendiv {display:none;}
.visiblediv {display:block;}

然后使用;

<script>  
function show() {  
    document.getElementById('benefits').className='visiblediv';  
}  
function close() {  
    document.getElementById('benefits').className='hiddendiv';  
}    
</script>

请注意“className”的大小写,这让我大吃一惊

于 2012-07-09T12:58:23.867 回答
4

jQuery 的美将允许我们执行以下操作:

$(function()
{
    var benefits = $('#benefits');

    // this is the show function
    $('a[name=1]').click(function()
    { 
        benefits.show();
    });

    // this is the hide function
    $('a', benefits).click(function()
    {
        benefits.hide();
    });
});

或者,您可以使用 1 个按钮切换显示,如下所示:

$(function()
{
    // this is the show and hide function, all in 1!
    $('a[name=1]').click(function()
    { 
        $('#benefits').toggle();
    });
});
于 2012-07-09T13:01:22.933 回答
3

你需要里面的链接是可点击的,这意味着它需要一个带有一些内容的href,而且close()是window的内置函数,所以你需要更改函数的名称以避免冲突。

<div id="upbutton"><a href="#" onclick="close2()">click to close</a></div>

此外,如果您想要一个真正的“按钮”而不是链接,您应该使用<input type="button"/>or <button/>

于 2012-07-09T13:01:58.530 回答
2

检查这个:

点击这里
<div id="benefits" style="display:none;">some input in here plus the close button
       <div id="upbutton"><a onclick="close(); return false;"></a></div>
</div>
于 2012-07-09T12:55:39.957 回答
2

例如,将关闭函数重命名为“隐藏”,它将起作用。

function hide() {
    if(document.getElementById('benefits').style.display=='block') {
      document.getElementById('benefits').style.display='none';
    }
} 
于 2012-07-09T13:03:46.087 回答
0

Close 似乎是某种保留字(可能是指 window.close)。将其更改为其他内容似乎可以解决问题。

http://jsfiddle.net/c7gdL/1/

于 2012-07-09T13:10:06.973 回答
0

你可以用这样的东西压缩这两者[就像 jQuery 一样]:

function toggleMyDiv() {
 if (document.getElementById("myDiv").style.display=="block"){
  document.getElementById("myDiv").style.display="none"
  }
 else{
  document.getElementById("myDiv").style.display="block";
 }
}

..并在两个按钮中使用相同的功能 - 或者通常在页面中为这两个功能使用。

于 2013-11-23T11:29:36.607 回答