用于所有子选项卡的单个滚动条的Accordion

时间:2015-06-02 04:13:45

标签: javascript jquery html css

我需要创建一个基于jquery的UI,我将在其中使用以下html

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <script type="text/javascript" src="//code.jquery.com/jquery-1.11.2.js"></script>
    <script type="text/javascript" src="//code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
    <link rel="stylesheet" type="text/css" href="http://code.jquery.com/ui/1.9.2/themes/base/jquery-ui.css">
    <link rel="stylesheet" href="//code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.css">

    <style type="text/css">
        div .content
        {
            border: 2px solid black;
            background-color: White;
        }

    div.content::-webkit-scrollbar{
  display:none;
   }
   #container::-webkit-scrollbar{
  display:none;
   }
    </style>
</head>
<body>
    <button type="button" id="btnPopup">
        Show Popup</button>
    <div id="container" style="display: none; border: 2px solid green; background-color: Blue;">
        <h3>
            DISTRIBUTION</h3>
        <div class="content">
            <p>
                Using jQuery UI Resizable I'm trying to prevent resizing based on various rules.
                The built-in containment feature doesn't seem to work properly with absolutely positioned
                elements, and I would need something more flexible than that anyway. Having something
                like this: Using jQuery UI Resizable I'm trying to prevent resizing based on various
                rules. The built-in containment feature doesn't seem to work properly with absolutely
                positioned elements, and I would need something more flexible than that anyway.
                Having something like this: Using jQuery UI Resizable I'm trying to prevent resizing
                based on various rules. The built-in containment feature doesn't seem to work properly
                with absolutely positioned elements, and I would need something more flexible than
                that anyway. Having something like this: Using jQuery UI Resizable I'm trying to
                prevent resizing based on various rules. The built-in containment feature doesn't
                seem to work properly with absolutely positioned elements, and I would need something
                more flexible than that anyway. Having something like this: Using jQuery UI Resizable
                I'm trying to prevent resizing based on various rules. The built-in containment
                feature doesn't seem to work properly with absolutely positioned elements, and I
                would need something more flexible than that anyway. Having something like this:
                Using jQuery UI Resizable I'm trying to prevent resizing based on various rules.
                The built-in containment feature doesn't seem to work properly with absolutely positioned
                elements, and I would need something more flexible than that anyway. Having something
                like this: Using jQuery UI Resizable I'm trying to prevent resizing based on various
                rules. The built-in containment feature doesn't seem to work properly with absolutely
                positioned elements, and I would need something more flexible than that anyway.
                Having something like this: Using jQuery UI Resizable I'm trying to prevent resizing
                based on various rules. The built-in containment feature doesn't seem to work properly
                with absolutely positioned elements, and I would need something more flexible than
                that anyway. Having something like this:
            </p>
        </div>
        <h3>
            EXCEPTION</h3>
        <div class="content">
            <p>
                Using jQuery UI Resizable I'm trying to prevent resizing based on various rules.
                The built-in containment feature doesn't seem to work properly with absolutely positioned
                elements, and I would need something more flexible than that anyway. Having something
                like this:</p>
            <p>
                Using jQuery UI Resizable I'm trying to prevent resizing based on various rules.
                The built-in containment feature doesn't seem to work properly with absolutely positioned
                elements, and I would need something more flexible than that anyway. Having something
                like this:</p>
        </div>
        <h3>
            ERROR</h3>
        <div class="content">
            <p>
                Using jQuery UI Resizable I'm trying to prevent resizing based on various rules.
                The built-in containment feature doesn't seem to work properly with absolutely positioned
                elements, and I would need something more flexible than that anyway. Having something
                like this:</p>
        </div>
        <h3>
            MY NOTES</h3>
        <div class="content">
            <p>
                Using jQuery UI Resizable I'm trying to prevent resizing based on various rules.
                The built-in containment feature doesn't seem to work properly with absolutely positioned
                elements, and I would need something more flexible than that anyway. Having something
                like this:</p>
        </div>

    </div>
</body>
<script type="text/javascript">
    $("#container").accordion({
        collapsible: true,
        heightStyle: "content",
        beforeActivate: function (event, ui) {
            // The accordion believes a panel is being opened
            if (ui.newHeader[0]) {
                var currHeader = ui.newHeader;
                var currContent = currHeader.next('.ui-accordion-content');
                // The accordion believes a panel is being closed
            } else {
                var currHeader = ui.oldHeader;
                var currContent = currHeader.next('.ui-accordion-content');
            }
            // Since we've changed the default behavior, this detects the actual status
            var isPanelSelected = currHeader.attr('aria-selected') == 'true';

            // Toggle the panel's header
            currHeader.toggleClass('ui-corner-all', isPanelSelected).toggleClass('accordion-header-active ui-state-active ui-corner-top', !
isPanelSelected).attr('aria-selected', ((!isPanelSelected).toString()));

            // Toggle the panel's icon
            currHeader.children('.ui-icon').toggleClass('ui-icon-triangle-1-e', isPanelSelected).toggleClass('ui-icon-triangle-1-s', !isPanelSelected);

            // Toggle the panel's content
            currContent.toggleClass('accordion-content-active', !isPanelSelected)
            if (isPanelSelected) { currContent.slideUp(); } else { currContent.slideDown(); }


            return false; // Cancel the default action
        }
    });

    $(document).ready(function () {
        $(".content").css('max-height', $("#container").height() - 150);

    });

    $(document).delegate("#btnPopup", "click", function () {

        $("#container").dialog({
            title: "jQuery Modal Dialog Popup",
            resizable: false,
            width: 800,
            maxHeight: 800
            //minHeight: 250,
            //minWidth: 500,
            //resize: function (event, ui) {
            //    $(".content").css('max-height', ($("#container").height() - 250));
            //}
        });
        return false;
    });


//    $(document).bind('wheel mousewheel', function (e) {
//      
//        if (e.originalEvent.wheelDelta > 0) {
//           
//        }
//        else {
//            k = h = 0;
//            $("div.content").each(function () {
//                if ($(this).is(":focus")) {
//                    h = k;
//                }
//                k++;
//            });
//            if ($('.content')[h] != undefined && h != (k - 1)) {
//                if ($('#container').children('div.content').eq(h).scrollTop() + $('#container').children('div.content').eq(h).innerHeight() >=
//$('.content')[h].scrollHeight) {
//                   
//                    if (!($('div.content').eq(h + 1).prev('h3').hasClass('ui-state-active'))) {
//                        var totalDiv = $('div.content').length;
//                        var h3Height = $('h3').height();

//                      

//                        $("#container").accordion({ active: h + 1 });

//                        var f = $('h3.ui-state-active').length;
//                        //if (f != 1) {
//                        $('div.content').each(function () {
//                            if ($(this).css('display') == 'block')
//                                $(this).css('max-height', ((parseInt($('#container').css('max-height')) / f) - (h3Height * (totalDiv + 1))));
//                        });
//                        $('div.content').eq(h + 1).focus();
//                      
//                    }
//                }
//            }
//           
//        }
//        });


    (function ($) {
        $.fn.hasScrollBar = function () {
            return this.get(0).scrollHeight > this.height();
        }
    })(jQuery);

//    $(function () {
//        $(".content").bind('scroll', function () {           
//            if ($(this).scrollTop() + $(this).innerHeight() >= $(this)[0].scrollHeight) {
//                //alert('end reached');
//                $(this).next('h3').click();
//                $(this).next('div.content').focus();
//            }
//        });
//    })




    $('div.content').bind('mousewheel', function (e) {
        if (e.originalEvent.wheelDelta / 120 > 0) {
            // $(this).text('scrolling up !');
        }
        else {
            //            if ($('div.content').hasScrollBar()) {

            //                if ($('div.content').scrollTop() == ($('div.content p').height() - $('div.content').height())) {
            //                    alert('end!');
            //                }
            //            }    


            if ($(this).scrollTop() + $(this).innerHeight() >= $(this)[0].scrollHeight) {

                //alert('end reached');



                $(this).next('h3').click();
                $(this).prev('h3').click()
               // $(this).next('div.content').attr('display', 'block');
                $(this).blur();
                $(this).next('div.content').focus();


            }


        }
    });




//    $('.content').bind('mousewheel', function (e) {
//        if ($('div.content').hasScrollBar()) {
//            $(this).delegate(".content", "scroll", function () {
//                if ($(this).scrollTop() + $(this).innerHeight() >= $(this)[0].scrollHeight) {
//                    //alert('end reached');
//                    $(this).next('h3').click();
//                    $(this).next('div.content').focus();
//                }
//            });
//        }
//        else {
//            $(this).next('h3').click();
//            $(this).next('div.content').focus();
//        }
//    });

    $(document).delegate("h3", "click", function () {
        var totalDiv = $('div.content').length;
        var h3Height = $('h3').height();
        var f = $('h3.ui-state-active').length;
        //        if (!($(this).hasClass('ui-state-active'))) {

        if (f != 1) {
            $('div.content').each(function () {
                if ($(this).css('display') == 'block')
                    $(this).css('max-height', ((parseInt($('#container').css('max-height')) / f) - (h3Height * (totalDiv + 1))));
            });
        }      
    });
</script>
</html>

上面的html显示了手风琴。 我需要做的是为整个手风琴内容提供一个滚动条,其工作方式如下: 当第一个div滚动到达结束时,第二个div将打开,在第二个div滚动完成时(如果没有滚动,那么同样的事情也将发生),第3个div将打开。 现在,这需要向下滚动,当用户向上滚动时也应如此。

请让我知道必须应用的解决方案,以实现上述类型的功能。

1 个答案:

答案 0 :(得分:0)

    $("#container").accordion({
        collapsible: true,
        heightStyle: "content",
        beforeActivate: function (event, ui) {
            // The accordion believes a panel is being opened
          var currHeader ;
          var currContent;
            if (ui.newHeader[0]) {
                 currHeader = ui.newHeader;
                 currContent = currHeader.next('.ui-accordion-content');
                // The accordion believes a panel is being closed
            } else {
                currHeader = ui.oldHeader;
               currContent = currHeader.next('.ui-accordion-content');
            }
            // Since we've changed the default behavior, this detects the actual status
            var isPanelSelected = currHeader.attr('aria-selected') == 'true';

            // Toggle the panel's header
            currHeader.toggleClass('ui-corner-all', isPanelSelected).toggleClass('accordion-header-active ui-state-active ui-corner-top', !
isPanelSelected).attr('aria-selected', ((!isPanelSelected).toString()));

            // Toggle the panel's icon
            currHeader.children('.ui-icon').toggleClass('ui-icon-triangle-1-e', isPanelSelected).toggleClass('ui-icon-triangle-1-s', !isPanelSelected);

            // Toggle the panel's content
            currContent.toggleClass('accordion-content-active', !isPanelSelected);
            if (isPanelSelected) { currContent.slideUp(); } else { currContent.slideDown(); }


            return false; // Cancel the default action
        }
    });

    $(document).ready(function () {
        $(".content").css('max-height', $("#container").height() - 150);

    });

    $(document).delegate("#btnPopup", "click", function () {

        $("#container").dialog({
            title: "jQuery Modal Dialog Popup",
            resizable: false,
            width: 800,
            maxHeight: 800
            //minHeight: 250,
            //minWidth: 500,
            //resize: function (event, ui) {
            //    $(".content").css('max-height', ($("#container").height() - 250));
            //}
        });
        return false;
    });


//    $(document).bind('wheel mousewheel', function (e) {
//      
//        if (e.originalEvent.wheelDelta > 0) {
//           
//        }
//        else {
//            k = h = 0;
//            $("div.content").each(function () {
//                if ($(this).is(":focus")) {
//                    h = k;
//                }
//                k++;
//            });
//            if ($('.content')[h] != undefined && h != (k - 1)) {
//                if ($('#container').children('div.content').eq(h).scrollTop() + $('#container').children('div.content').eq(h).innerHeight() >=
//$('.content')[h].scrollHeight) {
//                   
//                    if (!($('div.content').eq(h + 1).prev('h3').hasClass('ui-state-active'))) {
//                        var totalDiv = $('div.content').length;
//                        var h3Height = $('h3').height();

//                      

//                        $("#container").accordion({ active: h + 1 });

//                        var f = $('h3.ui-state-active').length;
//                        //if (f != 1) {
//                        $('div.content').each(function () {
//                            if ($(this).css('display') == 'block')
//                                $(this).css('max-height', ((parseInt($('#container').css('max-height')) / f) - (h3Height * (totalDiv + 1))));
//                        });
//                        $('div.content').eq(h + 1).focus();
//                      
//                    }
//                }
//            }
//           
//        }
//        });


    (function ($) {
        $.fn.hasScrollBar = function () {
            return this.get(0).scrollHeight > this.height();
        };
    })(jQuery);

//    $(function () {
//        $(".content").bind('scroll', function () {           
//            if ($(this).scrollTop() + $(this).innerHeight() >= $(this)[0].scrollHeight) {
//                //alert('end reached');
//                $(this).next('h3').click();
//                $(this).next('div.content').focus();
//            }
//        });
//    })




    $('div.content').bind('mousewheel', function (e) {

        if (e.originalEvent.wheelDelta == 120) {
            // $(this).text('scrolling up !');
         //alert("up scrolling");
          try{

            var x=$(this).prev('h3');
            var y=x.prev('div.content');
            $('.content').attr('display', 'none');
             $(this).prev('div.content').focus();
 if ( $(this).innerHeight() >= $(this)[0].scrollHeight) {
            y.prev('h3').click();
            x.click();
 }
            x.prev('div.content').attr('display', 'block');


        }catch(err){alert(err.message);}
        }
        else {

            if ($(this).scrollTop() + $(this).innerHeight() >= $(this)[0].scrollHeight) {

                //alert('end reached');



                $(this).next('h3').click();
                $(this).prev('h3').click();
               // $(this).next('div.content').attr('display', 'block');
                $(this).blur();
                $(this).next('div.content').focus();


            }


        }
    });




//    $('.content').bind('mousewheel', function (e) {
//        if ($('div.content').hasScrollBar()) {
//            $(this).delegate(".content", "scroll", function () {
//                if ($(this).scrollTop() + $(this).innerHeight() >= $(this)[0].scrollHeight) {
//                    //alert('end reached');
//                    $(this).next('h3').click();
//                    $(this).next('div.content').focus();
//                }
//            });
//        }
//        else {
//            $(this).next('h3').click();
//            $(this).next('div.content').focus();
//        }
//    });

    $(document).delegate("h3", "click", function () {
        var totalDiv = $('div.content').length;
        var h3Height = $('h3').height();
        var f = $('h3.ui-state-active').length;
        //        if (!($(this).hasClass('ui-state-active'))) {

        if (f != 1) {
            $('div.content').each(function () {
                if ($(this).css('display') == 'block')
                    $(this).css('max-height', ((parseInt($('#container').css('max-height')) / f) - (h3Height * (totalDiv + 1))));
            });
        }      
    });

这是更新的javascript,当你向上滚动它也会起作用,它会关闭当前窗格并打开上一个窗格。这是有效的JSBIN演示http://jsbin.com/viwojelico/2/edit?html,js