如何显示div,然后在单击链接时隐藏其他div?

时间:2010-12-21 10:34:30

标签: javascript jquery show-hide html

我现在正试图隐藏六个div而只显示其中一个div。我已经尝试过JavaScript和jQuery,但似乎没有任何效果!点击here即可访问该网站。

我想知道它是否与我的CSS,jQuery或HTML有关。或者有更简单的方法吗?

HTML:

<div id="resourceLinks">
  <a href="#" name="resource" id="resource1">General&nbsp;Information</a><br />
  <a href="#" name="resource" id="resource2">Automatic&nbsp;401(k)</a><br />
  <a href="#" name="resource" id="resource3">Consumer&nbsp;Fraud</a><br />
  <a href="#" name="resource" id="resource4">Direct&nbsp;Deposit</a><br />
  <a href="#" name="resource" id="resource5">Diversity</a><br />
  <a href="#" name="resource" id="resource6">Women</a><br />
  <a href="#" name="resource" id="resource7">Young&nbsp;Adults&nbsp;(20s&nbsp;-&nbsp;40s)</a>
  </div>

<div id="resource1></div>
<div id="resource2></div>
<div id="resource3></div>
<div id="resource4></div>
<div id="resource5></div>
<div id="resource6></div>
<div id="resource7></div>

CSS:

#resource1, #resource2, #resource3, #resource4, #resource5, #resource6, #resource7 {
    position: absolute;
    margin-left: 400px;
    margin-top: -10px;
    width: 300px;
    padding-bottom: 120px;
}

#resourceLinks {
    position: fixed;
    margin-left: -450px;
    z-index: 3;
    margin-top: 180px;
    font-size: 16px;
}

jQuery的:

$(document).ready(function(){ 

  $('#resourceLinks a').click(function (selected) { 

    var getName = $(this).attr("id"); 
    var projectImages = $(this).attr("name");

    $(function() {      
      $(".resource").hide().removeClass("current");
      $("#" + projectImages ).show("normal").addClass("current");
    }); 
  }); 
}); 

4 个答案:

答案 0 :(得分:2)

这个怎么样

<div id="resourceLinks">   
    <a href="#" name="resource" id="resource1">General&nbsp;Information</a><br />   
    <a href="#" name="resource" id="resource2">Automatic&nbsp;401(k)</a><br />   
    <a href="#" name="resource" id="resource3">Consumer&nbsp;Fraud</a><br />   
    <a href="#" name="resource" id="resource4">Direct&nbsp;Deposit</a><br />   
    <a href="#" name="resource" id="resource5">Diversity</a><br />   
    <a href="#" name="resource" id="resource6">Women</a><br />   
    <a href="#" name="resource" id="resource7">Young&nbsp;Adults&nbsp;(20s&nbsp;-&nbsp;40s)</a>   
</div>  

<div class="resource" id="resource1_info"></div> 
<div class="resource" id="resource2_info"></div> 
<div class="resource" id="resource3_info"></div> 
<div class="resource" id="resource4_info"></div> 
<div class="resource" id="resource5_info"></div> 
<div class="resource" id="resource6_info"></div> 
<div class="resource" id="resource7_info"></div> 


$(document).ready(function(){
     $("div.resource:gt(0)").hide();  // to hide all div except for the first one
     $('#resourceLinks a').click(function(selected) {
        var getID = $(this).attr("id");      
        var projectImages = $(this).attr("name");      

        $("div.resource").hide();       
        $("#" + getID + "_info" ).show();    
    });  
});  

答案 1 :(得分:0)

假设:

<div id="resourceLinks">
  <a href="#" data-child="resource1">General&nbsp;Information</a><br />
  <a href="#" data-child="resource2">Automatic&nbsp;401(k)</a><br />
  <a href="#" data-child="resource3">Consumer&nbsp;Fraud</a><br />
  <a href="#" data-child="resource4">Direct&nbsp;Deposit</a><br />
  <a href="#" data-child="resource5">Diversity</a><br />
  <a href="#" data-child="resource6">Women</a><br />
  <a href="#" data-child="resource7">Young&nbsp;Adults&nbsp;(20s&nbsp;-&nbsp;40s)</a>
  </div>

<div class="resource" id="resource1">1</div>
<div class="resource" id="resource2">2</div>
<div class="resource" id="resource3">3</div>
<div class="resource" id="resource4">4</div>
<div class="resource" id="resource5">5</div>
<div class="resource" id="resource6">6</div>
<div class="resource" id="resource7">7</div>

你可以:

$(function() {
    var $resLinks = $('#resourceLinks a'),
        $res = $('.resource');

    // Hide all but first
    $res.not(':first').hide();
    $resLinks.first().addClass('current');

    $resLinks.click(function() {
        var $elm = $(this),
            childId = $elm.data('child');

        // Hide all (only one is visible, though)
        $res.hide();

        // Reset and set .current class on links
        $resLinks.removeClass('current');
        $elm.addClass('current');

        // Show related
        $('#' + childId).show();

        return false;
    });
});

更新#1:代码为tested

更新#2: Showing first on init

答案 2 :(得分:0)

我认为你正在努力实现手风琴效果..看看这里:

http://jquery.bassistance.de/accordion/demo/

它和现有的jQuery插件。

答案 3 :(得分:0)

使用classNames

<div id="resourceLinks">
      <a href="#" class="resource1">General Information</a><br />
      <a href="#" class="resource2">Automatic</a><br />
      <a href="#" class="resource3">Consumer Fraud</a><br />
      <a href="#" class="resource4">Direct Deposit</a><br />
      <a href="#" class="resource5">Diversity</a><br />
      <a href="#" class="resource6">Women</a><br />
      <a href="#" class="resource7">Young</a>
</div>
<div class="resources">
    <div id="resource1" class="current"></div>
    <div id="resource2"></div>
    <div id="resource3"></div>
    <div id="resource4"></div>
    <div id="resource5"></div>
    <div id="resource6"></div>
    <div id="resource7"></div>
</div>

jQuery的:

$(document).ready(function(){
     $('#resourceLinks a').click(function() {
        $('div.resources div').hide().removeClass('current');       
        $("#" + $(this).attr('className')).show().addClass('current');
    });  
});