CMS:文章管理之控制器

2023-05-10,,

有了编写用户管理的控制器的经验,写这个问题应该不大。不过,文章管理的控制器还是要考虑一下怎么写这个问题,因为在视图里涉及分类的操作和文章的
操作。这确实是一个比较费神的事。在这里,问题的焦点就是需要不需要拆分的问题了。根据松耦合的原则,必然是拆分的,但是拆得太小,太凌乱,写代码是比较
痛苦的,尤其是象Javascript这样灵活但结构不太严谨的语言。笔者开发大型系统经验不多,因而一向比较随心所欲,方便不碍事就好,因而,笔者在这里倾向于不进行拆分,就单独一个控制器,有兴趣的读者可以尝试自己拆分一下。在Scripts\app\controoler目录下,创建一个名称为Content.js的控制器,根据用户管理的控制器的经验,先写下以下代码:Ext.define('SimpleCMS.controller.Content',{    extend: 'Ext.app.Controller',    models: [        'Category', 'CategoryTree','CategoryCombo', 'Content'    ],     stores: [        'CategoriesTree', 'CategoriesCombo','Contents'    ],     views: [    ],     refs: [    ],     init: function () {        me.control({        });    } }); 代码中,以把所有模型和Store包括进控制器了。视图还没创建,因而还没有定义。引用也是一样。现在切换到MainPanel的控制器,在“#contentPanel”的activate事件监听代码下,删除console.log的代码,添加以下代码:this.application.getController('Content').init(); 这样,文章管理的控制器就被加载到应用了,后续的工作就是在文章管理控制器的init方法内实现视图的加载了。还要修改一下MainPanel视图的activeTab配置项,修改回0,让文章管理标签页显示为默认标签页。至此,控制器的工作告一段落,接下来的就是定义视图,然后完成控制器的操作了。

《CMS:文章管理之控制器.doc》

下载本文的Word格式文档,以方便收藏与打印。