jQuery UI API - 折疊面板部件(Accordion Widget)
所屬類別
用法
描述:把一對標題和內容面板轉換成折疊面板。
版本新增: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-iconsclass。ui-accordion-content:折疊面板的內容面板。
依賴
- UI 核心(UI Core)
- 部件庫(Widget Factory)
- 特效核心(Effects Core)(可選的;當與
animate選項一起使用時)
附加說明
- 該部件要求一些功能性的 CSS,否則將無法工作。如果您創建了一個自定義的主題,請使用小部件指定的 CSS 檔作為起點。
快速導航
| 選項 | 方法 | 事件 |
|---|---|---|
| 選項 | 類型 | 描述 | 默認值 |
|---|---|---|---|
| active | Boolean 或 Integer | 當前打開哪一個面板。 支持多個類型:
代碼實例: 初始化帶有指定
$( ".selector" ).accordion({ active: 2 });
在初始化後,獲取或設置 // getter var active = $( ".selector" ).accordion( "option", "active" ); // setter $( ".selector" ).accordion( "option", "active", 2 ); |
0 |
| animate | Boolean 或 Number 或 String 或 Object | 是否使用動畫改變面板,且如何使用動畫改變面板。 支持多個類型:
代碼實例: 初始化帶有指定
$( ".selector" ).accordion({ animate: "bounceslide" });
在初始化後,獲取或設置 // getter var animate = $( ".selector" ).accordion( "option", "animate" ); // setter $( ".selector" ).accordion( "option", "animate", "bounceslide" ); |
{} |
| collapsible | Boolean | 所有部分是否都可以馬上關閉。允許折疊啟動的部分。 代碼實例: 初始化帶有指定
$( ".selector" ).accordion({ collapsible: true });
在初始化後,獲取或設置 // getter var collapsible = $( ".selector" ).accordion( "option", "collapsible" ); // setter $( ".selector" ).accordion( "option", "collapsible", true ); |
false |
| disabled | Boolean | 如果設置為 true,則禁用該 accordion。代碼實例: 初始化帶有指定
$( ".selector" ).accordion({ disabled: true });
在初始化後,獲取或設置 // getter var disabled = $( ".selector" ).accordion( "option", "disabled" ); // setter $( ".selector" ).accordion( "option", "disabled", true ); |
false |
| event | String | accordion 頭部會作出反應的事件,用以啟動相關的面板。可以指定多個事件,用空格間隔。 代碼實例: 初始化帶有指定
$( ".selector" ).accordion({ event: "mouseover" });
在初始化後,獲取或設置 // getter var event = $( ".selector" ).accordion( "option", "event" ); // setter $( ".selector" ).accordion( "option", "event", "mouseover" ); |
"click" |
| header | Selector | 標題元素的選擇器,通過主要 accordion 元素上的 .find() 進行應用。內容面板必須是緊跟在與其相關的標題後的同級元素。 代碼實例: 初始化帶有指定
$( ".selector" ).accordion({ header: "h3" });
在初始化後,獲取或設置 // getter var header = $( ".selector" ).accordion( "option", "header" ); // setter $( ".selector" ).accordion( "option", "header", "h3" ); |
"> li > :first-child,> :not(li):even" |
| heightStyle | String | 控制 accordion 和每個面板的高度。可能的值:
代碼實例: 初始化帶有指定
$( ".selector" ).accordion({ heightStyle: "fill" });
在初始化後,獲取或設置 // getter var heightStyle = $( ".selector" ).accordion( "option", "heightStyle" ); // setter $( ".selector" ).accordion( "option", "heightStyle", "fill" ); |
"auto" |
| icons | Object | 標題要使用的圖示,與 jQuery UI CSS 框架提供的圖示(Icons) 匹配。設置為 false 則不顯示圖示。
代碼實例: 初始化帶有指定
$( ".selector" ).accordion({ icons: { "header": "ui-icon-plus", "activeHeader": "ui-icon-minus" } });
在初始化後,獲取或設置
// getter
var 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 關聯的值。
代碼實例: 調用該方法: var isDisabled = $( ".selector" ).accordion( "option", "disabled" ); |
| option() | PlainObject | 獲取一個包含鍵/值對的對象,鍵/值對表示當前 accordion 選項哈希。
代碼實例: 調用該方法: var options = $( ".selector" ).accordion( "option" ); |
| option( optionName, value ) | jQuery (plugin only) | 設置與指定的 optionName 關聯的 accordion 選項的值。
代碼實例: 調用該方法: $( ".selector" ).accordion( "option", "disabled", true ); |
| option( options ) | jQuery (plugin only) | 為 accordion 設置一個或多個選項。
代碼實例: 調用該方法:
$( ".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.oldHeader 和 ui.oldPanel 將是空的 jQuery 對象。如果 accordion 正在折疊,則 ui.newHeader 和 ui.newPanel 將是空的 jQuery 對象。注意:由於
代碼實例: 初始化帶有指定 activate 回調的 accordion:
$( ".selector" ).accordion({
activate: function( event, ui ) {}
});
綁定一個事件監聽器到 accordionactivate 事件:
$( ".selector" ).on( "accordionactivate", function( event, ui ) {} );
|
| beforeActivate( event, ui ) | accordionbeforeactivate | 面板被啟動前直接觸發。可以取消以防止面板被啟動。如果 accordion 當前是折疊的,則 ui.oldHeader 和 ui.oldPanel 將是空的 jQuery 對象。如果 accordion 正在折疊,則 ui.newHeader 和 ui.newPanel 將是空的 jQuery 對象。
代碼實例: 初始化帶有指定 beforeActivate 回調的 accordion:
$( ".selector" ).accordion({
beforeActivate: function( event, ui ) {}
});
綁定一個事件監聽器到 accordionbeforeactivate 事件:
$( ".selector" ).on( "accordionbeforeactivate", function( event, ui ) {} );
|
| create( event, ui ) | accordioncreate | 當創建 accordion 時觸發。如果 accordion 是折疊的,ui.header 和 ui.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="//code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css">
<script src="//code.jquery.com/jquery-1.10.2.js"></script>
<script src="//code.jquery.com/ui/1.10.4/jquery-ui.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>
