Menu(菜单)
使用$.fn.iMenu.defaults重写默认值对象。
菜单组件通常用于快捷菜单。他是构建其他菜单组件的必备基础组件。比如:menubutton和splitbutton。它还可以用于导航和执行命令。
使用案例
创建菜单
通过标签创建菜单,给<div/>标签添加data-toggle="topjui-menu"。每个菜单项都通过<div/>标签创建。我们可以添加'iconCls'属性来给菜单项定义一个图标显示到菜单项的左侧。添加'menu-sep'类ID菜单项将会生成一个菜单分割线。
html
<div id="mm" data-toggle="topjui-menu" style="width:120px;">
<div>New</div>
<div>
<span>Open</span>
<div style="width:150px;">
<div><b>Word</b></div>
<div>Excel</div>
<div>PowerPoint</div>
</div>
</div>
<div data-options="iconCls:'icon-save'">Save</div>
<div class="menu-sep"></div>
<div>Exit</div>
</div>1
2
3
4
5
6
7
8
9
10
11
12
13
14
2
3
4
5
6
7
8
9
10
11
12
13
14
使用Javascript创建菜单项并监听'onClick'事件。
javascript
$('#mm').iMenu({
onClick:function(item){
//...
}
});1
2
3
4
5
2
3
4
5
显示菜单
在菜单被创建的时候它是隐藏和不可见的。调用'show'方法显示菜单。
javascript
$('#mm').iMenu('show', {
left: 200,
top: 100
});1
2
3
4
2
3
4
菜单项
菜单项代表显示在菜单上的一个单独的项目。它包含以下属性:
| 属性名 | 属性值类型 | 描述 | 默认值 |
|---|---|---|---|
| id | string | 菜单项ID属性。 | |
| text | string | 菜单项文本。 | |
| iconCls | string | 显示在菜单项左侧的16x16像素图标的CSS类ID。 | |
| href | string | 设置点击菜单项时候的页面位置。 | |
| disabled | boolean | 定义是否显示菜单项。 | false |
| onclick | function | 在点击菜单项的时候调用的函数。 |
菜单属性
| 属性名 | 属性值类型 | 描述 | 默认值 |
|---|---|---|---|
| zIndex | number | 菜单z-index样式,增加它的值。 | 110000 |
| left | number | 菜单的左边距位置。 | 0 |
| top | number | 菜单的上边距位置。 | 0 |
| align | string | 菜单对齐方式,可用值有:'left' 和 'right'。 | left |
| minWidth | number | 菜单的最小宽度。 | 120 |
| itemHeight | number | 菜单项高度。 | 22 |
| duration | number | 该属性允许用户自定义隐藏菜单动画的持续时间,以毫秒为单位。 | 100 |
| hideOnUnhover | boolean | 当设置为true时,在鼠标离开菜单的时候将自动隐藏菜单。 | true |
| inline | boolean | 当设置为true时,菜单将相对于父级标签进行定位,否则相对于body进行定位。 | false |
| fit | boolean | 当设置为true时,菜单尺寸将自动适配父容器。 | false |
| noline | boolean | 当设置为true时,菜单将不显示图标和文字之间的分割线。 | false |
菜单事件
| 事件名 | 事件参数 | 描述 |
|---|---|---|
| onShow | none | 在菜单显示之后触发。 |
| onHide | none | 在菜单隐藏之后触发。 |
| onClick | item | 在菜单项被点击的时候触发。下面的例子显示了如何处理所有菜单项的点击: |
html
<div data-toggle="topjui-menu" data-options="onClick:menuHandler" style="width:120px;">
<div data-options="name:'new'">新建</div>
<div data-options="name:'save',iconCls:'icon-save'">保存</div>
<div data-options="name:'print',iconCls:'icon-print'">打印</div>
<div class="menu-sep"></div>
<div data-options="name:'exit'">退出</div>
</div>
<script type="text/javascript">
function menuHandler(item) {
alert(item.name)
}
</script>1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
菜单方法
| 方法名 | 方法参数 | 描述 |
|---|---|---|
| options | none | 返回属性对象。 |
| show | pos | 显示菜单到指定的位置。'pos'参数有2个属性:left:新的左边距位置。top:新的上边距位置。 |
| hide | none | 隐藏菜单。 |
| destroy | none | 销毁菜单。 |
| getItem | itemEl | 获取指定的菜单项。得到的是一个菜单项的DOM元素。 |
| setText | param | 设置指定菜单项的文本。'param'参数包含2个属性:target:DOM对象,要设置值的菜单项。text: 字符串,要设置的新文本值。 |
| setIcon | param | 设置指定菜单项图标。'param'参数包含2个属性:target:DOM对象,要设置的菜单项。iconCls:新的图标CSS类ID。 |
| findItem | text | 查找的指定菜单项,返回的对象和getItem方法是一样的。 |
| appendItem | options | 追加新的菜单项,'options'参数代表新菜单项属性。默认情况下添加的项在菜单项的顶部。追加一个子菜单项,'parent'属性应该设置指定的父项元素,并且该父项元素必须是已经定义在页面上的。 |
| removeItem | itemEl | 移除指定的菜单项。 |
| enableItem | itemEl | 启用菜单项。 |
| disableItem | itemEl | 禁用菜单项。 |
| showItem | itemEl | 显示菜单项。 |
| hideItem | itemEl | 隐藏菜单项。 |
| resize | menuEl | 重置指定的菜单项。 |