小兔网

所属类别

小部件(Widgets)

用法

描述:把一对标题和内容面板转换成折叠面板。

版本新增:1.0

折叠面板容器的标记需要一对标题和内容面板。

<div id="accordion">  <h3>First header</h3>  <div>First content panel</div>  <h3>Second header</h3>  <div>Second content panel</div></div>

折叠面板支持任意标记,但是每个内容面板必须是与其相关的头部面板的下一个同级。请查看 header 选项了解如何使用自定义的标记结构。

面板可以通过设置 active 选项以编程的方式激活。

键盘交互

当焦点在标题(header)上时,下面的键盘命令可用:

  • UP/LEFT - 移动焦点到上一个标题(header)。如果在第一个标题(header)上,则移动焦点到最后一个标题(header)上。
  • DOWN/RIGHT - 移动焦点到下一个标题(header)。如果在最后一个标题(header)上,则移动焦点到第一个标题(header)上。
  • HOME - 移动焦点到第一个标题(header)上。
  • END - 移动焦点到最后一个标题(header)上。
  • SPACE/ENTER - 激活与获得焦点的标题(header)相关的面板(panel)。

当焦点在面板(panel)中时,下面的键盘命令可用:

  • CTRL+UP:移动焦点到相关的标题(header)。

主题化

折叠面板部件(Accordion Widget)使用 jQuery UI CSS 框架 来定义它的外观和感观的样式。如果需要使用折叠面板指定的样式,则可以使用下面的 CSS class 名称:

  • ui-accordion:折叠面板的外层容器。
    • ui-accordion-header:折叠面板的标题。如果标题包含 icons,则标题会另外有个 ui-accordion-icons class。
    • ui-accordion-content:折叠面板的内容面板。

依赖

附加说明

  • 该部件要求一些功能性的 CSS,否则将无法工作。如果您创建了一个自定义的主题,请使用小部件指定的 CSS 文件作为起点。

快速导航

选项方法 事件

选项类型 描述默认值
active Boolean 或 Integer当前打开哪一个面板。

支持多个类型:

  • Boolean:设置 activefalse 将折叠所有的面板。这要求 collapsible 选项必须为 true
  • Integer:激活打开的面板索引,以零为基础。负值则表示从最后一个面板后退选择面板。

代码实例:

初始化带有指定 active 选项的 accordion:

$( ".selector" ).accordion({ active: 2 });    

在初始化后,获取或设置 active 选项:

// gettervar active = $( ".selector" ).accordion( "option", "active" ); // setter$( ".selector" ).accordion( "option", "active", 2 );    
0
animate Boolean 或 Number 或 String 或 Object是否使用动画改变面板,且如何使用动画改变面板。

支持多个类型:

  • Booleanfalse 值将禁用动画。
  • Number:easing 默认的持续时间,以毫秒计。
  • String:默认的持续时间要使用的 easing 名称。
  • Objecteasingduration 属性的动画设置。
    • 上面任意的选项都可以包含 down 属性。
    • 当被激活的面板有一个比当前激活面板较低的指数时,发生 "Down" 动画。

代码实例:

初始化带有指定 animate 选项的 accordion:

$( ".selector" ).accordion({ animate: "bounceslide" });    

在初始化后,获取或设置 animate 选项:

// gettervar animate = $( ".selector" ).accordion( "option", "animate" ); // setter$( ".selector" ).accordion( "option", "animate", "bounceslide" );    
{}
collapsible Boolean所有部分是否都可以马上关闭。允许折叠激活的部分。

代码实例:

初始化带有指定 collapsible 选项的 accordion:

$( ".selector" ).accordion({ collapsible: true });    

在初始化后,获取或设置 collapsible 选项:

// gettervar collapsible = $( ".selector" ).accordion( "option", "collapsible" ); // setter$( ".selector" ).accordion( "option", "collapsible", true );    
false
disabled Boolean如果设置为 true,则禁用该 accordion。

代码实例:

初始化带有指定 disabled 选项的 accordion:

$( ".selector" ).accordion({ disabled: true });    

在初始化后,获取或设置 disabled 选项:

// gettervar disabled = $( ".selector" ).accordion( "option", "disabled" ); // setter$( ".selector" ).accordion( "option", "disabled", true );    
false
event Stringaccordion 头部会作出反应的事件,用以激活相关的面板。可以指定多个事件,用空格间隔。

代码实例:

初始化带有指定 event 选项的 accordion:

$( ".selector" ).accordion({ event: "mouseover" });    

在初始化后,获取或设置 event 选项:

// gettervar event = $( ".selector" ).accordion( "option", "event" ); // setter$( ".selector" ).accordion( "option", "event", "mouseover" );    
"click"
header Selector标题元素的选择器,通过主要 accordion 元素上的 .find() 进行应用。内容面板必须是紧跟在与其相关的标题后的同级元素。

代码实例:

初始化带有指定 header 选项的 accordion:

$( ".selector" ).accordion({ header: "h3" });    

在初始化后,获取或设置 header 选项:

// gettervar header = $( ".selector" ).accordion( "option", "header" ); // setter$( ".selector" ).accordion( "option", "header", "h3" );    
"> li > :first-child,> :not(li):even"
heightStyle String控制 accordion 和每个面板的高度。可能的值:
  • "auto":所有的面板将会被设置为最高的面板的高度。
  • "fill":基于 accordion 的父元素的高度,扩展到可用的高度。
  • "content":每个面板的高度取决于它的内容。

代码实例:

初始化带有指定 heightStyle 选项的 accordion:

$( ".selector" ).accordion({ heightStyle: "fill" });    

在初始化后,获取或设置 heightStyle 选项:

// gettervar heightStyle = $( ".selector" ).accordion( "option", "heightStyle" ); // setter$( ".selector" ).accordion( "option", "heightStyle", "fill" );    
"auto"
icons Object标题要使用的图标,与 jQuery UI CSS 框架提供的图标(Icons) 匹配。设置为 false 则不显示图标。
  • header (string,默认值:"ui-icon-triangle-1-e")
  • activeHeader (string,默认值:"ui-icon-triangle-1-s")

代码实例:

初始化带有指定 icons 选项的 accordion:

$( ".selector" ).accordion({ icons: { "header": "ui-icon-plus", "activeHeader": "ui-icon-minus" } });    

在初始化后,获取或设置 icons 选项:

// gettervar icons = $( ".selector" ).accordion( "option", "icons" ); // setter$( ".selector" ).accordion( "option", "icons", { "header": "ui-icon-plus", "activeHeader": "ui-icon-minus" } );    
{ "header": "ui-icon-triangle-1-e", "activeHeader": "ui-icon-triangle-1-s" }

方法返回 描述
destroy() jQuery (plugin only)完全移除 accordion 功能。这会把元素返回到它的预初始化状态。
  • 该方法不接受任何参数。

代码实例:

调用 destroy 方法:

$( ".selector" ).accordion( "destroy" );    
disable() jQuery (plugin only)禁用 accordion。
  • 该方法不接受任何参数。

代码实例:

调用 disable 方法:

$( ".selector" ).accordion( "disable" );    
enable() jQuery (plugin only)启用 accordion。
  • 该方法不接受任何参数。

代码实例:

调用 enable 方法:

$( ".selector" ).accordion( "enable" );    
option( optionName ) Object获取当前与指定的 optionName 关联的值。
  • optionName
    类型:String
    描述:要获取的选项的名称。

代码实例:

调用该方法:

var isDisabled = $( ".selector" ).accordion( "option", "disabled" );    
option() PlainObject获取一个包含键/值对的对象,键/值对表示当前 accordion 选项哈希。
  • 该方法不接受任何参数。

代码实例:

调用该方法:

var options = $( ".selector" ).accordion( "option" );    
option( optionName, value ) jQuery (plugin only)设置与指定的 optionName 关联的 accordion 选项的值。
  • optionName
    类型:String
    描述:要设置的选项的名称。
  • value
    类型:Object
    描述:要为选项设置的值。

代码实例:

调用该方法:

$( ".selector" ).accordion( "option", "disabled", true );    
option( options ) jQuery (plugin only)为 accordion 设置一个或多个选项。
  • options
    类型:Object
    描述:要设置的 option-value 对。

代码实例:

调用该方法:

$( ".selector" ).accordion( "option", { disabled: true } );    
refresh()jQuery (plugin only)处理任何在 DOM 中直接添加或移除的标题和面板,并重新计算 accordion 的高度。结果取决于内容和 heightStyle 选项。
  • 该方法不接受任何参数。

代码实例:

调用 refresh 方法:

$( ".selector" ).accordion( "refresh" );    
widget() jQuery返回一个包含 accordion 的 jQuery 对象。
  • 该方法不接受任何参数。

代码实例:

调用 widget 方法:

var widget = $( ".selector" ).accordion( "widget" );    

事件类型 描述
activate( event, ui )accordionactivate面板被激活后触发(在动画完成之后)。如果 accordion 之前是折叠的,则 ui.oldHeaderui.oldPanel 将是空的 jQuery 对象。如果 accordion 正在折叠,则 ui.newHeaderui.newPanel 将是空的 jQuery 对象。

注意:由于 activate 事件只有在面板激活时才能触发,当创建 accordion 部件时,最初的面板不会触发该事件。如果您需要一个用于部件创建的钩,请使用 create 事件。

  • event
    类型:Event
  • ui
    类型:Object
    • newHeader
      类型:jQuery
      描述:刚被激活的标题。
    • oldHeader
      类型:jQuery
      描述:刚被取消激活的标题。
    • newPanel
      类型:jQuery
      描述:刚被激活的面板。
    • oldPanel
      类型:jQuery
      描述:刚被取消激活的面板。

代码实例:

初始化带有指定 activate 回调的 accordion:

$( ".selector" ).accordion({  activate: function( event, ui ) {}});    

绑定一个事件监听器到 accordionactivate 事件:

$( ".selector" ).on( "accordionactivate", function( event, ui ) {} );    
beforeActivate( event, ui )accordionbeforeactivate面板被激活前直接触发。可以取消以防止面板被激活。如果 accordion 当前是折叠的,则 ui.oldHeaderui.oldPanel 将是空的 jQuery 对象。如果 accordion 正在折叠,则 ui.newHeaderui.newPanel 将是空的 jQuery 对象。
  • event
    类型:Event
  • ui
    类型:Object
    • newHeader
      类型:jQuery
      描述:将被激活的标题。
    • oldHeader
      类型:jQuery
      描述:将被取消激活的标题。
    • newPanel
      类型:jQuery
      描述:将被激活的面板。
    • oldPanel
      类型:jQuery
      描述:将被取消激活的面板。

代码实例:

初始化带有指定 beforeActivate 回调的 accordion:

$( ".selector" ).accordion({  beforeActivate: function( event, ui ) {}});    

绑定一个事件监听器到 accordionbeforeactivate 事件:

$( ".selector" ).on( "accordionbeforeactivate", function( event, ui ) {} );    
create( event, ui )accordioncreate当创建 accordion 时触发。如果 accordion 是折叠的,ui.headerui.panel 将是空的 jQuery 对象。
  • event
    类型:Event
  • ui
    类型:Object
    • header
      类型:jQuery
      描述:激活的标题。
    • panel
      类型:jQuery
      描述:激活的面板。

代码实例:

初始化带有指定 create 回调的 accordion:

$( ".selector" ).accordion({  create: function( event, ui ) {}});    

绑定一个事件监听器到 accordioncreate 事件:

$( ".selector" ).on( "accordioncreate", function( event, ui ) {} );    

实例

一个简单的 jQuery UI 折叠面板(Accordion)。

<!doctype html><html lang="en"><head>  <meta charset="utf-8">  <title>折叠面板部件(Accordion Widget)演示</title>  <link rel="stylesheet" href="https://zhishitu.com/">  <script src="/images/2021/07/13/07/2021071307103211238290.js"></script>  <script src="/images/2021/07/13/07/2021071307103211605001.js"></script></head><body> <div id="accordion">  <h3>部分 1</h3>  <div>    <p>Mauris mauris ante, blandit et, ultrices a, suscipit eget.    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.</p>  </div>  <h3>部分 2</h3>  <div>    <p>Sed non urna. Phasellus eu ligula. Vestibulum sit amet purus.    Vivamus hendrerit, dolor aliquet laoreet, mauris turpis velit,    faucibus interdum tellus libero ac justo.</p>  </div>  <h3>部分 3</h3>  <div>    <p>Nam enim risus, molestie et, porta ac, aliquam ac, risus.    Quisque lobortis.Phasellus pellentesque purus in massa.</p>    <ul>      <li>List item one</li>      <li>List item two</li>      <li>List item three</li>    </ul>  </div></div> <script>$( "#accordion" ).accordion();</script> </body></html>