2009-09-22 23:25

Flex MXML编译成AS类

由“Flex 基础”文中可知:每一个mxml文件首先要编译成as文件,然后再译成swf文件。app.mxml文件编译后会产生一系列中间类,其中app_generated.as文件是主文件,文件中定义了转换后app的类定义。

以下将对转换后的类进行详细阐述。

1    转换后类的名称与应用程序同名(以app为例),继承自mx.core.Application。

2    在<mx:application>标签中定义的且有id的mx控件,转换成类app的共有成员。构造函数中初始化类对象,包括events、styles、properties等

3    mxml文件中定义的控件层次结构,通过mx.core.UIComponentDescriptor实例对象定义,控件的属性通过UIComponentDescriptor对象的propertiesFactory属性以键/值对的形式设置,控件的事件响应由UIComponentDescriptor对象的events属性设置,编译器自动生成一个新的事件响应函数,函数体为mxml中定义的内容,在events属性值中使用新的响应函数。举例如下:

mxml中定义如下控件<mx:Button id="addBtn" click="addToCart()" label="Add to Cart" x="36" y="124">

as中定义如下:

new mx.core.UIComponentDescriptor({
              type: mx.controls.Button                                        //控件类型
              ,
              id: "addBtn"                                                            //控件ID
              ,
              events: {                                                                  //事件响应函数
                click: "__addBtn_click"                                         //自动生成一个新事件函数
              }
              ,
              propertiesFactory: function():Object { return {      //普通属性
                label: "Add to Cart",
                x: 36,
                y: 124
              }}
            })

。。。。。

public function __addBtn_click(event:flash.events.MouseEvent):void
        {
             addToCart();                                                               //函数体为mx:Button的click属性值
        }

4    以mx标签形式定义的非可视化对象,如<mx:Number id="selectedBookIndex">{myDataGrid.selectedIndex}</mx:Number>

编译器在编译时自动生成一个相对应的函数,用于创建对象,并在构造函数中调用该对象。依上例,编译器生成如下函数

private function _app_Number1_i() : Number
            {
             var temp : Number = undefined;
             selectedBookIndex = temp;                                //作为类成员已在前面声明
             mx.binding.BindingManager.executeBindings(this, "selectedBookIndex", selectedBookIndex);    //为对象赋值
             return temp;
            }

在构造函数中调用其函数创建类成员的实例对象

public function app()

{

.........

_app_Number1_i() ;

........

}

5    _app_bindingsSetup():Array 函数创建绑定对象数组,每个绑定对象对应mxml文件中的{}数据绑定,如上所示的{myDataGrid.selectedIndex},在as中转换为:

binding = new mx.binding.Binding(this,
                function():Number
                {
                    return (myDataGrid.selectedIndex);
                },
                function(_sourceFunctionReturnValue:Number):void
                {
                    selectedBookIndex = _sourceFunctionReturnValue;
                },
                "selectedBookIndex");
        result[0] = binding;

_app_bindingExprs():void    设置绑定目标表达式

var destination:*;
          [Binding(id='0')]
          destination = (myDataGrid.selectedIndex);

通过编译生成的其他类来执行具体的数据绑定(待后续研究)

转 Flex MXML编译成AS类的更多相关文章

  1. JDK Tools - xjc: 将 XML Schema 编译成 Java 类

    xjc 是 JAXB 将 xsd 生成 Java 类的工具. 命令格式 xjc [ options ] schema file/URL/dir/jar ... [-b bindinfo ] ... 命 ...

  2. jsp页面编译成Servlet类文件

    package org.apache.jsp; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.js ...

  3. 【转贴】 Flex 预编译处理 与 手机项目、Web项目、Air项目自由转换

    原文连接: http://bbs.9ria.com/forum.php?mod=viewthread&tid=263350#lastpost 由于这个论坛不稳定,所以转到这里来,这个帖子蛮有用 ...

  4. 使用Maven将Hadoop2.2.0源码编译成Eclipse项目

    编译环境: OS:RHEL 6.3 x64 Maven:3.2.1 Eclipse:Juno SR2 Linux x64 libprotoc:2.5.0 JDK:1.7.0_51 x64 步骤: 1. ...

  5. 创建Unity新项目并编译成游戏程序

    注:本人所使用的Unity版本为:Unity5.3.5f1,所使用的VS版本为:Visual.Studio.2013.Ultimate 折腾了快一个月了,终于有时间做自己的啦,哈哈: ) 步骤一:启动 ...

  6. 晓莲说-何不原创:如何通过jad把class批量反编译成java文件

    背景:前几天在项目开发的时候遇到一个问题,那就是利用myeclipse编写好的一个项目打包成jar包后上传部署到服务器里,之后本地的项目被自己改来改去出现了一些问题,想着把上传到服务器里面的war包下 ...

  7. ubuntu16.04编译安装mysql-boost-5.7.21并编译成php扩展测试与使用

    我之前的文章已经改造了自定义MVC框架中的工具类(验证码,图片上传,图像处理,分类)4个类,接下来,就要改造模型类,模型类肯定要连接数据库,由于我的Ubuntu Linux是裸装的php(目前只编译了 ...

  8. JSP编译成Servlet(五)JDT Compiler编译器

    通过JSP编译器编译后生成了对应的java文件,接下去要把Java文件编译成class文件.对于这部分完全没有必要重新造轮子,常见的优秀编译工具有Eclipse JDT Java编译器和Ant编译器. ...

  9. JSP编译成Servlet(四)JSP与Java行关系映射

    我们知道java虚拟机只认识class文件,要在虚拟机上运行就必须要遵守class文件格式,所以JSP编译成servlet后还需要进一步编译成class文件,但从JSP文件到java文件再到class ...

随机推荐

  1. JAVA TcpServer端使用Scanner读取不到数据的解决办法

    在使用JAVA进行Socket通信时,在Server端使用Scanner的nextLine()方法读取数据时,一直读取不到数据是因为Scanner是一个扫描器,它扫描数据都是去内存中一块缓冲区中进行扫 ...

  2. windows消息和消息队列

    windows消息和消息队列 转自:http://blog.163.com/zhangjie_0303/blog/static/990827062010113062446767/ 与基于MS - DO ...

  3. 2015年江西理工大学C语言程序设计竞赛(高级组)

    A 解法:DP+二分 dp[i]=max(dp[i],dp[j]+p[i].v)(i>j) dp[i]表示建立i点之后能够获得的最大值 int n,M; struct node { int l, ...

  4. 从yum源下载安装包及依赖包

    局域网内所有linux都用yum从外网源安装软件有点浪费,尤其遇到下载慢的情况: 所以考虑下载后传到其他机器安装,还可以保证版本一致(创建一个本地仓库更好,这个后面研究了再记录): 首先安装yum工具 ...

  5. 【前端】String.prototype.match() 用法详解

    var str="1 plus 2 equal 3" // 正则表达式 console.log(str.match(/\d+/g)); // ["1", &qu ...

  6. [问题2015S11] 复旦高等代数 II(14级)每周一题(第十二教学周)

    [问题2015S11]  证明: 任一复方阵都相似于一个复对称阵. 举例说明: 存在实方阵, 它不相似于实对称阵. 问题解答请在以下网址下载:http://pan.baidu.com/share/ho ...

  7. 离线安装Cloudera Manager 5和CDH5(最新版5.1.3) 完全教程

    关于CDH和Cloudera Manager CDH (Cloudera's Distribution, including Apache Hadoop),是Hadoop众多分支中的一种,由Cloud ...

  8. Sublime Text的使用代码块安装的模块

    在众多的开发工具IDE当中.作者现在唯独深爱sublime text(以下简称st).以前做后台开发使用visual studio(以下简称vs),以及实行前后端分工也是配合后台使用vs.这里要讲述两 ...

  9. powerdesinger中建立一个表后,出现Existence of index的警告

    可以不检查 Existence of index 这项,也就没有这个警告错误了!意思是说没有给表建立索引,而一个表一般至少要有一个索引,这是一个警告,不用的话对执行没有影响~ 转载:http://bl ...

  10. Docker中的镜像分层技术详解

    早在集装箱没有出现的时候,码头上还有许多搬运的工人在搬运货物,在集装箱出现以后,码头上看到更多的不是工人,而且集装箱的搬运模式更加单一,更加高效,还有其他的好处,比如:货物多打包在集装箱里面,可以防止 ...