接下来的几篇Cairngorm教学是参考David Tucker 的 Getting Started with Cairngorm ,假如英文程度够好的话,建议直接去看他的网站,里面还有英文教学影片。(其实英文不好,建议大家也看看David Tucker的网站,自己英文水平不够,可以借助金山和有道桌面词典。慢慢啃英文技术文档是我们做Flex程序员以后成长必备的能力) 新增三个文件,两个是MXML 组件。
Cairngorm: Model Locator
用来集中管理程序所需的变量。
首先在我们的项目的src文件夹下,建立model文件夹:
第二步建立ViewModelLocator.as类。此类必须实现IModelLocator接口。
ViewModelLocator.as的代码如下:
package org.rianotes.CairngormSample.model
{
import com.adobe.cairngorm.model.IModelLocator;
import mx.collections.ArrayCollection;
[Bindable]
public class ViewModelLocator implements IModelLocator {
// Single Instance of Our ModelLocator
private static var instance:ViewModelLocator;
public function ViewModelLocator(enforcer:SingletonEnforcer) {
if (enforcer == null) {
throw new Error( "You Can Only Have One ViewModelLocator" );
}
}
// 回传已存的参数
// Returns the Single Instance
public static function getInstance() : ViewModelLocator {
if (instance == null) {
instance = new ViewModelLocator( new SingletonEnforcer );
}
return instance;
}
//在下面定义你要的参数 - DEFINE YOUR VARIABLES HERE
public var contactbook:ArrayCollection = new ArrayCollection();
}
}
// Utility Class to Deny Access to Constructor
class SingletonEnforcer {}
其中构造函数与getInstance()这两个部分照着写,大致上不用修改。
它们是用来判断application中是否已经建立了ViewModelLocator,有的话读取,沒有的话初始一个。
在同一个application中只能有一个ModelLocator,所有的View都能从此读取数据。
而[Bindable]的特性,可以让任一个使用ModelLocator中的变量的地方自动更新。
下面的示例是一个通讯录,将使用者资料存在ModelLocator中
其中将示范,即使在不同的组件中对ModelLocator数据修改,其他的组件也会即时更新。
新增三个文件,两个是MXML 组件。
AddPersonForm.mxml - 用来输入用户名与用户Email地址的From
<?xml version="1.0" encoding="utf-8"?>
<mx:VBox xmlns:mx="http://www.adobe.com/2006/mxml"
horizontalAlign="right">
<mx:Script>
<![CDATA[
import org.rianotes.CairngormSample.vo.User;
import mx.controls.Alert;
import org.rianotes.CairngormSample.model.ViewModelLocator;
private var modelOne:ViewModelLocator = ViewModelLocator.getInstance();
private function addPerson(e:MouseEvent):void{
if(tiUserID.text && tiEmail.text){
var usercontact:User = new User();
usercontact.UserID = tiUserID.text;
usercontact.Email = tiEmail.text;
modelOne.contactbook.addItem(usercontact);
tiUserID.text = "";
tiEmail.text = "";
}
else{
mx.controls.Alert.show("使用者ID與電子郵件不可為空!");
}
}
]]>
</mx:Script>
<mx:Form borderStyle="solid" width="100%" height="100%">
<mx:FormItem label="UserID :" width="100%">
<mx:TextInput id="tiUserID" width="100%"/>
</mx:FormItem>
<mx:FormItem label="Email: " width="100%">
<mx:TextInput id="tiEmail" width="100%"/>
</mx:FormItem>
</mx:Form>
<mx:Button label="输入" click="addPerson(event)" />
</mx:VBox>
ContactbookGrid.mxml -用来显示输入资料的DataGrid
<?xml version="1.0" encoding="utf-8"?>
<mx:DataGrid xmlns:mx="http://www.adobe.com/2006/mxml"
dataProvider="{modelOne.contactbook}">
<mx:Script>
<![CDATA[
import org.rianotes.CairngormSample.model.ViewModelLocator;
private var modelOne:ViewModelLocator = ViewModelLocator.getInstance();
]]>
</mx:Script>
<mx:columns>
<mx:DataGridColumn headerText=" - UserID - " width="75" dataField="UserID" />
<mx:DataGridColumn headerText=" - Email - " dataField="Email"/>
</mx:columns>
</mx:DataGrid>
一个VO(value object)
User.as - 用来记录User contact info的资料的类。
package org.rianotes.CairngormSample.vo
{
public class User
{
public var UserID:String;
public var Email:String;
public function User()
{
}
}
}
而其中最重要的是:
import org.rianotes.CairngormSample.model.ViewModelLocator;
private var modelOne:ViewModelLocator = ViewModelLocator.getInstance();
这是每个组件对ModelLocator作初使化的动作,之后Component就能夠从ModelLocator读取已存在或被修改的变量了。
最後在MXML Application中将components加入
Main.mxml -项目的主文件
<?xml version="1.0" encoding="utf-8"?>
<mx:Application
xmlns:mx="http://www.adobe.com/2006/mxml"
layout="absolute" xmlns:components="org.rianotes.CairngormSample.view.components.*">
<mx:Script>
<![CDATA[
import org.rianotes.CairngormSample.model.ViewModelLocator;
private var modelOne:ViewModelLocator = ViewModelLocator.getInstance();
]]>
</mx:Script>
<mx:HBox width="500" height="200">
<mx:VBox>
<mx:Label text="{'Number of Contacts: ' + modelOne.contactbook.length}" />
<components:ContactbookGrid width="100%" height="100%" />
</mx:VBox>
<components:AddPersonForm width="100%" height="100%" />
</mx:HBox>
</mx:Application>
分享到:
相关推荐
在教程的最后,作者强调了本教程的目的是帮助初学者入门,更深层次的内容需要读者自行学习和探索。 通过以上的知识点,可以看出Cairngorm是一个功能丰富的框架,尤其适合于构建复杂的企业级Flex应用程序。它通过...
在提供的压缩包文件中,"Cairngorm中文版.pdf"和"Cairngorm中文版"很可能是对Cairngorm框架的详细中文教程和实例,对于初学者来说,是学习和理解Cairngorm的宝贵资源。通过深入学习这些资料,开发者可以更好地掌握...
本教程将通过一个登录注册功能的实例,帮助初学者理解并掌握Cairngorm框架的基本概念和用法。 首先,Cairngorm的核心组件包括: 1. **模型(Model)**:存储和管理应用程序数据,通常与后台服务进行交互以获取或...
这个“Cairngorm.swc+Cairngorm+开发文档中文版.rar”套装提供了一个完整的Cairngorm框架,以及相关的中文开发文档,对于初学者和经验丰富的开发者来说都是一个宝贵的资源。 Cairngorm的核心设计理念是基于Model-...
### Cairngorm深入解析 #### 一、Cairngorm框架简介 Cairngorm作为一款专门为Adobe Flex设计的模型视图控制器(Model-View-...无论是对于初学者还是经验丰富的开发者来说,掌握Cairngorm都是一项非常有价值的技能。
**Cairngorm框架初探** Cairngorm是一种基于ActionScript 3.0的轻量级MVC(Model-View-...通过"**CairegormLogin**"这样的实例,初学者可以快速掌握Cairngorm的核心概念和工作流程,为自己的项目打下坚实的基础。
在提供的"Cairngorm"压缩包文件中,初学者可以通过查看和运行示例项目来学习如何在实际开发中应用这些概念。通过学习Cairngorm,开发者能够更好地理解如何组织Flex应用程序,提高代码的可读性和可维护性,同时利用其...
本篇文章将深入探讨两个Cairngorm实例,非常适合初学者学习和理解MVC架构在实际项目中的应用。 实例一:Cairngorm实例1 在这个实例中,我们将了解如何创建一个简单的Cairngorm应用。首先,我们会设置项目的结构,...
这个项目可能是为了帮助初学者理解如何在Flex中使用Cairngorm来组织代码和管理应用程序的复杂性。 描述中提到的“NULL”表明没有具体的项目描述,但我们可以通过标签和压缩包内的文件来推测其内容。标签“源码”...
《cairngorm视频教材》是一份专门为初学者设计的教育资源,旨在帮助学习者掌握使用Flex、BlazeDS、Java以及Socket技术进行软件开发的基本技能。这份教材由一位经验丰富的教师亲自录制,充满了实践经验和深入的理论...
尽管现在已经有了许多其他Flex和ActionScript框架,如Spark和RobotLegs,但Cairngorm因其简洁和灵活性仍然受到很多开发者的喜爱,尤其是对于初学者,它是一个很好的学习起点。通过深入理解和实践Cairngorm,你可以...
这对于初学者来说非常有价值,因为它提供了一个实际操作的学习平台,让他们能够快速理解Cairngorm框架的工作原理和用法。 Cairngorm的核心组件包括: 1. **Controller**:控制层负责接收用户交互,调度模型和视图...
"Cairngorm2/3 框架 烟水晶 HelloWorld 源代码案例"是一个很好的学习资源,它将帮助初学者理解Cairngorm的工作原理和实际应用。通过研究和实践这个案例,你可以深入掌握如何利用Cairngorm组织和管理代码,以及如何...
这本书是深入理解并有效利用Cairngorm框架的宝贵资源,无论你是初学者还是有经验的开发者,都能从中受益。《Wrox Professional Cairngorm Nov 2009》的PDF文件包含了所有这些详细信息,是你学习和探索Cairngorm...
总的来说,《Cairngorm中文版》教程是Flex开发者不可或缺的参考资料,无论你是初学者还是有经验的开发者,都可以从中受益匪浅,提升你的Flex应用开发技能。通过阅读压缩包中的"Cairngorm中文版.pdf"文件,你将深入...
《Flex常用教程及库》 Flex,作为Adobe的开源框架,是用于构建富互联网应用程序(RIA)的强大工具,尤其在创建交互式、图形...无论是初学者还是有经验的开发者,掌握这些知识都将对提升开发效率和项目质量大有裨益。
CairngormTest实例是基于Flex的开源框架Cairngorm的一个入门级示例,它旨在为初学者提供一个直观的途径,以便更好地理解和应用Model-View-Controller(MVC)设计模式。Cairngorm是Adobe Flex社区开发的一个轻量级...
【Flex环境搭建技术指导】 Flex,全称Adobe Flex,是一种基于标准编程模型的富互联网应用程序(RIA)开发框架。它最初由Macromedia公司在2004...对Flex初学者来说,了解这些基础知识和整合技术是非常重要的学习步骤。