`

第三章 Flex的基础 (5-6小节)

    博客分类:
  • Flex
阅读更多

第五节使 MXML

MXML 是一 XML 语言,你可以使用它去布 Adobe Flex 应用程序的用户界面。你还可以使 MXML 去定义其它的方面,如存取服务器端的数据,将用户组件与服务器端数据源进行绑定等

MXML 看起来与你所熟悉 HTML 很类似,然而 MXML 更为结构化,并提供更为丰富的标签集 MXML HTML 之间最大的不同之处在于, MXML 所定义的应用程序将被编译 SWF 文件并 Flash Player 进行渲染,它提供 HTML 程序更为丰富的和动态的用户界面。

你可以 MXML 应用程序编写成一个文件或多个文件。同时 MXML 还支持 MXML ActionScrip 所定制的组件。

编写一个简单的应用程序

随后的简单程序显 Hello World ”,该例子包含 <mx:Application> 标签和两个子标签,即 <mx:Panel> 标签和 <mx:Label> 标签。 <mx:Application> 是所 Fles 应用程序的根标签 <mx:Panel> 标签定义了一个面板容器,它包括了标题栏、状态信息、边界、以及容纳子对象的内容区域 <mx:Label> 标签中使用了一 Label 控件用来显示文本

<?xml version="1.0"? > <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" >

<mx:Panel title="My Application" paddingTop="10" paddingBottom="10 " paddingLeft="10" paddingRight="10" >

<mx:Label text="Hello World!" fontWeight="bold" fontSize="24" />

</mx:Panel> </mx:Application>

将文件保存 hello.mxml 。请注意 MXML 文件的后 .mxml 必须是小写。然后编译并运行所生成 SWF 文件,结果如下所示

MXML 标签 ActionScript 类的关

Adobe 是通 ActionScript 类库来实 Flex 应用程序的。类库包括了组件(容器和控件),管理类,数据服务类等等。事实上,你是在使用类库所支持 MXML ActionScript 来开 Flex 应用程序

MXML 标签 ActionScript 类或类的属性相对应 Flex MXML 标签并编译成相应 SWF 文件。举个例子 Flex ActionScript 按钮类 /Button class 来定义按钮控件。 MXML 中,你使用如 MXML 语句来创建一个按钮控件

<mx:Button label="Submit" />

当你使 MXML 标签来声明一个控件时,事实上你就创建了相应那个类的一个实例对象。上 MXML 语句创建了一个按钮对象,并初始化它 label 属性值。

MXML 相关的技术标准

MXM 相关的技术标准有

1. XML 标准 XML 文档使用标签去决定结构化信息的内容,以及它们之间的关系

2. 事件模型标准 Flex 事件模型是文档对象模 /Document Object Model DOM )第三级事件的一个子集,该模型是 World Wide Web Consortium W3C )起草制定

3. Web 服务标 Flex 提供与服务器交互 MXML 标签,遵循 Web 服务描述语 /Web Services Description Language WSDL )的规则。具体包括了简单对象访问协 /Simple Object Access Protocol SOAP )和超文本传送协 /Hypertext Transfer Protocol HTTP

4. Java

Flex 提供了与服务器 Java 对象交互 MXML 标签,包 plain old Java objects POJOs ), JavaBeans 和企业 /Enterprise JavaBeans EJBs

5. HTTP

Flex 提供了相应 MXML 标签去支持标准 HTTP GET POST 请求,以及 HTTP 返回数据的处理

6. 图形标

Flex 还提供了相应 MXML 标签去使 JPEG GIF PNG 图象。 Flex 还能够 SWF 文件 Scalable Vector Graphics SVG )文件导入到应用程序中

7. 层叠样式表标 MXML 样式的定义和使用遵循 W3C Cascading Style Sheets CSS )标准

第六节使 ActionScript Adobe Flex 开发人员还可以使 ActionScript 去扩展应用程序的功能性 ActionScript 提供了 MXML 更为低层的、更细致的、更为强大的功能。

ActionScript

ActionScript 是一种运用 Adobe Flash Player 的编程语言,它 core JavaScript 非常类似。 ActionScript 3.0 的特性完全实现 ECMAScript for XML (E4X)

MXML 程序中 ActionScript

ActionScript 极大地扩展 Flex 开发人员的能力。通过使 ActionScript ,你可以定义事件监听器,获取或设置组件的属性,处理回调功能,创建新的类、包和组件等。

你可以运用如下所示方法 Flex 中使 ActionScript

  1. 1. <mx:Script> 标签中插 ActionScript 代码块
  2. 2. 调用存储 system_classes 目录结构中的全 ActionScript 功能函数
  3. 3. user_classes 中的外部类和包来处理更为复杂的任务
  4. 4. 使用标准 Flex 组件
  5. 5. 使 ActionScript 类扩展已有的组件
  6. 6. 使 ActionScript 创建新的组件
  7. 7. Flash 创建环境中创建新的组件 SWC 文件)

ActionScript 的编

Flex 应用程序的逻辑实现是 ActionScript 类, MXML 文件, SWF 文件,外部组件共同组成。最后 Flash Player SWF 文件并在客户端机器上进行运行。

你可以 MXML 文件中使 ActionScript 代码段 Flex 编译器将 MXML 文件和它的子文件变换成一个单独 ActionScript 类。同时,你还可以 MXML 文件中导 ActionScript 类,这些类会被添加到最后 SWF 文件中。

随后的例子显示了源文件是如何生 SWF 文件,并通 J2EE 服务器发送给客户端的:

Flex 应用程序中使 ActionScript

当你编写一 Flex 应用程序时,使 MXML 去布置用户的界面,使 ActionScript 去处理与用户的交互。你可以使用不同的方法 ActionScript MXML 混合在一起。

Flex 应用程序中使 ActionScript ,你可以 <mx:Script> 标签中添加脚本块,或者包含外部 ActionScript 文件。另外,你还可以 MXML 程序中导入外部的类文件或整个类的包。

ActionScript 组件

通过使 ActionScript Flex 程序中进行引用的方式,你可以创建可复用的组件。使 ActionScript 所创建的组件可以包含图形元素、定制的商业逻辑、或扩展已存在 Flex 组件。

例如,你可以定义一个定制的按钮,它 Flex 的按钮控件派生出来,就象这样

package myControls { public class MyButton extends Button { public function MyButton() {

...

}

...

} }

这个例子中,你 MyButton.as 文件里编写 MyButton 控件,并将文件保存 Flex 应用程序的根目录 myControls 子目录下。然后 Flex 应用程序中引用你定制的按钮控件,如 MyApp.mxml 文件里,就象这样

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"

xmlns:cmp="myControls.*" >

<cmp:MyButton label="Jack"/>

</mx:Application>

本例中,你首先定 cmp 命名空间,用它来放置你定制的组件,然后使用该命名空间为前缀 MXML 标签对组件进行引用。

 

分享到:
评论

相关推荐

    flex 移动开发

    ### Flex 移动开发知识点详解 #### 一、起步阶段:了解移动应用开发的基础 **1.1 起步阶段** 在《Developing Mobile Applications with ADOBE® FLEX® and ADOBE® FLASH® BUILDER™》文档中,“起步阶段”章节...

    FUJI NXT2编程资料

    - **第3章**:Job编制器 - 创建NXT-2 Job的基础步骤 - 从变更现有Job开始 - 从手动输入顺序数据开始 - 从导入各种CAD数据开始(CentroidCAD、CCIMF、MCSIMF、AllegroCAD、MentorCAD等) - NXT-2 Job设置 - ...

    FluorineFx中文帮助[中英对照译文]

    第 5 章未在给出的内容中提及,但通常会涉及更高级的主题,比如安全配置、性能优化、错误处理、示例应用或其他特定功能的详细解释。 通过 FluorineFx 的中文帮助文档,开发者可以更轻松地理解和使用这款工具,从而...

    使用 ACTIONSCRIPT 3.0组件 (AS3组件帮助文档)

    #### 第 6 章:使用 FLVPlayback 组件 **使用 FLVPlayback 组件** FLVPlayback 组件专门用于播放 FLV 视频格式的内容。通过配置组件的各种属性,可以轻松实现视频的播放、暂停、音量调节等功能。 **自定义 ...

    电子工程0欧姆电阻在PCB设计中的多功能应用

    内容概要:0欧姆电阻在电路设计中有多种重要作用。它不仅可以在PCB上为调试提供便利,还能用于跳线、替代不确定参数的元件以及测量电路的耗电流。此外,在布线困难时可作为应急解决方案。在高频信号环境下,它能充当电感或电容,有助于解决EMC问题。对于地线处理,0欧姆电阻可用于实现单点接地,避免模拟地和数字地直接大面积相连带来的互相干扰问题。在跨接电流回路方面,它可以提供较短的回流路径,减少干扰。同时,0欧姆电阻还适用于配置电路,防止用户误操作跳线或拨码开关,并且在布线、调试、测试、温度补偿等方面有着广泛应用,尤其在EMC对策中表现突出。; 适合人群:电子工程师、硬件设计师以及对电路设计感兴趣的爱好者。; 使用场景及目标:①在PCB设计阶段,利用0欧姆电阻进行灵活的电路调试与优化;②解决高频信号下的EMC问题,确保电路稳定性和抗干扰能力;③实现单点接地,避免不同地线间的相互干扰;④提高电路的可维护性和可靠性,降低生产成本。; 阅读建议:本文详细介绍了0欧姆电阻在电路设计中的多种应用场景,读者应结合具体项目需求来理解和运用这些知识,特别是在面对复杂的电路布局和电磁兼容性问题时,要充分考虑0欧姆电阻的独特优势。

    一个基于SpringBoot+Mybatis+Mysql+Html实现的页面登录案例

    mysql安装教程 一个基于SpringBoot+Mybatis+Mysql+Html实现的页面登录案例.

    全域旅游综合解决方案PPT(71页).pptx

    在探索智慧旅游的新纪元中,一个集科技、创新与服务于一体的整体解决方案正悄然改变着我们的旅行方式。智慧旅游,作为智慧城市的重要分支,旨在通过新一代信息技术,如云计算、大数据、物联网等,为游客、旅游企业及政府部门提供无缝对接、高效互动的旅游体验与管理模式。这一方案不仅重新定义了旅游行业的服务标准,更开启了旅游业数字化转型的新篇章。 智慧旅游的核心在于“以人为本”,它不仅仅关注技术的革新,更注重游客体验的提升。从游前的行程规划、信息查询,到游中的智能导航、个性化导览,再到游后的心情分享、服务评价,智慧旅游通过构建“一云多屏”的服务平台,让游客在旅游的全过程中都能享受到便捷、个性化的服务。例如,游客可以通过手机APP轻松定制专属行程,利用智能语音导览深入了解景点背后的故事,甚至通过三维GIS地图实现虚拟漫游,提前感受目的地的魅力。这些创新服务不仅增强了游客的参与感和满意度,也让旅游变得更加智能化、趣味化。 此外,智慧旅游还为旅游企业和政府部门带来了前所未有的管理变革。通过大数据分析,旅游企业能够精准把握市场动态,实现旅游产品的精准营销和个性化推荐,从而提升市场竞争力。而政府部门则能利用智慧旅游平台实现对旅游资源的科学规划和精细管理,提高监管效率和质量。例如,通过实时监控和数据分析,政府可以迅速应对旅游高峰期的客流压力,有效预防景区超载,保障游客安全。同时,智慧旅游还促进了跨行业、跨部门的数据共享与协同合作,为旅游业的可持续发展奠定了坚实基础。总之,智慧旅游以其独特的魅力和无限潜力,正引领着旅游业迈向一个更加智慧、便捷、高效的新时代。

    工业自动化中模拟量滤波防抖PLC程序的实现与应用

    内容概要:本文详细介绍了如何通过PLC程序实现模拟量滤波防抖,确保电流、电压和热电阻等信号的准确采集。核心算法采用掐头去尾平均法,即去掉一组数据中的最大值和最小值后取剩余数据的平均值,以消除因环境干扰导致的异常值。文中提供了详细的代码实现步骤,包括数据结构定义、主程序逻辑、间接寻址方法以及参数配置。此外,还讨论了如何通过死区判断和上升率限制进一步优化滤波效果,提高系统的稳定性和响应速度。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是熟悉PLC编程和模拟量信号处理的专业人士。 使用场景及目标:适用于需要高精度模拟量信号采集的工业控制系统,如电力、化工、制造业等领域。主要目标是提升数据采集的准确性和稳定性,减少外部干扰带来的误差。 其他说明:文中提供的代码示例基于西门子S7-1200/1500系列PLC,但相关原理和方法同样适用于其他品牌的PLC。建议在实际应用中根据具体情况调整参数设置,以达到最佳效果。

    【人工智能大模型发展】从技术突破到场景落地:大模型发展图谱与DeepSeek创新应用解析

    内容概要:本文详细介绍了大模型的发展现状与未来趋势,尤其聚焦于DeepSeek这一创新应用。文章首先回顾了人工智能的定义、分类及其发展历程,指出从摩尔定律到知识密度提升的转变,强调了大模型知识密度的重要性。随后,文章深入探讨了DeepSeek的发展路径及其核心价值,包括其推理模型、思维链技术的应用及局限性。此外,文章展示了DeepSeek在多个行业的应用场景,如智能客服、医疗、金融等,并分析了DeepSeek如何赋能个人发展,具体体现在公文写作、文档处理、知识搜索、论文写作等方面。最后,文章展望了大模型的发展趋势,如通用大模型与垂域大模型的协同发展,以及本地部署小模型成为主流应用渠道的趋势。 适合人群:对人工智能和大模型技术感兴趣的从业者、研究人员及希望利用DeepSeek提升工作效率的个人用户。 使用场景及目标:①了解大模型技术的最新进展和发展趋势;②掌握DeepSeek在不同领域的具体应用场景和操作方法;③学习如何通过DeepSeek提升个人在公文写作、文档处理、知识搜索、论文写作等方面的工作效率;④探索大模型在特定行业的应用潜力,如医疗、金融等领域。 其他说明:本文不仅提供了理论知识,还结合实际案例,详细介绍了DeepSeek在各个场景下的应用方式,帮助读者更好地理解和应用大模型技术。同时,文章也指出了当前大模型技术面临的挑战,如模型的局限性和数据安全问题,鼓励读者关注技术的持续改进和发展。

    电力负荷预测中LSSVM及其改进算法的性能对比研究

    内容概要:本文详细比较了四种基于最小二乘支持向量机(LSSVM)的短期电力负荷预测算法:原始LSSVM、SSA-LSSVM、VMD-LSSVM以及VMD-SSA-LSSVM。通过对这些算法的具体实现和性能评估,展示了每种方法的优势和局限性。实验结果显示,随着算法复杂度的增加,预测精度显著提高,特别是VMD-SSA-LSSVM在RMSE和MAPE等评价指标上表现出色,达到了接近真实值的预测效果。然而,这也伴随着计算成本的大幅上升。 适合人群:从事电力系统调度、数据分析、机器学习领域的研究人员和技术人员。 使用场景及目标:适用于需要进行短期电力负荷预测的研究项目或实际应用,旨在提高预测准确性,减少因天气变化、节假日等因素带来的不确定性影响。 其他说明:文中提供了详细的Python代码片段,帮助读者理解和复现相关算法。同时提醒,在选择模型时需综合考虑预测精度与计算效率之间的平衡。

    基于Python+Django的电影推荐系统:融合机器学习与深度学习的全栈实现

    内容概要:本文详细介绍了一种基于Python和Django框架构建的电影推荐系统。该系统不仅涵盖了用户端的基本功能(如登录、搜索、浏览、评论、评分、收藏),还包括管理端的增删改查操作。后端使用Python和Django框架,结合MySQL数据库,前端采用HTML、CSS和JavaScript实现交互界面。推荐算法方面,利用机器学习和深度学习技术,特别是协同过滤和内容过滤相结合的方式,确保推荐结果的多样性和精准性。此外,文中还讨论了一些常见的技术挑战及其解决方案,如用户冷启动问题、前端交互效果优化、数据库配置错误等。 适合人群:具有一定编程经验的Web开发者和技术爱好者,尤其是对Django框架、机器学习和深度学习感兴趣的读者。 使用场景及目标:适用于希望深入了解并实现一个完整的电影推荐系统的个人或团队。主要目标是掌握如何整合前后端技术,运用机器学习和深度学习算法提升用户体验。 其他说明:文中提供了大量代码片段和实践经验,帮助读者更好地理解和实施各个技术细节。同时强调了系统优化的重要性,如通过Redis缓存提高查询效率,使用AJAX实现无缝加载等。

    MATLAB实现V2G光储充一体化微网多目标优化调度策略及其应用

    内容概要:本文探讨了基于MATLAB平台的V2G(车辆到电网)光储充一体化微网多目标优化调度策略。该策略旨在通过建立光伏微网中以经济性和并网负荷波动率为双目标的蓄电池和V2G协同调度模型,利用粒子群优化(PSO)算法求解模型。文中详细介绍了模型搭建、核心算法实现、运行模式对比以及算例分析。结果显示,V2G模式能够显著提高系统的经济性和稳定性,减少蓄电池的需求量,优化三方(电网、微网调度中心、电动汽车用户)的利益。 适合人群:从事电力系统优化、智能电网研究的专业人士,尤其是对MATLAB编程有一定基础的研究人员和技术人员。 使用场景及目标:适用于需要优化光储充一体化微网调度策略的研究机构和企业。目标是在保证系统经济运行的同时,稳定并网负荷,减少波动,从而提升整体性能。 其他说明:代码注释详尽,包含并行计算框架、电池寿命模型和可视化模块等多个亮点。通过实际案例验证,证明了V2G模式的有效性。

    三菱FX3U五轴钻孔机PLC与威纶通触摸屏程序解析及优化技巧

    内容概要:本文详细介绍了三菱FX3U五轴钻孔机的PLC程序和威纶通触摸屏配置,涵盖梯形图编程、IO分配表、参数设置、自动补偿机制以及异常处理等方面。文章通过具体的代码实例展示了如何实现加工循环、参数动态调整、安全防护等功能,并分享了调试过程中遇到的问题及解决方案。此外,还提供了完整的工程文件,便于读者快速理解和应用。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对三菱PLC和威纶通触摸屏有一定了解的人群。 使用场景及目标:帮助读者掌握五轴钻孔机的控制系统设计方法,提高编程效率和设备稳定性,适用于类似机床控制系统的开发和维护。 其他说明:文中提到的许多技巧和注意事项来源于作者的实际工作经验,对于初学者来说非常有价值。同时,提供的完整工程文件可以作为参考模板,节省开发时间和成本。

    matlab开发相关资源.m

    matlab开发相关资源

    a383d-main.zip

    a383d-main.zip

    智慧小区解决方案.pptx

    智慧小区解决方案.pptx

    Seafile 基于 Qt 的 GUI 客户端

    Seafile 基于 Qt 的 GUI 客户端

    无人驾驶车辆局部路径规划:基于Matlab的Astar与RRT算法仿真及优化

    内容概要:本文详细介绍了无人驾驶车辆在局部路径规划中的两种经典算法——Astar和RRT的Matlab实现及其优化。首先,文章解释了Astar算法的核心思想,即通过启发函数进行路径搜索,并针对U型障碍等问题提出了双向搜索策略和动态权重调节。接着,文章探讨了RRT算法的特点,如随机生长特性和路径平滑处理,解决了路径过于曲折的问题。此外,还提出了一种混合算法HRA*,通过改进OPEN集的维护方式,提高了算法效率。最后,通过对不同场景的仿真测试,展示了两种算法在复杂环境中的性能差异,并提供了详细的调参经验和优化建议。 适合人群:对无人驾驶技术和路径规划感兴趣的科研人员、工程师以及有一定编程基础的学习者。 使用场景及目标:适用于研究无人驾驶车辆在复杂环境中的路径规划问题,帮助研究人员理解和优化Astar和RRT算法,提高路径规划的效率和准确性。 其他说明:文中附有大量Matlab代码片段和仿真结果图表,便于读者理解和复现实验。同时,提供了关于栅格地图分辨率、车辆动力学参数等方面的实用建议,有助于实际系统的部署和优化。

    选择.txt

    选择

    西门子200Smart与维纶触摸屏在疫苗车间控制系统的应用:配液、发酵、纯化及CIP清洗工艺详解

    内容概要:本文详细介绍了西门子200Smart PLC与维纶触摸屏在某疫苗车间控制系统的具体应用,涵盖配液、发酵、纯化及CIP清洗四个主要工艺环节。文中不仅展示了具体的编程代码和技术细节,还分享了许多实战经验和调试技巧。例如,在配液罐中,通过模拟量处理确保温度和液位的精确控制;发酵罐部分,着重讨论了PID参数整定和USS通讯控制变频器的方法;纯化过程中,强调了双PID串级控制的应用;CIP清洗环节,则涉及复杂的定时器逻辑和阀门联锁机制。此外,文章还提到了一些常见的陷阱及其解决方案,如通讯干扰、状态机切换等问题。 适合人群:具有一定PLC编程基础的技术人员,尤其是从事工业自动化领域的工程师。 使用场景及目标:适用于需要深入了解PLC与触摸屏集成控制系统的工程师,帮助他们在实际项目中更好地理解和应用相关技术和方法,提高系统的稳定性和可靠性。 其他说明:文章提供了大量实战经验和代码片段,有助于读者快速掌握关键技术点,并避免常见错误。同时,文中提到的一些优化措施和调试技巧对提升系统性能非常有帮助。

Global site tag (gtag.js) - Google Analytics