跟我一起学extjs5(08--自己定义菜单1)


顶部和底部区域已经作好,在顶部区域有一个菜单的button。这一节我们设计一个菜单的数据结构,使其能够展示出不相同式的菜单。因为准备搭建的是一个系统模块自己定义的系统,因此菜单也是自己定义的,在操作员系统登录的时候,和MainModel中的其它数据一样,将会通过ajax载入要显示的菜单数据。然后生成菜单栏或者菜单树。在这个样例中,我仅仅做了二层菜单。要做三层以上的仅仅要稍作改动就可以。

以下先来看看菜单数据的定义:在MainModel中。在data属性下定义一个systemMenu的数组属性,以下就放了各个菜单项和菜单栏的数据定义。

				// 系统菜单的定义。这个菜单能够是从后台通过ajax传过来的
systemMenu : [{
text : 'project管理', // 菜单项的名称
icon : '', // 菜单顶的图标地址
glyph : 0,// 菜单项的图标字体的数值
expanded : true, // 在树形菜单中是否展开
description : '', // 菜单项的描写叙述
items : [{
text : 'project项目', // 菜单栏的名称
module : 'Global', // 相应模块的名称
icon : '', // 菜单栏的图标地址
glyph : 0xf0f7
// 菜单栏的图标字体
}, {
text : 'project标段',
module : 'Project',
icon : '',
glyph : 0xf02e
}] }, {
text : '合同管理',
expanded : true,
items : [{
text : '项目合同',
module : 'Agreement',
glyph : 0xf02d
}, {
text : '合同付款计划',
module : 'AgreementPlan',
glyph : 0xf03a
}, {
text : '合同请款单',
module : 'Payment',
glyph : 0xf022
}, {
text : '合同付款单',
module : 'Payout',
glyph : 0xf0d6
}, {
text : '合同发票',
module : 'Invoice',
glyph : 0xf0a0
}]
}, {
text : '综合查询',
glyph : 0xf0ce,
expanded : true,
items : [{
text : '项目合同台帐',
module : 'Agreement',
glyph : 0xf02d
}, {
text : '合同付款计划台帐',
module : 'AgreementPlan',
glyph : 0xf03a
}, {
text : '合同请款单台帐',
module : 'Payment',
glyph : 0xf022
}, {
text : '合同付款单台帐',
module : 'Payout',
glyph : 0xf0d6
}, {
text : '合同发票台帐',
module : 'Invoice',
glyph : 0xf0a0
}] } ]

上面菜单中定义了三个菜单项。若干个菜单栏。详细的属性上面有说明。有了菜单数据。再编制一个能够依据这些数据生成菜单展示数据的函数,这个函数返回的数组能够直接供toolbar和button作为items和menu来使用。以下这个函数也是在MainModel.js中。

			// 依据data.systemMenu生成菜单栏和菜单button以下使用的菜单数据
getMenus : function() {
var items = [];
var menuData = this.get('systemMenu'); // 取得定义好的菜单数据
Ext.Array.each(menuData, function(group) { // 遍历菜单项的数组
var submenu = [];
// 对每个菜单项。遍历菜单栏的数组
Ext.Array.each(group.items, function(menuitem) {
submenu.push({
mainmenu : 'true',
moduleName : menuitem.module,
text : menuitem.text,
icon : menuitem.icon,
glyph : menuitem.glyph,
handler : 'onMainMenuClick' // MainController中的事件处理程序
})
})
var item = {
text : group.text,
menu : submenu,
icon : group.icon,
glyph : group.glyph
};
items.push(item);
})
return items;
}

以下继承toolbar自己定义一个菜单栏的控件。在war/app/view/main/region文件夹下建立文件MainMenuToolbar.js。

/**
* 系统的主菜单栏,依据MainModel中的数据来生成,能够切换至button菜单,菜单树
*/
Ext.define('app.view.main.region.MainMenuToolbar', {
extend : 'Ext.toolbar.Toolbar',
alias : 'widget.mainmenutoolbar', defaults : {
xtype : 'buttontransparent'
}, items : [{
glyph : 0xf100,
tooltip : '在左边栏中显示树状菜单', // 几种菜单样式切换的button
disableMouseOver : true,
margin : '0 -5 0 0'
}, {
glyph : 0xf102,
tooltip : '在顶部区域显示菜单',// 几种菜单样式切换的button
disableMouseOver : true
}], viewModel : 'main', // 指定viewModel为main initComponent : function() { // 把ViewModel中生成的菜单items加到此toolbar的items中
this.items = this.items.concat(this.getViewModel().getMenus()); this.callParent();
}
});

至此菜单栏控件制作完毕,以下要把其增加到Main的界面之中。

首先在Main.js的uses之中引入

'app.view.main.region.MainMenuToolbar'。然后在items中将菜单toolbar加进去。

			items : [{
xtype : 'maintop',
region : 'north' // 把他放在最顶上
}, {
xtype : 'mainmenutoolbar',
region : 'north' // 把他放在maintop的以下
}, {
xtype : 'mainbottom',
region : 'south' // 把他放在最底下
}, {
region : 'center', // 中间面版
xtype : 'maincenter'
}]

一个菜单栏就增加到了系统之中,来看一下效果。

系统中我共设置了4种类型的菜单,各自是:

  • 菜单button:在顶部的“菜单”button之下。
  • 菜单栏:在顶部区域以下,刚做好的那个就是。

  • 菜单树:显示在左边区域的菜单树。
  • 折叠式菜单:显示在左边区域的还有一种方式。
这几种菜单之间能够非常方便的切换,假设觉得太多了不是必需,能够把不喜欢的取消掉。全部的界面都是用控件搭起来的,所以要添加一种菜单风格或取消一种都非常方便。

跟我一起学extjs5(08--自己定义菜单1)的更多相关文章

  1. 跟我一起学extjs5(11--自己定义模块的设计)

    跟我一起学extjs5(11--自己定义模块的设计)        从这一节開始我们来设计并完毕一个自己定义模块.我们先来确定一个独立的模块的所能定义的一些模块信息. 下面信息仅仅是我自己在开发过程中 ...

  2. 与我一起extjs5(09--其定义菜单2)

    跟我一起学extjs5(09--自己定义菜单2)         这一节来定义另外三种类型的菜单类. 首先定义菜单button类.文件放于app/view/main/region文件夹以下,文件名称为 ...

  3. 跟我一起学extjs5(22--模块Form的自己定义的设计)

    跟我一起学extjs5(22--模块Form的自己定义的设计)         前面几节完毕了模块Grid的自己定义,模块Form自己定义的过程和Grid的过程类似,可是要更复杂一些.先来设计一下要完 ...

  4. 跟我一起学extjs5(24--模块Form的自己定义的设计[2])

    跟我一起学extjs5(24--模块Form的自己定义的设计[2])         在本节中将要增加各种类型的字段,在增加字段的时候因为能够一行增加多个字段,因此层次结构又多了一层fieldcont ...

  5. 跟我一起学extjs5(16--各种Grid列的自己定义渲染)

    跟我一起学extjs5(16--各种Grid列的自己定义渲染)         Grid各列已经可以展示出来了.列的类型包含字符型,整型,浮点型,货币型,百分比型,日期型和布尔型,我自己定义了各种类型 ...

  6. 跟我一起学extjs5(25--模块Form的自己定义的设计[3])

    跟我一起学extjs5(25--模块Form的自己定义的设计[3])         自己定义的Form已经能够执行了,以下改一下配置,把Form里面的FieldSet放在Tab之下.改动一下Modu ...

  7. 跟我一起学extjs5(05--主界面上增加顶部和底部区域)

    跟我一起学extjs5(05--主界面上增加顶部和底部区域)         这一节为主界面加一个顶部区域和底部区域. 一个管理系统的界面能够粗分为顶部标题部分.中间数据展示和处理的部分.底部备注和状 ...

  8. 跟我一起学extjs5(17--Grid金额字段单位MVVM方式的选择)

    跟我一起学extjs5(17--Grid金额字段单位MVVM方式的选择)         这一节来完毕Grid中的金额字段的金额单位的转换.转换旰使用MVVM特性,整体上和控制菜单的几种模式类似.首先 ...

  9. 跟我一起学extjs5(13--运行菜单命令在tabPanel中显示模块)

    跟我一起学extjs5(13--运行菜单命令在tabPanel中显示模块)         上面设计好了一个模块的主界面,以下通过菜单命令的运行来把这个模块增加到主界面其中. 在MainModule. ...

随机推荐

  1. CTF内存高级利用技术

    起了一个比较屌的标题,233.想写这篇文章主要是看了kelwya分析的议题,于是准备自己动手实践一下.蓝莲花的选手真的是国际大赛经验丰富,有很多很多的思路和知识我完全都没有听说过.这篇文章会写一些不常 ...

  2. Linux文件系统备份dump

    常用的备份方式有三种:1.完全备份:把所有数据完全备份下来2.增量备份:以上一次备份的内容作参照3.差异备份:一直以某一个记录点的全备份作参照备份 dump备份工具dump命令:dump -数字 数字 ...

  3. PLSQL Developer个性化设置

    1)代码自动完成 和讨厌的.才后出现提示说88,我用快捷键任意呼唤. Tools->Preferences->User Interface->Key Configuration.找到 ...

  4. pandas实战——对星巴克数据的分析

    一.实验对象 实验对象为星巴克在全球的门店数据,我们可以使用pandas对其进行简单的分析,如分析每个国家星巴克的数量,根据门店数量对国家进行排序等. 二.数据分析 1.读取数据并获取数据行列数 首先 ...

  5. python脚本获取本机公网ip

    1.获取公网IP地址方式,访问:http://txt.go.sohu.com/ip/soip 2.python脚本实现: #!/usr/bin/python # -*- coding:utf8 -*- ...

  6. 关于table边框,设置了border-collapse:collapse之后,设置border-radius没效果

    做项目遇到边框需要设置圆角,然后发现在设置了border-collapse:collapse之后,border-radius:10px不起作用了,发现这个是css本身的问题,两者不能混在一起使用. 代 ...

  7. JAVAEE——SSH项目实战03:新增客户、数据字典、文件上传和修改客户

    作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7145599.html 一.新增客户 1.数据字典  用于枚举项目中有限个数的字典项 (1 ...

  8. Vue图片懒加载插件

    图片懒加载是一个很常用的功能,特别是一些电商平台,这对性能优化至关重要.今天就用vue来实现一个图片懒加载的插件. 这篇博客采用"三步走"战略--Vue.use().Vue.dir ...

  9. shell 转码BIG5 UTF8

    BIG-5 轉 UTF-8 若要將一個文字檔從 BIG-5 編碼轉換為 UTF-8 編碼,可以執行: iconv -f BIG-5 -t UTF-8 big5.txt > utf8.txt 其中 ...

  10. 整理之DOM事件阶段、冒泡与捕获、事件委托、ie事件和dom模型事件、鼠标事件

    整理之DOM事件阶段 本文主要解决的问题: 事件流 DOM事件流的三个阶段 先理解流的概念 在现今的JavaScript中随处可见.比如说React中的单向数据流,Node中的流,又或是今天本文所讲的 ...