Jquery手风琴,下一个和上一个向导,如何获得上一节和下一节?

时间:2009-09-13 16:51:41

标签: javascript jquery accordion

我有一支Jquery手风琴,效果很好。单击相应标题时,节将展开/折叠。但我想添加这些功能,以便当我点击“下一步”按钮时,它会打开下一部分,然后点击“上一步”按钮将我带回上一部分。

这已在此页http://jquery.bassistance.de/accordion/demo/?p=1.1.2(最后一个示例)上完成,但不确定如何在我的情况下实现相同的内容。

请提出任何建议。

由于

更新:如何获得手风琴的上一部分或下一部分?

<script type="text/javascript">
 $("#accordion").accordion({ 
   header: "h3.header"
   , autoHeight: false
   , collapsible: true
  });
</script>

<div id="accordion">
 <h3 class="header">Section 1</h3>
 <div> content 1 .. content 1 .. content 1 .. content 1 ..
  <input class="next" type="button" value="next"/>   
 </div>
 <h3 class="header">Section 2</h3>
 <div> content 2 .. content 2 .. content 2 .. content 2 ..
  <input class="previous" type="button" value="previous"/>
  <input class="next" type="button" value="next"/>   
 </div>
 <h3 class="header">Section 3</h3>
 <div> content 3 .. content 3 .. content 3 .. content 3 ..
  <input class="previous" type="button" value="previous"/>
 </div> 
</div>

6 个答案:

答案 0 :(得分:5)

我能够让它发挥作用。给它一个镜头,它适用于jQuery 1.6和jQuery UI 1.8:

HTML:

<div id="checkout">
    <h2><a href="#">Section 1</a></h2>
    <div>
        <form action="#">
            <h3>Content</h3>
            <input type="submit" class="next" value="Continue" />
        </form>
    </div>
    <h2><a href="#">Section 2</a></h2>
    <div>
        <form action="#">
            <h3>Content</h3>
            <input type="submit" class="prev" value="Back" />
        </form>
    </div>
</div>

jQuery的:

<script type="text/javascript">
    $(document).ready(function () {
        // create new accordion
        var checkout = $('#checkout').accordion({ event: false });

        // assign accordion navigation events to button clicks
        $('form', checkout).each(function (index) {
            $(this)
            .children(':submit')
            .filter('.next, .prev')
            .click(function () {
                checkout.accordion('option', 'active', index + ($(this).is('.next') ? 1 : -1));
                return false;
            });
        });
    });
</script>

答案 1 :(得分:4)

将此添加到您的jQuery文件中。它添加了一个函数$(“#accordion”)。accordion(“next”)和一个选项“loopOnNext”(默认为false),强制它在结束时返回顶部框。

$.extend($.ui.accordion.prototype, {
    next: function(){
        var index = this.option('active') || 0,
            next = index + 1,
        nodes = $(this.element).children('h3').length;
        if(next >= nodes && this.option('loopOnNext') === true) {
            next = 0;
        }

        return this.activate(next);
    }
});

答案 2 :(得分:2)

我遇到了类似的问题并使用了:

<button onclick="$('#accordion').accordion('activate', 0);">Prev</button>
<button onclick="$('#accordion').accordion('activate', 2);">Next</button>

在每个手风琴窗格上。这是在第二个窗格中,返回第一个(索引为0)或前进到第三个(索引为2)。

答案 3 :(得分:0)

您是否尝试过像示例一样的工作?

var wizard = $("#accordion").accordion({ 
    header: 'h3.header', 
    event: false
}); 

$("h3.header", wizard).each(function(index) { 
    $(this) 
    .next() 
    .children(":button") 
    .filter(".next, .previous") 
    .click(function() { 
        wizard.changeAccordion("activate", index + ($(this).is(".next") ? 1 : -1)) 
    }); 
});

答案 4 :(得分:0)

我一直在寻找同样问题的解决方案并提出这个问题(我正在使用jQuery 1.4.2和jQuery UI 1.8.1):

<div id="wizard">
    <h3><a href="#step1">Step 1 / 3</a></h3>
    <div id="step1">
        <button type="button">Next &raquo;</button>
    </div>
    <h3><a href="#step2">Step 2 / 3</a></h3>
    <div id="step2">
        <button type="button">Next &raquo;</button>
    </div>
    <h3><a href="#step3">Step 3 / 3</a></h3>
    <div id="step3">
        <button type="submit">Finish</button>
    </div>
</div>

这是剧本:

<script type="text/javascript">
    $(function() {

        $('#wizard').accordion();

        $('#wizard :button').each(function (index, elm) {
            $(elm).click(function() {
                $('#wizard').accordion('activate', index + 1);
            });
        });

    });
</script>

答案 5 :(得分:0)

试试这个:

var wizard = $("#register_form").accordion({
    header: '.title',
    event: 'none',
    collapsible: false
});
$(':button.previous').click(function() { wizard.accordion("activate", 0); });
$(':button.next').click(function() { wizard.accordion("activate", 1); });

:button是prev和next按钮,而wizard是你的jQuery手风琴。 省略所有其他代码。看看这是否有效。 请留下反馈,谢谢。