如需理解更多有关 accordion 部件的细节,请查看 API 文档 折叠面板部件(Accordion Widget)。

默认功能

null折叠门订制_jQueryUI实例折叠面板Accordion 推拉门

点击头部展开/折叠被分为各个逻辑部分的内容,就像标签页(tabs)一样。
您可以选择性地设置当鼠标悬停时是否切换各部分的打开/关闭状态。

基本的 HTML 标记是一系列的标题(H3 标签)和内容 div,因此内容不用通过 JavaScript 即可用。

<!doctype html&gt; <html> <head> <meta charset=\"大众utf-8\"大众> <title>jQuery UI 折叠面板(Accordion) - 默认功能</title> <link rel=\"大众stylesheet\"大众 href=\"大众//code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css\"大众> <script src=\公众//code.jquery.com/jquery-1.9.1.js\公众></script> <script src=\公众//code.jquery.com/ui/1.10.4/jquery-ui.js\公众></script> <link rel=\"大众stylesheet\"大众 href=\"大众http://jqueryui.com/resources/demos/style.css\"大众> <script> $(function() { $( \公众#accordion\公众 ).accordion(); }); </script> </head> <body> <div id=\"大众accordion\公众> <h3>部分 1</h3> <div> <p> Mauris mauris ante, blandit et, ultrices a, suscipit eget, quam. Integer ut neque. Vivamus nisi metus, molestie vel, gravida in, condimentum sit amet, nunc. Nam a nibh. Donec suscipit eros. Nam mi. Proin viverra leo ut odio. Curabitur malesuada. Vestibulum a velit eu ante scelerisque vulputate. </p> </div> <h3>部分 2</h3> <div> <p> Sed non urna. Donec et ante. Phasellus eu ligula. Vestibulum sit amet purus. Vivamus hendrerit, dolor at aliquet laoreet, mauris turpis porttitor velit, faucibus interdum tellus libero ac justo. Vivamus non quam. In suscipit faucibus urna. </p> </div> <h3>部分 3</h3> <div> <p> Nam enim risus, molestie et, porta ac, aliquam ac, risus. Quisque lobortis. Phasellus pellentesque purus in massa. Aenean in pede. Phasellus ac libero ac tellus pellentesque semper. Sed ac felis. Sed commodo, magna quis lacinia ornare, quam ante aliquam nisi, eu iaculis leo purus venenatis dui. </p> <ul> <li>List item one</li> <li>List item two</li> <li>List item three</li> </ul> </div> <h3>部分 4</h3> <div> <p> Cras dictum. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aenean lacinia mauris vel est. </p> <p> Suspendisse eu nisl. Nullam ut libero. Integer dignissim consequat lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. </p> </div> </div> </body> </html>

折叠内容

默认情形下,折叠面板总是保持一个部分是打开的。
为了让所有部分都是折叠的,可设置 collapsible 选项为 true。
点击当前打开的部分,来折叠它的内容面板。

<!doctype html> <html> <head> <meta charset=\"大众utf-8\"大众> <title>jQuery UI 折叠面板(Accordion) - 折叠内容</title> <link rel=\"大众stylesheet\公众 href=\"大众//code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css\公众> <script src=\"大众//code.jquery.com/jquery-1.9.1.js\"大众></script> <script src=\"大众//code.jquery.com/ui/1.10.4/jquery-ui.js\"大众></script> <link rel=\公众stylesheet\"大众 href=\"大众http://jqueryui.com/resources/demos/style.css\"大众> <script> $(function() { $( \"大众#accordion\"大众 ).accordion({ collapsible: true }); }); </script> </head> <body> <div id=\"大众accordion\"大众> <h3>部分 1</h3> <div> <p>Mauris mauris ante, blandit et, ultrices a, suscipit eget, quam. Integer ut neque. Vivamus nisi metus, molestie vel, gravida in, condimentum sit amet, nunc. Nam a nibh. Donec suscipit eros. Nam mi. Proin viverra leo ut odio. Curabitur malesuada. Vestibulum a velit eu ante scelerisque vulputate.</p> </div> <h3>部分 2</h3> <div> <p>Sed non urna. Donec et ante. Phasellus eu ligula. Vestibulum sit amet purus. Vivamus hendrerit, dolor at aliquet laoreet, mauris turpis porttitor velit, faucibus interdum tellus libero ac justo. Vivamus non quam. In suscipit faucibus urna. </p> </div> <h3>部分 3</h3> <div> <p>Nam enim risus, molestie et, porta ac, aliquam ac, risus. Quisque lobortis. Phasellus pellentesque purus in massa. Aenean in pede. Phasellus ac libero ac tellus pellentesque semper. Sed ac felis. Sed commodo, magna quis lacinia ornare, quam ante aliquam nisi, eu iaculis leo purus venenatis dui. </p> <ul> <li>List item one</li> <li>List item two</li> <li>List item three</li> </ul> </div> <h3>部分 4</h3> <div> <p>Cras dictum. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aenean lacinia mauris vel est. </p><p>Suspendisse eu nisl. Nullam ut libero. Integer dignissim consequat lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. </p> </div> </div> </body> </html>

查看演示

自定义图标

通过 icons 选项自定义标题图标,icons 选项接管标题默认的和激活的(打开的)状态的 class。
利用 UI CSS 框架中的任意 class,或者利用背景图像创建自定义的 class。

<!doctype html> <html> <head> <meta charset=\"大众utf-8\"大众> <title>jQuery UI 折叠面板(Accordion) - 自定义图标</title> <link rel=\"大众stylesheet\"大众 href=\"大众//code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css\公众> <script src=\"大众//code.jquery.com/jquery-1.9.1.js\"大众></script> <script src=\公众//code.jquery.com/ui/1.10.4/jquery-ui.js\"大众></script> <link rel=\公众stylesheet\"大众 href=\"大众http://jqueryui.com/resources/demos/style.css\"大众> <script> $(function() { var icons = { header: \"大众ui-icon-circle-arrow-e\公众, activeHeader: \"大众ui-icon-circle-arrow-s\"大众 }; $( \"大众#accordion\"大众 ).accordion({ icons: icons }); $( \"大众#toggle\"大众 ).button().click(function() { if ( $( \公众#accordion\公众 ).accordion( \公众option\"大众, \公众icons\公众 ) ) { $( \公众#accordion\公众 ).accordion( \公众option\公众, \"大众icons\"大众, null ); } else { $( \"大众#accordion\"大众 ).accordion( \"大众option\公众, \"大众icons\"大众, icons ); } }); }); </script> </head> <body> <div id=\公众accordion\"大众> <h3>部分 1</h3> <div> <p>Mauris mauris ante, blandit et, ultrices a, suscipit eget, quam. Integer ut neque. Vivamus nisi metus, molestie vel, gravida in, condimentum sit amet, nunc. Nam a nibh. Donec suscipit eros. Nam mi. Proin viverra leo ut odio. Curabitur malesuada. Vestibulum a velit eu ante scelerisque vulputate.</p> </div> <h3>部分 2</h3> <div> <p>Sed non urna. Donec et ante. Phasellus eu ligula. Vestibulum sit amet purus. Vivamus hendrerit, dolor at aliquet laoreet, mauris turpis porttitor velit, faucibus interdum tellus libero ac justo. Vivamus non quam. In suscipit faucibus urna. </p> </div> <h3>部分 3</h3> <div> <p>Nam enim risus, molestie et, porta ac, aliquam ac, risus. Quisque lobortis. Phasellus pellentesque purus in massa. Aenean in pede. Phasellus ac libero ac tellus pellentesque semper. Sed ac felis. Sed commodo, magna quis lacinia ornare, quam ante aliquam nisi, eu iaculis leo purus venenatis dui. </p> <ul> <li>List item one</li> <li>List item two</li> <li>List item three</li> </ul> </div> <h3>部分 4</h3> <div> <p>Cras dictum. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aenean lacinia mauris vel est. </p><p>Suspendisse eu nisl. Nullam ut libero. Integer dignissim consequat lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. </p> </div> </div> <button id=\"大众toggle\"大众>切换图标</button> </body> </html>

查看演示

添补空间

由于折叠面板是由块级元素组成的,默认情形下它的宽度会添补可用的水平空间。
为了添补由容器分配的垂直空间,设置 heightStyle 选项为 \公众fill\"大众,脚本会自动设置折叠面板的尺寸为父容器的高度。

<!doctype html> <html> <head> <meta charset=\"大众utf-8\"大众> <title>jQuery UI 折叠面板(Accordion) - 添补空间</title> <link rel=\公众stylesheet\"大众 href=\"大众//code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css\"大众> <script src=\"大众//code.jquery.com/jquery-1.9.1.js\"大众></script> <script src=\"大众//code.jquery.com/ui/1.10.4/jquery-ui.js\"大众></script> <link rel=\"大众stylesheet\"大众 href=\"大众http://jqueryui.com/resources/demos/style.css\公众> <style> #accordion-resizer { padding: 10px; width: 350px; height: 220px; } </style> <script> $(function() { $( \"大众#accordion\公众 ).accordion({ heightStyle: \"大众fill\"大众 }); }); $(function() { $( \"大众#accordion-resizer\"大众 ).resizable({ minHeight: 140, minWidth: 200, resize: function() { $( \公众#accordion\"大众 ).accordion( \"大众refresh\"大众 ); } }); }); </script> </head> <body> <h3>重新调度外部容器:</h3> <div id=\"大众accordion-resizer\公众> <div id=\公众accordion\公众> <h3>部分 1</h3> <div> <p>Mauris mauris ante, blandit et, ultrices a, suscipit eget, quam. Integer ut neque. Vivamus nisi metus, molestie vel, gravida in, condimentum sit amet, nunc. Nam a nibh. Donec suscipit eros. Nam mi. Proin viverra leo ut odio. Curabitur malesuada. Vestibulum a velit eu ante scelerisque vulputate.</p> </div> <h3>部分 2</h3> <div> <p>Sed non urna. Donec et ante. Phasellus eu ligula. Vestibulum sit amet purus. Vivamus hendrerit, dolor at aliquet laoreet, mauris turpis porttitor velit, faucibus interdum tellus libero ac justo. Vivamus non quam. In suscipit faucibus urna. </p> </div> <h3>部分 3</h3> <div> <p>Nam enim risus, molestie et, porta ac, aliquam ac, risus. Quisque lobortis. Phasellus pellentesque purus in massa. Aenean in pede. Phasellus ac libero ac tellus pellentesque semper. Sed ac felis. Sed commodo, magna quis lacinia ornare, quam ante aliquam nisi, eu iaculis leo purus venenatis dui. </p> <ul> <li>List item one</li> <li>List item two</li> <li>List item three</li> </ul> </div> <h3>部分 4</h3> <div> <p>Cras dictum. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aenean lacinia mauris vel est. </p><p>Suspendisse eu nisl. Nullam ut libero. Integer dignissim consequat lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. </p> </div> </div> </div> </body> </html>

非自动高度

设置 heightStyle: \"大众content\公众,让折叠面板保持它们初始的高度。

<!doctype html> <html> <head> <meta charset=\公众utf-8\"大众> <title>jQuery UI 折叠面板(Accordion) - 非自动高度</title> <link rel=\"大众stylesheet\"大众 href=\"大众//code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css\"大众> <script src=\"大众//code.jquery.com/jquery-1.9.1.js\公众></script> <script src=\"大众//code.jquery.com/ui/1.10.4/jquery-ui.js\"大众></script> <link rel=\"大众stylesheet\"大众 href=\"大众http://jqueryui.com/resources/demos/style.css\公众> <script> $(function() { $( \公众#accordion\公众 ).accordion({ heightStyle: \"大众content\"大众 }); }); </script> </head> <body> <div id=\公众accordion\公众> <h3>部分 1</h3> <div> <p>Mauris mauris ante, blandit et, ultrices a, susceros. Nam mi. Proin viverra leo ut odio. Curabitur malesuada. Vestibulum a velit eu ante scelerisque vulputate.</p> </div> <h3>部分 2</h3> <div> <p>Sed non urna. Donec et ante. Phasellus eu ligula. Vestibulum sit amet purus. Vivamus hendrerit, dolor at aliquet laoreet, mauris turpis porttitor velit, faucibus interdum tellus libero ac justo. Vivamus non quam. In suscipit faucibus urna. </p> </div> <h3>部分 3</h3> <div> <p>Nam enim risus, molestie et, porta ac, aliquam ac, risus. Quisque lobortis. Phasellus pellentesque purus in massa. Aenean in pede. Phasellus ac libero ac tellus pellentesque semper. Sed ac felis. Sed commodo, magna quis lacinia ornare, quam ante aliquam nisi, eu iaculis leo purus venenatis dui. </p> <ul> <li>List item</li> <li>List item</li> <li>List item</li> <li>List item</li> <li>List item</li> <li>List item</li> <li>List item</li> </ul> </div> </div> </body> </html>

查看演示

当悬停时打开

点击头部展开/折叠被分为各个逻辑部分的内容,就像标签页(tabs)一样。
您可以选择性地设置当鼠标悬停时是否切换各部分的打开/关闭状态。

基本的 HTML 标记是一系列的标题(H3 标签)和内容 div,因此内容不用通过 JavaScript 即可用。

<!doctype html> <html> <head> <meta charset=\公众utf-8\公众> <title>jQuery UI 折叠面板(Accordion) - 当悬停时打开</title> <link rel=\公众stylesheet\公众 href=\"大众//code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css\公众> <script src=\公众//code.jquery.com/jquery-1.9.1.js\公众></script> <script src=\"大众//code.jquery.com/ui/1.10.4/jquery-ui.js\"大众></script> <link rel=\公众stylesheet\公众 href=\公众http://jqueryui.com/resources/demos/style.css\公众> <script> $(function() { $( \"大众#accordion\"大众 ).accordion({ event: \"大众click hoverintent\"大众 }); }); / hoverIntent | Copyright 2011 Brian Cherne http://cherne.net/brian/resources/jquery.hoverIntent.html modified by the jQuery UI team / $.event.special.hoverintent = { setup: function() { $( this ).bind( \"大众mouseover\"大众, jQuery.event.special.hoverintent.handler ); }, teardown: function() { $( this ).unbind( \公众mouseover\"大众, jQuery.event.special.hoverintent.handler ); }, handler: function( event ) { var currentX, currentY, timeout, args = arguments, target = $( event.target ), previousX = event.pageX, previousY = event.pageY; function track( event ) { currentX = event.pageX; currentY = event.pageY; }; function clear() { target .unbind( \公众mousemove\"大众, track ) .unbind( \"大众mouseout\"大众, clear ); clearTimeout( timeout ); } function handler() { var prop, orig = event; if ( ( Math.abs( previousX - currentX ) + Math.abs( previousY - currentY ) ) < 7 ) { clear(); event = $.Event( \"大众hoverintent\公众 ); for ( prop in orig ) { if ( !( prop in event ) ) { event[ prop ] = orig[ prop ]; } } // 防止访问原始事宜,由于新事宜会被异步触发,往事宜不再可用 (#6028) delete event.originalEvent; target.trigger( event ); } else { previousX = currentX; previousY = currentY; timeout = setTimeout( handler, 100 ); } } timeout = setTimeout( handler, 100 ); target.bind({ mousemove: track, mouseout: clear }); } }; </script> </head> <body> <div id=\"大众accordion\公众> <h3>部分 1</h3> <div> <p> Mauris mauris ante, blandit et, ultrices a, suscipit eget, quam. Integer ut neque. Vivamus nisi metus, molestie vel, gravida in, condimentum sit amet, nunc. Nam a nibh. Donec suscipit eros. Nam mi. Proin viverra leo ut odio. Curabitur malesuada. Vestibulum a velit eu ante scelerisque vulputate. </p> </div> <h3>部分 2</h3> <div> <p> Sed non urna. Donec et ante. Phasellus eu ligula. Vestibulum sit amet purus. Vivamus hendrerit, dolor at aliquet laoreet, mauris turpis porttitor velit, faucibus interdum tellus libero ac justo. Vivamus non quam. In suscipit faucibus urna. </p> </div> <h3>部分 3</h3> <div> <p> Nam enim risus, molestie et, porta ac, aliquam ac, risus. Quisque lobortis. Phasellus pellentesque purus in massa. Aenean in pede. Phasellus ac libero ac tellus pellentesque semper. Sed ac felis. Sed commodo, magna quis lacinia ornare, quam ante aliquam nisi, eu iaculis leo purus venenatis dui. </p> <ul> <li>List item one</li> <li>List item two</li> <li>List item three</li> </ul> </div> <h3>部分 4</h3> <div> <p> Cras dictum. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aenean lacinia mauris vel est. </p> <p> Suspendisse eu nisl. Nullam ut libero. Integer dignissim consequat lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. </p> </div> </div> </body> </html>

查看演示

排序(Sortable)

拖拽标题来给面板重新排序。

<!doctype html> <html> <head> <meta charset=\"大众utf-8\公众> <title>jQuery UI 折叠面板(Accordion) - 排序(Sortable)</title> <link rel=\"大众stylesheet\公众 href=\公众//code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css\公众> <script src=\"大众//code.jquery.com/jquery-1.9.1.js\"大众></script> <script src=\"大众//code.jquery.com/ui/1.10.4/jquery-ui.js\公众></script> <link rel=\公众stylesheet\"大众 href=\"大众http://jqueryui.com/resources/demos/style.css\公众> <style> / 当排序时,IE 存在布局问题(查看 #5413) / .group { zoom: 1 } </style> <script> $(function() { $( \"大众#accordion\"大众 ) .accordion({ header: \公众> div > h3\"大众 }) .sortable({ axis: \"大众y\公众, handle: \"大众h3\公众, stop: function( event, ui ) { // 当排序时,IE 不能注册 blur,以是触发 focusout 处理程序来移除 .ui-state-focus ui.item.children( \"大众h3\"大众 ).triggerHandler( \公众focusout\公众 ); } }); }); </script> </head> <body> <div id=\"大众accordion\"大众> <div> <h3>部分 1</h3> <div> <p>Mauris mauris ante, blandit et, ultrices a, suscipit eget, quam. Integer ut neque. Vivamus nisi metus, molestie vel, gravida in, condimentum sit amet, nunc. Nam a nibh. Donec suscipit eros. Nam mi. Proin viverra leo ut odio. Curabitur malesuada. Vestibulum a velit eu ante scelerisque vulputate.</p> </div> </div> <div> <h3>部分 2</h3> <div> <p>Sed non urna. Donec et ante. Phasellus eu ligula. Vestibulum sit amet purus. Vivamus hendrerit, dolor at aliquet laoreet, mauris turpis porttitor velit, faucibus interdum tellus libero ac justo. Vivamus non quam. In suscipit faucibus urna. </p> </div> </div> <div> <h3>部分 3</h3> <div> <p>Nam enim risus, molestie et, porta ac, aliquam ac, risus. Quisque lobortis. Phasellus pellentesque purus in massa. Aenean in pede. Phasellus ac libero ac tellus pellentesque semper. Sed ac felis. Sed commodo, magna quis lacinia ornare, quam ante aliquam nisi, eu iaculis leo purus venenatis dui. </p> <ul> <li>List item one</li> <li>List item two</li> <li>List item three</li> </ul> </div> </div> <div> <h3>部分 4</h3> <div> <p>Cras dictum. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aenean lacinia mauris vel est. </p><p>Suspendisse eu nisl. Nullam ut libero. Integer dignissim consequat lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. </p> </div> </div> </div> </body> </html>