写点什么

Flex 开发者需要知道的 10 件事

  • 2010-02-18
  • 本文字数:1606 字

    阅读完需:约 5 分钟

不久前, Michael Portuesi 发表了一篇博文,谈到了Flex 开发者需要知道的10 件事。文章介绍了每个进入Flex 领域的开发者都需要掌握的基本知识与技能。

Michael Portuesi 给出的 10 个条目中,有些是开发者需要了解的简单细节信息;有些则揭示了 Flash/ActionScript/Flex 与其他开发环境之间的差别。

如果你了解 HTML/CSS 并熟悉 JavaScript,但却对 ActionScript 或 Flex 一无所知的话,那么应该花些时间学习一下面向对象编程,因为 ActionScript 是一门完全的面向对象编程语言,而 Flex 则是一个面向对象的框架。

1. 再简单的东西也是异步的

Flex 是一个异步框架,因此我们绝对不能指望代码调用后就能立刻执行。事实上,我们是无法预知方法的调用序列的。

2. 搞清楚 Flex 组件的样式与属性

Flex UI 组件(按钮、菜单等等)既有属性(通过 ActionScript 语言指定)也有样式(通过 Flex 框架指定)。搞清楚他们之间的区别是非常重要的,因为组件的某些可视化效果可以通过属性指定,但另一些却只能通过样式设定。通过属性指定:

复制代码
button.width = 100;
button.height = 50;

通过样式指定:

复制代码
<mx:Style>
Button {
color: #cc0000;
textRollOverColor: #ccff00;
fontFamily: Trebuchet MS;
}
</mx:Style>
<mx:Button id="setupB" text="Click Me" click="onSetup()" />

3. Flex 中的样式与 HTML 中的不尽相同

可以使用标准的 CSS 样式表来为 Flex 组件添加样式,也可以在 Flex 应用中包含 CSS 样式表。虽然标准 CSS 使用连字符(例如 text-font)格式来定义样式名称,但是 Flex 使用驼峰式的命名格式(例如 textFont)。这是因为连字符不能出现在 XML 的属性中,所以不能用这样的名字作为 MXML 标签的属性。

当然了,如果把样式定义在外部的 CSS 文件中或者 Style 标签中,也可以使用连字符格式的样式名。此外,Flex 还定义了很多 HTML 中不存在的 CSS 样式。

4. 尽管看起来不同,但 MXML 和 ActionScript 本质上是一回事

在 Flex 中声明的所有 MXML 标签都会被 Flex 编译器转换为 ActionScript 代码;当然了,也可以在 MXML 文件中嵌入内联的 ActionScript 代码。既可以使用 MXML 也可以使用 ActionScript 创建新组件。

5. 理解 Flex 的 Code-behind 模式

虽然 MXML 和 ActionScript 本质上是一样的,但他们各司其职。一般来说,MXML 负责显示界面,而 ActionScript 用来完成功能。Code-behind 用于解耦 MXML 和 ActionScript,这样设计师可以直接修改 MXML 而无需阅读代码,程序员则可以更好地组织和重用功能。

6. 理解 Flex 组件的生命周期

Flex 通过状态机机制定义了一套完美的生命周期模型,用于组件的创建、运行和销毁,还定义了一些“入口”,开发者可以借此完成定制化的工作。没有透彻理解组件的生命周期可能会导致错误的编程模型。

7. 理解 Flash 运行时所使用的“跑道”模型

理解 Flash Player 的渲染和代码执行机制非常重要的。在执行了改变界面的指令时,Flash Player 并不是立刻把你要的内容显示在屏幕上,它根据一定的周期来刷新屏幕,而代码的执行则是另一回事。这和 Java 正好相反,Java 总是等待程序主动告诉它什么时候重绘屏幕。

8. 理解数据绑定与查看器(Watcher)

Flex 提供了一种数据绑定机制。简单地说,就是将一个源属性绑定到一个目标属性上,当源属性发生变化时,目标属性也会随之变化。不仅仅可以绑定到属性,还可以绑定到函数。甚至可以为某个属性创建一个 Watcher,当属性变化时会获得事件通知。

9. 数据封装与松耦合非常重要

对于 Flex 和 AIR 项目来说,代码组织与高层结构非常重要。有些人竟然在一个文件中编写了 1000 多行代码,这导致的问题就是牵一发而动全身。

10. 理解 ActionScript 中的弱引用与强引用

不管使用何种语言与开发环境,内存管理始终是一个重要的问题,ActionScript 也不例外。如果不理解运行时环境的内存管理,那么很容易就会出现内存泄露与内存碎片问题。请阅读这篇博文文章来深入了解 ActionScript 的垃圾收集机制。

2010-02-18 01:259184
用户头像

发布了 88 篇内容, 共 273.0 次阅读, 收获喜欢 9 次。

关注

评论

发布
暂无评论
发现更多内容

Spring 之依赖注入底层原理

Java你猿哥

spring ssm 架构师 Java工程师 spring ioc

如何在Java中做基准测试?JMH使用初体验

Java JMH 基准测试

Redis缓存穿透/击穿/雪崩以及数据一致性的解决方案

Java你猿哥

redis ssm 架构师 Java工程师

百度APP iOS端包体积50M优化实践(一)总览

百度Geek说

ios xcode 百度 企业号 4 月 PK 榜

Spring为什么需要三级缓存来解决循环依赖

Java spring 循环依赖

浏览器缓存清理:Cookie for Mac6.9.0激活版

真大的脸盆

Mac Mac 软件 缓存清理 清理缓存 缓存处理工具

这份Java面试八股文让329人成功进入大厂,堪称2023最强

Java你猿哥

Java 面试 面经 春招 Java八股文

一文了解MySQL中的多版本并发控制

京东科技开发者

MySQL 京东云 企业号 4 月 PK 榜

AI真的会让程序员失业吗 | 社区征文

五分钟学大数据

三周年征文

MySQL主从复制原理剖析与应用实践

Java MySQL 数据库 主从复制

前端自动化测试之葵花宝典

京东科技开发者

前端 企业号 4 月 PK 榜

AI 能否取代打工人?| 社区征文

阿发

三周年征文

博睿数据受邀出席GOPS 2023 深圳站:自适应AI支撑可观测性全面升级

博睿数据

可观测性 智能运维 博睿数据 Bonree ONE 自适应AI

图解云消息服务KooMessage

华为云开发者联盟

云计算 后端 华为云 华为云开发者联盟 企业号 4 月 PK 榜

线上问题排查异闻录

小小怪下士

Java 程序员 后端 堆内存管理

展心展力 metaapp:基于 DeepRec 的稀疏模型训练实践

阿里云大数据AI技术

机器学习 算法 稀疏模型

测试1号位的自我修养

京东科技开发者

测试 京东云 企业号 4 月 PK 榜

可处理十亿级向量数据!Zilliz Cloud GA 版本正式发布

Zilliz

SaaS 非结构化数据 Milvus Zilliz 向量数据库

JetCache 缓存开源组件设计精要

阿里技术

缓存 JetCache

阿里P8架构师3年心血终成的453页神级Java系统分析与架构设计文档

Java 架构设计 系统分析

IT架构师全栈成长路线,13张架构图一次说明白

Java你猿哥

Java 面试 架构师 面经 Spring全家桶

LLM 快人一步的秘籍 —— Zilliz Cloud,热门功能详解来啦!

Zilliz

非结构化数据 Milvus Zilliz LLM

软件测试/测试开发简历写作与面试技巧-VIP内部资料

测试人

面试 软件测试 自动化测试 简历 测试开发

MySQL主从复制原理剖析与应用实践

vivo互联网技术

负载均衡 高可用 主从复制 数据备份 Binary Log

安全测试前置实践1-白盒&黑盒扫描

京东科技开发者

京东云 安全测试 企业号 4 月 PK 榜

GitHub上线一天星标99.9K:阿里内部高逼格SpringCloud实战手册

Java 架构 微服务 Spring Cloud

印象最深的都是关于 IoTConsensus 共识协议?听听新晋 Committer 怎么说!

Apache IoTDB

IoTDB Apache IoTDB

流程图哪个软件好用?10款好用的流程图软件推荐:boardmix、Visio、Miro…

彭宏豪95

效率工具 职场 工具 流程图 在线白板

如何将微前端项目部署在同一台服务器同一个端口下

京东科技开发者

微前端 京东云 企业号 4 月 PK 榜

设计模式-备忘录模式

Java你猿哥

Java 设计模式 ssm 架构师 备忘录模式

Flex开发者需要知道的10件事_Java_张龙_InfoQ精选文章