ExtJS学习:MVC模式案例(四)

      通过ExtJS案例系列教程的前三讲,我们基本实现了MVC模式布局ExtJS项目的目的,并且在浏览器中也可以看到最为常见的网页布局结构。但是,作为WEB开发者,并不是能够实现网页布局就算是完成任务了,我们还需要实现一定的功能。在这一讲中,我们将实现当点击ExtJS菜单节点的时候,网页主题部分显示相对应的内容。

      本讲我们不会添加新的文件,只是对原来的文件进行修改即可。前面我们说过,控制器的主要作用是监听事件,控制逻辑。所以,我们今天主要修改demoController.js这个文件,为我们的项目添加切换页面的功能。目前我们demoController.js文件的代码为:

Ext.define('Demo.controller.demoController', {
    extend: 'Ext.app.Controller',
    views: ['Viewport','menuTree'],
    stores: ['menuStore'],
    model: ['menuModel']
});

      首先我们需要对menuTree组件的鼠标点击事件进行监听,修改后的代码:

Ext.define('Demo.controller.demoController', {
    extend: 'Ext.app.Controller',
    views: ['Viewport','menuTree'],
    stores: ['menuStore'],
    model: ['menuModel'],
    //通过init函数来监听视图事件,控制视图与控制器的交互
    init: function() {
        //init函数通过this.control来负责监听
        this.control({
                        //被监听的组件的别名
            'menutree': {
                //监听鼠标点击事件,点击后调用changePage方法
                itemclick: this.changePage,
            }
        });
    },
    changePage:function(){
        alert('success');
    }
});

      刷新页面,点击菜单几点,弹出success说明我们监听事件成功。下面我们继续修改changePage方法,实现对主体内容部分页面的切换功能。demoController.js代码如下:

Ext.define('Demo.controller.demoController', {
    extend: 'Ext.app.Controller',
    views: ['Viewport','menuTree'],
    stores: ['menuStore'],
    model: ['menuModel'],
    //通过init函数来监听视图事件,控制视图与控制器的交互
    init: function() {
        //init函数通过this.control来负责监听
        this.control({
            //被监听的组件的别名
            'menutree': {
                //监听鼠标点击事件,点击后调用changePage方法
                itemclick: this.changePage,
            }
        });
    },
    changePage:function(view, rec, item, index, e){
        //获取url地址
        var url = rec.get('url');
        //获取当前节点信息
        var title = rec.get('text');
        //将主体内容部分的url地址指定为我们获取到的url
        Ext.getDom('contentIframe').src = url;
        //将主体内容框的标题设置为我们获取的节点信息
        Ext.getCmp('mainContent').setTitle(title);
    }
});

      通过对changePage方法的修改,刷新页面,当我们再次点击节点的时候,右侧主体内容部分将显示对应url的页面信息,大功告成。
      今天我们实现了页面切换的功能,下一讲我们将讲解如何实现右键菜单。

文章来源:ITLee博客

原文地址:http://www.itlee.name/qianduan/extjs/491.html/

转载于:https://www.cnblogs.com/itleeblog/archive/2013/03/07/2947409.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值