1

我有几个页面链接到我的手风琴网格所在的特定页面。在页面加载时,我希望手风琴网格的目标部分为用户自动折叠。

举个例子:页面 A 和页面 B。页面 A 是用户从页面 B 上查看内容的地方。页面 B 有一个带有 4 个(例如 1、2、3 和 4)部分的手风琴。如果用户单击从页面 A 到页面 B 的链接 2,则手风琴的数字 2 部分应折叠以供用户查看。

在下面找到代码:

HTML:

<div id="accord_bar">
<ul id="accordion">
<li><a href="#recent" class="heading">Number 1 Header</a>
<ul id="recent"><li>Number 1</li></ul>
</li>
<li><a href="#popular" class="heading">Number 2 Header</a>
<ul id="recent"><li>Number 2</li></ul>
</li>
<li><a href="#categories" class="heading">Number 3 Header</a>
<ul id="recent"><li>Number 3</li></ul>
</li>
<li><a href="#archive" class="heading">Number 4 Header</a>
<ul id="recent"><li>Number 4</li></ul>
</li></ul></div>

HEAD 标签中的 Javascipt:

<script type="text/javascript">
$(document).ready(function() {
    $('#accordion').accordion(
    {active: "a.default", header: "a.heading"}
    );
});

链接手风琴 Jquery 文件:

<script type="text/javascript" src="js/jquery-ui-accordion.js"></script>

我真的需要尽快解决这个问题,如果有人能提供帮助,我将非常感激......

4

1 回答 1

0

您可以使用 jQuery 构建自己的简单手风琴,无需 ui。

eq()用这种简单的手风琴结构折叠手风琴的特定部分。

这是带有悬停触发器的 jsFiddle。

jQuery:

$('.content').slideUp(100);
$('.content').eq(1).slideDown(600);
//for collapsing second part of an accordion

$('.panel').hover(function() {//open
    var takeID = $(this).attr('id');//takes id from clicked ele
    $('.content').stop(false,true).slideUp(600);
    //used stop for prevent conflict
    $('#'+takeID+'C').stop(false,true).slideDown(600);
    ///show's hovered ele's id macthed div
});​

html:

<div class="panel" id="panel1">panel1</div>
<div class="content" id="panel1C">content1</div>

<div class="panel" id="panel2">panel2</div>
<div class="content" id="panel2C">content2</div>

<div class="panel" id="panel3">panel3</div>
<div class="content" id="panel3C">content3</div>

----------

这是带有单击触发器和关闭按钮的 jsFiddle。

jQuery:

$('.content').slideUp(100);
$('.content').eq(1).slideDown(600);
//for collapsing second part of an accordion

$('.panel').click(function() {//open
   var takeID = $(this).attr('id');//takes id from clicked ele
   $('#'+takeID+'C').slideDown(600);//show's clicked ele's id macthed div
});
$('span').click(function() {//close
   var takeID = $(this).attr('id').replace('Close','');//strip close from id
   $('#'+takeID+'C').slideUp(600);//hide clicked close button's panel
});​

html:

<div class="panel" id="panel1">panel1</div>
<div class="content" id="panel1C">content1<span id="panel1Close">X</span></div>

<div class="panel" id="panel2">panel2</div>
<div class="content" id="panel2C">content2<span id="panel2Close">X</span></div>

<div class="panel" id="panel3">panel3</div>
<div class="content" id="panel3C">content3<span id="panel3Close">X</span></div>

注意:我之前回答过与此答案相关的手风琴: 折叠和展开标签 jquery / 简单手风琴

于 2012-08-29T08:34:53.510 回答