Menu Widgetversion added: 1.9
Description: 带有鼠标和键盘交互的用于导航的可主题化菜单。
菜单可以用任何有效的标记创建,只要元素有严格的父/子关系且每个条目都有一个锚。最常用的元素是无序列表(<ul>
):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
|
如果使用一个非 <ul>
/<li>
的结构,为菜单和菜单条目使用相同的元素,请使用 menus
选项来区分两个元素,例如 menus: "div.menuElement"
。
可通过向元素添加 ui-state-disabled
class 来禁用任何菜单条目。
图标(Icons)
为了向菜单添加图标,请在标记中包含图标:
1
2
3
|
|
菜单(Menu)会自动向无图标的条目添加必要的内边距。
分隔符(Dividers)
分隔符元素可通过包含未链接的菜单条目来创建,菜单条目只能是空格/破折号:
1
2
3
4
5
|
|
键盘交互(Keyboard interaction)
- ENTER/SPACE:调用获得焦点的菜单项的动作,可能会打开一个子菜单。
- UP:移动教导到上一个菜单项。
- DOWN:移动教导到下一个菜单项。
- RIGHT:如果可用,则打开子菜单。
- LEFT:关闭当前子菜单,移动焦点到父菜单项。如果焦点不在子菜单上,则不进行任何操作。
- ESCAPE:关闭当前子菜单,移动焦点到父菜单项。如果焦点不在子菜单上,则不进行任何操作。
输入一个字母,移动焦点到以该字母开头的第一个条目。重复相同的字符会循环显示匹配的条目。在一个时间内输入更多的字符则匹配所输入的字符。
禁用项可获得键盘焦点,但是不允许任何交互。
主题化(Theming)
菜单部件(Menu Widget)使用 jQuery UI CSS 框架 来定义它的外观和感观的样式。如果需要使用菜单指定的样式,则可以使用下面的 CSS class 名称:
ui-menu
:菜单的外层容器。如果菜单包含图标,该元素会另外带有一个ui-menu-icons
class。ui-menu-item
:单个菜单项的容器。ui-menu-icon
:通过icons
选项进行子菜单图标设置。
ui-menu-divider
:菜单项之间的分隔符元素。
依赖(Dependencies)
其他注意事项(Additional Notes:)
- 该部件要求一些功能性的 CSS,否则将无法工作。如果您创建了一个自定义的主题,请使用小部件指定的 CSS 文件作为起点。
Options
disabledType: Boolean
false
true
,则禁用该 menu(菜单)。初始化带有指定 disabled
选项的menu(菜单)
1
|
|
在初始化后,获取或设置disabled
选项:
1
2
3
4
5
|
|
iconsType: Object
{ submenu: "ui-icon-carat-1-e" }
- submenu (string, default: "ui-icon-carat-1-e")
初始化带有指定 icons
选项的menu(菜单)
1
|
|
在初始化后,获取或设置icons
选项:
1
2
3
4
5
|
|
positionType: Object
{ my: "left top", at: "right top" }
of
选项默认为 input 元素,但是您可以指定另一个定位元素。如需了解各种选项的更多细节,请查看 jQuery UI Position。初始化带有指定 position
选项的menu(菜单)
1
|
|
在初始化后,获取或设置position
选项:
1
2
3
4
5
|
|
roleType: String
"menu"
自定义用于菜单和菜单项的ARIA roles(注:关于ARIA roles)。
在默认情况下菜单项使用"menuitem"
。
设置role
选项为了使"listbox"
使用"option"
作为菜单项。
如果设置为null
,
没有roles将被设置,如果菜单是由被保持焦点另一个元件控制时候,非常有用。
role
选项 不应该被更改。
现有(子)菜单和菜单项将不会被更新。
初始化带有指定 role
选项的menu(菜单)
1
|
|
获取 role
选项:
1
2
|
|
Methods
blur( [event ] )Returns: jQuery (plugin only)
blur
事件。
-
eventType: Event什么事件触发了菜单失去焦点。
调用 blur 方法:
1
|
|
collapse( [event ] )Returns: jQuery (plugin only)
-
eventType: Event什么事件触发关闭子菜单
调用 collapse 方法:
1
|
|
collapseAll( [event ] [, all ] )Returns: jQuery (plugin only)
调用 collapseAll 方法:
1
|
|
destroy()Returns: jQuery (plugin only)
- 该方法不接受任何参数。
调用 destroy 方法:
1
|
|
disable()Returns: jQuery (plugin only)
- 该方法不接受任何参数。
调用 disable 方法:
1
|
|
enable()Returns: jQuery (plugin only)
- 该方法不接受任何参数。
调用 enable 方法:
1
|
|
expand( [event ] )Returns: jQuery (plugin only)
-
eventType: Event什么时间触发打开子菜单。
调用 expand 方法:
1
|
|
focus( [event ], item )Returns: jQuery (plugin only)
focus
事件。
调用 focus 方法:
1
|
|
isFirstItem()Returns: jQuery (plugin only)
- 该方法不接受任何参数。
调用 isFirstItem 方法:
1
|
|
isLastItem()Returns: jQuery (plugin only)
- 该方法不接受任何参数。
调用 isLastItem 方法:
1
|
|
next( [event ] )Returns: jQuery (plugin only)
-
eventType: Event什么事件触发焦点转移。
调用 next 方法:
1
|
|
nextPage( [event ] )Returns: jQuery (plugin only)
-
eventType: Event什么事件触发焦点转移。
调用 nextPage 方法:
1
|
|
option( optionName )Returns: Object
optionName
关联的值。-
optionNameType: String要获取值的选项的名称。
调用该方法:
1
|
|
option()Returns: PlainObject
- 该方法不接受任何参数。
调用该方法:
1
|
|
option( optionName, value )Returns: jQuery (plugin only)
optionName
关联的 menu 选项的值。调用该方法:
1
|
|
option( options )Returns: jQuery (plugin only)
-
optionsType: Object要设置的 option-value 对。
调用该方法:
1
|
|
previous( [event ] )Returns: jQuery (plugin only)
-
eventType: Event什么事件触发焦点转移。
调用 previous 方法:
1
|
|
previousPage( [event ] )Returns: jQuery (plugin only)
-
eventType: Event什么事件触发焦点转移。
调用 previousPage 方法:
1
|
|
refresh()Returns: jQuery (plugin only)
refresh()
方法初始化。
- 该方法不接受任何参数。
调用 refresh 方法:
1
|
|
select( [event ] )Returns: jQuery (plugin only)
select
事件。
-
eventType: Event什么事件触发选择。
调用 select 方法:
1
|
|
widget()Returns: jQuery
jQuery
对象。
- 该方法不接受任何参数。
调用 widget 方法:
1
|
|
Events
blur( event, ui )Type: menublur
初始化带有指定 blur 回调的 menu:
1
2
3
|
|
绑定一个事件监听器到 menublur 事件:
1
|
|
create( event, ui )Type: menucreate
注意:ui
对象是空的,这里包含它是为了与其他事件保持一致性。
初始化带有指定 create 回调的 menu:
1
2
3
|
|
绑定一个事件监听器到 menucreate 事件:
1
|
|
focus( event, ui )Type: menufocus
初始化带有指定 focus 回调的 menu:
1
2
3
|
|
绑定一个事件监听器到 menufocus 事件:
1
|
|
select( event, ui )Type: menuselect
初始化带有指定 select 回调的 menu:
1
2
3
|
|
绑定一个事件监听器到 menuselect 事件:
1
|
|
Example:
一个简单的 jQuery UI Menu
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
|