ExtJS5_自定义菜单2

这一节来定义另外三种类型的菜单类。首先定义菜单按钮类。文件放于app/view/main/region目录下面,文件名为ButtonMainMenu.js。

/**
 * 显示在顶部的按钮菜单,可以切换至标准菜单,菜单树
 */
Ext.define(‘app.view.main.region.ButtonMainMenu‘, {
    extend : ‘app.ux.ButtonTransparent‘,
    alias : ‘widget.buttonmainmenu‘,
    viewModel : ‘main‘,
    text : ‘菜单‘,
    glyph : 0xf0c9,
    initComponent : function() {
        this.menu = this.getViewModel().getMenus();
        this.callParent();
    }
})

第二种树状菜单,文件名为MainMenuTree.js。

/**
* 树状菜单,显示在主界面的左边
*/
Ext.define(‘app.view.main.region.MainMenuTree‘, {
    extend : ‘Ext.tree.Panel‘,
    alias : ‘widget.mainmenutree‘,
    title : ‘系统菜单‘,
    glyph : 0xf0c9,
    rootVisible : false,
    lines : true,
    viewModel : ‘main‘,

    initComponent : function() {
        this.store = Ext.create(‘Ext.data.TreeStore‘, {
                    root : {
                        text : ‘系统菜单‘,
                        leaf : false,
                        expanded : true
                    }
                });
        var menus = this.getViewModel().get(‘systemMenu‘);
        var root = this.store.getRootNode();
        for (var i in menus) {
            var menugroup = menus[i];
            var menuitem = root.appendChild({
                        text : menugroup.text,
                        expanded : menugroup.expanded,
                        icon : menugroup.icon,
                        glyph : menugroup.glhpy
                    });
            for (var j in menugroup.items) {
                var menumodule = menugroup.items[j];
                var childnode = {
                    moduleId : menumodule.text,
                    moduleName : menumodule.module,
                    text : menumodule.text,
                    leaf : true
                };
                menuitem.appendChild(childnode);
            }
        }
        this.callParent(arguments);
    }
})

第三种为折叠式菜单,文件名为AccordionMainMenu.js。

/**
* 折叠式(accordion)菜单,样式可以自己用css进行美化
*/

Ext.define(‘app.view.main.region.AccordionMainMenu‘, {
    extend : ‘Ext.panel.Panel‘,
    alias : ‘widget.mainmenuaccordion‘,
    title : ‘系统菜单‘,
    glyph : 0xf0c9,

    layout : {
        type : ‘accordion‘,
        animate : true
    },

    viewModel : ‘main‘,

    initComponent : function() {
        this.items = [];
        var menus = this.getViewModel().get(‘systemMenu‘);
        for (var i in menus) {
            var menugroup = menus[i];
            var accpanel = {
                menuAccordion : true,
                xtype : ‘panel‘,
                title : menugroup.text,
                bodyStyle : {
                    padding : ‘10px‘
                },
                layout : ‘fit‘,
                dockedItems : [{
                            dock : ‘left‘,
                            xtype : ‘toolbar‘,
                            items : []
                        }],
                glyph : menugroup.glyph
            };
            for (var j in menugroup.items) {
                var menumodule = menugroup.items[j];
                accpanel.dockedItems[0].items.push({
                            xtype : ‘buttontransparent‘,
                            text : this.addSpace(menumodule.text, 12),
                            glyph : menumodule.glyph,
                            handler : ‘onMainMenuClick‘
                        });
            }
            this.items.push(accpanel);
        }
        this.callParent(arguments);
    },

    addSpace : function(text, len) {
        console.log(text.length);
        var result = text;
        for (var i = text.length; i < len; i++) {
            result += ‘ ‘;
        }
        return result;
    }

})

把这三种类型的菜单加入到页面中。先修改Top.js,引入按钮菜单类

uses : [‘app.ux.ButtonTransparent‘, ‘app.view.main.region.ButtonMainMenu‘],

然后在items中加入

{
    xtype : ‘buttonmainmenu‘
}

再修改Main.js,引入MainMenuTree 和 AccordionMainMenu,在items中加入

{
    xtype : ‘mainmenutree‘,
    region : ‘west‘, // 左边面板
    width : 250,
    split : true
}, {
    xtype : ‘mainmenuaccordion‘,
    region : ‘west‘, // 左边面板
    width : 250,
    split : true
},

经过以上处理,现在界面上会有4种类型的菜单。见下图:

时间: 2024-10-25 15:31:28

ExtJS5_自定义菜单2的相关文章

ExtJS5_自定义菜单1

顶部和底部区域已经作好,在顶部区域有一个菜单的按钮,这一节我们设计一个菜单的数据结构,使其可以展示出不同样式的菜单.由于准备搭建的是一个系统模块自定义的系统,因此菜单也是自定义的,在操作员系统登录的时候,和MainModel中的其他数据一样,将会通过ajax加载要显示的菜单数据,然后生成菜单条或者菜单树.在这个例子中,我只做了二层菜单,要做三层以上的只要稍作修改即可.下面先来看看菜单数据的定义:在MainModel中,在data属性下定义一个systemMenu的数组属性,下面就放了各个菜单项和

自定义菜单创建接口

自定义菜单接口可实现多种类型按钮,如下: 1.click:点击推事件用户点击click类型按钮后,微信服务器会通过消息接口推送消息类型为event的结构给开发者(参考消息接口指南),并且带上按钮中开发者填写的key值,开发者可以通过自定义的key值与用户进行交互: 2.view:跳转URL用户点击view类型按钮后,微信客户端将会打开开发者在按钮中填写的网页URL,可与网页授权获取用户基本信息接口结合,获得用户基本信息. 3.scancode_push:扫码推事件用户点击按钮后,微信客户端将调起

自定义菜单查询接口

使用接口创建自定义菜单后,开发者还可使用接口查询自定义菜单的结构.另外请注意,在设置了个性化菜单后,使用本自定义菜单查询接口可以获取默认菜单和全部个性化菜单信息. 请求说明 http请求方式:GET https://api.weixin.qq.com/cgi-bin/menu/get?access_token=ACCESS_TOKEN 返回说明(无个性化菜单时) 对应创建接口,正确的Json返回结果: {     "menu": {         "button"

微信公众平台自定义菜单及高级接口PHP SDK

本文介绍介绍微信公众平台自定义菜单及高级接口的PHP SDK及使用方法. 作者 方倍工作室 修正记录: 2014.05.03 v1.0 方倍工作室 http://www.cnblogs.com/txw1958/ SDK 源码: 1 /* 2 方倍工作室 http://www.cnblogs.com/txw1958/ 3 CopyRight 2014 www.doucube.com All Rights Reserved 4 */ 5 6 class class_weixin_adv 7 { 8

微信公众平台如何创建自定义菜单?

微信现在的功能越来越强大了,申请认证后的开发者能自定义菜单,用户直接点击微信界面下方的菜单,就能直接去到指定的页面,下面小编用[微信公众平台测试号]为大家演示一下怎么创建自定义菜单. 工具/原料 认证后的微信公众平台 微信公众平台切换开发者模式 方法/步骤 登录[微信公众平台],选择[功能]菜单下面的[高级功能],进入[开发模式]. 由于小编的微信公众平台还没通过认证,下面用[申请测试账户]为大家演示. 微信公众平台接口测试帐号申请,无需公众帐号.快速申请接口测试号,直接体验和测试公众平台所有高

微信自定义菜单中文乱码问题

文章转自 <微信自定义菜单中文乱码问题> 问题:微信自定义菜单开发者模式,菜单中文出现乱码 例: $menu = array( 'button' => array( array( 'type'=>'view', 'name'=>'百度', 'url'=>'https://www.baidu.com', ), ), ); 调用微信自定义菜单创建接口:https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACC

php微信自定义菜单开发

微信自定义菜单需要有一个微信服务号,在开发之前需要获取access_token,获取方法很简单,登陆微信公众账号,进入开发者模式,就可以看到{开发者凭据}:下面AppId和AppSecret,开发者文档说明 : 接口调用请求说明 http请求方式: GEThttps://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET 参数说明 参数 是否必须 说明 grant

微信公众号开发者模式自定义菜单

纯属分享 var config = require('./admin/wx/config/config'); var API = require('wechat-api'); var api = new API(config.appid, config.appsecret); api.getAccessToken(function (err, token) { console.log(err); console.log(token); //accessToken }); var menu = J

C#微信公众号开发 -- (五)自定义菜单创建

公众号中,底部都是有自己定义的功能按钮,通过点击某个按钮来实现指定的业务逻辑操作. 下面就来说说这些按钮是怎样放到微信公众平台的,还是先来看看微信的官方解释: 请注意: 1.自定义菜单最多包括3个一级菜单,每个一级菜单最多包含5个二级菜单. 2.一级菜单最多4个汉字,二级菜单最多7个汉字,多出来的部分将会以“...”代替. 3.创建自定义菜单后,菜单的刷新策略是,在用户进入公众号会话页或公众号profile页时,如果发现上一次拉取菜单的请求在5分钟以前,就会拉取一下菜单, 如果菜单有更新,就会刷