如何使用javascript的PureMVC框架

 我来答
福喜900
2015-02-13 · TA获得超过6.1万个赞
知道大有可为答主
回答量:1.1万
采纳率:0%
帮助的人:1亿
展开全部
Controller保存所有Command的映射。Command类是无状态的,只在需要时才被创建。

Command是负责处理复杂的数据逻辑的地方,它的使用归纳起来有两种

1. 通过发送Notification 来触发Command

2. addSubCommand() 来启动

口水不要太多,我们马上进入正题

在demo文件夹下建立文件夹controller ,然后在controller夹下建立一个叫StartupCommand.js的js文件,输入以下内容

[javascript]
var StartupCommand = Objs("sweeps.controller.StartupCommand",
MacroCommand,
{
/**
* @override
* 添加Subcommands来启动PuerMVC组件
* 通常这里是先准备Model(即Proxy),然后是View(即Mediators);
*/
initializeMacroCommand: function( note )
{
alert('收到由facade发来的');
//this.addSubCommand( PrepModelCommand );
//this.addSubCommand( PrepViewCommand );
}

});
跟着在demo文件夹下面建立一个文件夹abc来存放Noticefiction,在abc文件夹下建立NotificationNames.js文件,输入下面内容

[javascript]
var NotificationNames = Objs("demo.abc.NotificationNames",{});

NotificationNames.STARTUP = "startup";
然后在html文件里导入 StartupCommand.js和NotificationNames.js文件

[html] view plaincopyprint?
<script type="text/javascript" src="src/demo/abc/NotificationNames.js"></script>
<script type="text/javascript" src="src/demo/controller/StartupCommand.js"></script>
完成后程序的目录树为下图

跟着回到上次如何使用javascript的PureMVC框架 - 初始化里面的 ApplicationFacade.js类

在 initializeController()方法里面添加代码

[javascript]
<pre name="code" class="javascript"> ApplicationFacade.$super.initializeController.call( this );
//注册StartupCommand,并让他监听STARTUP消息
this.registerCommand( NotificationNames.STARTUP, StartupCommand );
以及在startup()方法里面添加代码
[javascript] view plaincopyprint?
//发送STARTUP消息给StartupCommand
this.sendNotification( NotificationNames.STARTUP, app );
这里主要是通过使用sendNotification(notice, app);方法发送Notification来触发StartupCommand 类。

程序在初始化的时候调用initializeController()方法,并使用registerCommand()方法注册了StartupCommand实例,

这样当收到由sendNotification()方法发送出来的NotificationNames.STARTUP消息后就会触发StartupCommand实例的initializeMacroCommand()方法了
运行后你会看到“收到由facade发来的”。

接下来我们来看看怎么使用addSubCommand() 来启动Command实例.

现在controller文件夹下新建PrepViewCommand.js文件,并输入以下内容

[javascript]
var PrepViewCommand = Objs("demo.controller.PrepViewCommand",
SimpleCommand,
{
/**
* @override
*/
execute: function( note )
{
alert('使用addSubCommand方法调用Command实例');
}
}); www 2cto com
然后在html文件里导入 PrepViewCommand.js文件。

[javascript]
<script type="text/javascript" src="src/demo/controller/PrepViewCommand.js"></script>
接着在StartupCommand.js文件的initializeMacroCommand方法添加

[javascript]
this.addSubCommand( PrepViewCommand );
这样就可以调用到PrepViewCommand.js文件的execut()方法了!
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式