打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
ExtJS学习:MVC模式案例(四) | 李坏博客

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


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

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

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

01Ext.define('Demo.controller.demoController', {
02  extend: 'Ext.app.Controller',
03  views: ['Viewport','menuTree'],
04  stores: ['menuStore'],
05  model: ['menuModel'],
06  //通过init函数来监听视图事件,控制视图与控制器的交互
07  init: function() {
08    //init函数通过this.control来负责监听
09    this.control({
10                        //被监听的组件的别名
11      'menutree': {
12        //监听鼠标点击事件,点击后调用changePage方法
13        itemclick: this.changePage,
14      }
15    });
16  },
17  changePage:function(){
18    alert('success');
19  }
20});

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

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

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

如非特殊说明,文章均为ITLee原创,转载请注明原文地址: http://www.lihuai.net/qianduan/extjs/491.html/

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
extjs CheckboxSelectionModel 有选择的显示
EXTjs通过autoLoad加载页面与IFRAME嵌入页面的区别
Extjs中store的load监听的回调函数
ExtJS - Show Framework
ExtJs 4 中的MVC应用架构
ExtJs J2EE的Session过时请求(Timeout)的处理
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服