`
cuixuxucui
  • 浏览: 352529 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

构建Flex应用的10大误区(转自InfoQ)

    博客分类:
  • Flex
阅读更多

原文地址:http://www.infoq.com/cn/news/2008/04/top-10-flex-mistakes

作者 Jon Rose 译者 张龙 发布于 2008年4月25日 上午10时7分

 

在这篇新闻中,Adobe的James Ward与InfoQ.com一起为你带来了Flex的另一种10大(Flex最新的10大)。Flex是一个开源的应用开发框架,用来构建运行在web(使用 Flash Player)或者桌面上(使用Adobe AIR)的富Internet应用。总之,Flex是一个强大易用的框架,但是今天让我们瞧瞧构建Flex应用时经常犯的错误。

对于Flex新手,请阅读InfoQ最近的Adobe Flex Basics以对该框架有一个快速的了解。下面是易犯的错误列表:

1. 使用RIA框架去构建Web1.0应用(新技术换汤不换药)。

从Web 1.0到RIA的过渡中最大的挑战之一来自思考方式的转变。Flex给予开发者一个高级的组件库,使其可以完成很多以前不可能完成的任务。但是很多时候,Flex的这种能力被忽略了,它仅仅被用来实现更加传统的Web 1.0应用。

构建Web 2.0应用不仅仅意味着页面的局部刷新和旋转的圆角图标。例如,Flex开发者应使用矢量图向用户提供数据的可视化表示,以及对于富应用流的高级控制。最近Stephan Janssen与InfoQ.com一起讨论了该议题

作为一个Java开发者,对于面向对象的ActionScript和UI标记语言的学习简直就是小菜一碟。但是对于(Java)开发者来说真正的挑战在于我们不是设计师,并且这两个技术对于RIA来说是必不可少的。

2. 破坏标准的浏览器体验

尽管Flex确实提供了一个优秀的平台以改善用户体验,但是保持用户习惯,如后退按钮、书签和自动完成也是相当重要的。

Flex 3包含了新的深层链接特性以支持后退按钮和书签。你可以访问labs.adobe.com来了解更多。那有很多组件能够实现自动完成。你可以使用来自于Adobe Exchange的AutoComplete Input组件。

3. 使用过多的容器导致应用变慢

Flash Player使用了一个按层次显示的对象图,这一点与HTML的文档对象模型(DOM)很相似。容器嵌套的层次越深,渲染所花费的时间就越长。Adobe的Flex开发者中心有一篇文章讨论了关于Flex性能的最佳实践,包括了容器的使用细节:

Flex最大的性能风险来自于对容器的滥用。嵌套太多的容器会影响应用的性能。这是Flex开发者面临的最严重的性能风险——不过还好,它完全能被避免。

4. 使用XML而不是其他更优化的协议导致应用变慢

Flex向开发者提供了多种选择以在Flex客户端和服务器之间进行数据传输,包括AMF3、XML、SOAP及直接的HTTP请求。Ward在他的人口普查应用中阐述了这些技术的使用及性能。

对于后端使用Java的新项目来说,应该考虑一下BlazeDS。BlazeDS是Adobe最近的一个开源数据服务产品,它使用了AMF3协议。AMF是一个二进制传输协议,很容易与Java集成,其性能要优于XML。对于所有主要的后端技术都有相应的AMF开源实现。

如果你不选择BlazeDS,那么你还可以选择Hessian。Hessian对二进制的web services协议提供了ActionScript/Flex支持。

5. 试图雇佣Flex开发者

现在很难找到有经验的Flex开发者。Flex现在正处在上世纪90年代Java所处的位置。Flex开发者已经供不应求了。这就造成了难以寻觅 到有经验的Flex开发者的后果。然而,这给Java开发者创造了一个很好的机会以扩充技能,并且从事一种新兴且有趣的技术。很多寻找Flex开发者的公 司直接对Java或者其他web开发者进行几周的Flex培训,并且大获成功。对于熟悉Web和GUI编程的开发者来说,学习Flex语言和APIs易如反掌。

6. 特效的过度使用

开发者可以很容易地通过Flash增加特效。但是要确保特效有意义并且与上下文是匹配的。否则他们只会让用户反感。特效的时间选择也很重要。交互设计器可以帮助我们决定何时应使用特效,何时不应该使用。交互设计器还能为我们推荐最佳的特效类型、间隔和最简化的功能。

关于特效的使用在laair.org上有一篇好文:

大多数的特效简直太长了。它们不但长,而且还慢,甚至让人反感。关掉它。如果我遇到这种事情的话,我就会转身离去,因为我实在讨厌这种等待。

千万不要误会我,我并不是反对特效。我只是反对为了目的而做的太长或者太过分的特效。每个特效都可以依照其目的进行分解。找到你要特效的目的,然后再使用它。

7. 没有搭建企业生态系统

就像其他的软件项目一样,为于你的Flex应用建立企业生态系统是非常重要的。

测试驱动开发(TDD)在当前是大多数企业项目的首选方案。对于Flex来说,FlexUnit框架可用来编写单元测试。在Adobe的开发者网络上,Neil Webb讨论了面向Flex开发者的TDD及FlexUnit的使用。此外,Flexcover可用来度量代码覆盖率。

当多个开发者协同工作时,持续集成(Continuous Integration)被证明是良好的实践。与Java应用类似,也有相应的Ant和Maven插件对你的Flex应用进行持续集成。

8. 没有使用整个框架

在Adobe Flex中有大量可选的特性,你应该考虑在你的应用中使用它们。例如,运行时共享库(Runtime Shared Libraries,即RSL)可用来减少应用的大小。

你可以将共享资源集成到单独的文件中,这样就可以在客户端单独下载和缓存了,通过这种手段可以减少应用产生 的SWF文件的大小。很多Flex应用可以在运行时加载这些共享资源,而每个客户端只需下载一次即可。这些共享资源叫做运行时共享库(Runtime Shared Libraries)。

框架的另一个特性是内建的辅助功能。你可以通过Adobe在线文档了解更多的关于Flex的辅助功能的信息。除了内建的辅助功能外,框架还提供了对于本地化的内在支持。请访问Adobe新手上路来了解最新的Flex3框架特性。

9. 使用复杂的渲染器降低了DateGrid的速度

针对DataGrid开箱即用的itemRenderer已经有过很好的优化了。误解#3讨论了嵌套过深的容器的性能问题。在Flex中有一个地 方很容易造成容器的深层次嵌套,那就是DataGrid的item渲染器。由DataGrid所渲染的item渲染器数量等于可见的行数乘以可见的列数。 定制的DataGrid和List item渲染器应该经过非常好的优化才行。当需要在item渲染器中使用复杂的布局逻辑时,最好使用UIComponent(或者其他底层类)并且手工完成该单元格内容的定位。

10. 没有准备离线应用。

RIAs的传统模型在于浏览器。然而像Adobe AIRGoogle Gears这 样的技术使得应用可以离线运行。如果用户需要可以离线对应用时而你尚未准备好的话,那将你的应用改为支持离线特性将变得异常困难。典型地,在web应用 中,业务逻辑存在于服务器端。在离线RIAs中,业务逻辑必须转到客户端。为了使应用既支持离线,也支持在线,那就很有必要提前决定某些业务逻辑的位置。

查看InfoQ.com上有关Flex的内容以了解更多。

查看英文原文:Top 10 Mistakes when building Flex Application

分享到:
评论

相关推荐

    Flex_for_PHP_developers_InfoQ.pdf

    通过Adobe AIR,开发者可以将Web应用打包成桌面应用程序,极大地扩展了Flex应用的部署范围。 #### 九、下一步计划 对于希望深入了解Flex的PHP开发者,建议从以下几个方面入手: - **深入学习MXML和ActionScript 3...

    Infoq架构师2016合集

    3. 大数据处理与分析:大数据技术在2016年已经广泛应用,Hadoop、Spark等框架备受关注。合集可能涵盖大数据平台搭建、实时流处理、数据分析工具以及数据安全等内容。 4. 容器技术:Docker作为容器技术的代表,在...

    InfoQ云生态期刊(全套)

    2. **主流云服务商及产品**:InfoQ云生态期刊可能会深度解析各大云服务提供商,如阿里云、亚马逊AWS、微软Azure等,介绍他们的核心产品和服务,以及各自的优势和适用场景。 3. **云技术趋势**:期刊会讨论云计算的...

    infoq架构师月刊下部

    《infoQ架构师月刊下部》集合了2013年至2017年8月期间在infoQ平台上发布的关于架构领域的深度文章和专题,是广大架构师和IT从业者学习、研究架构技术的重要资源。infoQ作为一个全球知名的IT技术交流平台,其内容覆盖...

    infoq_topic

    标题“infoq_topic”可能指的是一个InfoQ技术网站上的专题讨论,这通常涵盖某一特定的IT主题或技术。InfoQ是一个知名的在线平台,提供最新的软件开发资讯、深度文章、会议报道和技术访谈等内容。由于描述是“NULL”...

    infoq系统架构与前沿技术

    10. 大数据处理:Hadoop和MapReduce等技术在2009年正处于快速发展阶段,杂志可能讲解了如何利用这些技术处理大规模数据,以及大数据对业务决策的影响。 通过阅读这期电子杂志,读者不仅可以了解到2009年当时的热门...

    InfoQ架构师月刊 0710

    由于容器化技术可以让数据库更容易地部署和扩展,因此,了解如何在Docker中配置和运行MySQL,对于构建现代的可伸缩应用架构非常重要。 在人工智能(AI)方面,文件提及了“AI专区”,这可能意味着月刊中会有专门的...

    infoq架构师月刊上部

    《infoQ架构师月刊上部》集合了2008年至2012...以上只是《infoQ架构师月刊上部》可能包含的部分知识点,每一篇文章都可能深入探讨了这些主题,提供了丰富的实践案例和专家见解,对提升架构师的专业素养具有极大的价值。

    infoq 架构师8月刊

    infoq 架构师8月刊 infoq 架构师8月刊 infoq 架构师8月刊

    flex 指南 Flex入门 Flex实例 flex图表 flex与java flex中文帮助 flex培训

    Adobe+Flex编码指南.pdf chart.rar--java+flex图表 Flex3高级图表开发指南.pdf--英文的 Flex+白皮书.pdf ...InfoQ Flex与JSON及XML的互操作.mht 结合java做的flex图表例子 - 点点滴滴 - JavaEye技术网站.mht

    InfoQ:软件工程数智化研究报告-可观测应用篇2023.pdf

    【InfoQ:软件工程数智化研究报告-可观测应用篇2023】这份报告深入探讨了在云原生技术、敏捷开发和DevOps理念推动下,软件工程领域的新趋势——可观测性。随着企业对业务灵活性和客户体验的重视,系统稳定性与可靠性...

    infoq 架构师 2019年月刊收集

    infoq 架构师 2019年月刊收集 infoq 架构师 2019年月刊收集

    2019年InfoQ架构师峰会ppt.z01

    ArchSummit北京2019大会演讲 PPT 分共三个压缩包 2019年InfoQ架构师峰会ppt.z01 2019年InfoQ架构师峰会ppt.z02 2019年InfoQ架构师峰会ppt.zip

    InfoQ10月刊

    ### InfoQ10月刊知识点总结 #### 一、乔布斯的影响与遗产 - **个人简介**:乔布斯,苹果公司的联合创始人之一,以其卓越的领导力和对产品设计的独特见解闻名于世。 - **科技界反应**:乔布斯去世后,全球科技界...

    Scala在挖财的应用实践-infoq.zip

    Scala,一种多范式编程语言,融合了面向对象和函数式编程的概念,因其强大的表达性和高性能,近年来在金融科技领域,尤其是大数据处理和分布式计算中得到了广泛应用。挖财,作为国内知名的金融科技公司,利用Scala的...

    架构设计from infoQ

    - **使用ADOBE FLEX进行模型驱动开发**:介绍了如何利用ADOBE FLEX进行高效的模型驱动开发,展示了该工具在提高开发效率和代码质量方面的潜力。 - **SOAP基于JAVA消息服务**:探讨了SOAP协议在JAVA消息服务中的应用...

    InfoQ研究中心:2023中国人工智能成熟度模型报告(1).pdf

    InfoQ研究中心:2023中国人工智能成熟度模型报告(1).pdf

    InfoQ_ArchSummit全球架构师峰会

    《InfoQ_ArchSummit全球架构师峰会_Day1_rebuilt》是InfoQ组织的一场专注于架构设计和技术领导力的盛会。这场会议汇集了全球顶尖的架构师、技术领导者和行业专家,共同探讨和分享了关于软件架构设计的最新趋势、最佳...

    FLEX入门实例--------各种Effect的综合运用

    Flex是一个开源框架,用于构建富互联网应用程序(RIA),它基于ActionScript和MXML语言。本教程可能着重于如何在Flex项目中集成和操控各种特效,以提升用户体验。 描述中的"项目文件,运行看效果"表明这是一个包含...

Global site tag (gtag.js) - Google Analytics