Flex_SDK编码规范及最佳实践

Flex SDK 编码规范及最佳实践

注意:本文档目前还不完整且有些部分以TBD(待讨论) 标记, 但这对于起步已经足够了!

引言

这篇文档拟定了用AS3编写开源Flex 框架组件的编码规范. 遵照这些规范可以使得源代码看起来组织良好, 风格一致并且更加专业. 其中有些规范是很任意的, 因为并非总存在一种”最好方式”来编码. 然而, 为了照顾一致性的

要求, 所有付诸Flex SDK的项目都将遵循这些编码规范.

目录

命名

∙ 缩写词 缩略语 单词定界 类型指定名 包名 文件名 命名空间名 接口名 类名 事件名 样式名 字符串属性枚举值 常量名 属性 (变量和ge tter/setter) 名 存储变量名 方法名 事件处理方法名 参数名 资源包名 资源键名 杂项名

语言用法

编译选项 基于属性的 APIs 类型定义 Literals Expressions

∙ Declarations

文件组织

格式化

Copyright notice package statement import statements use namespace statement Class metadata Class declaration include statement for Version.as Implementation notes Class initialization Class constants Class mix-ins Class resources Class variables Class properties Class methods Constructor Variables Overridden properties Properties Overridden methods Methods Overridden event handlers Event handlers Out-of-package helper classes Line width Indentation Section separators Separation of declarations Metadata Array indexing Commas Array literals Object literals Function literals Type declarations Operators and assignments Statements

∙ Function declarations Function calls if statements for statements switch statements class and interface declarations

ASDoc 文档

∙ Property comments

命名

缩写词

作为通用规则而避免使用. 例如calculateOptimalValue()比calcOptVal()的命名方式更优. ∙

∙ acc 代表 accessibility, 比如 ButtonAccImpl auto 代表automatic, 比如autoLayout eval 代表evaluate, 比如EvalBindingResponder impl 代表implementation, 比如ButtonAccImpl info 代表information, 比如GridRowInfo num 代表number of, 比如numChildren min 代表minimum, 比如minWidth max 代表maximum, 比如maxHeight nav 代表navigation, 比如NavBar regexp 代表regular expression, 比如RegExpValidator util 代表utility, 比如StringUtil

编码时采用合适的命名既便于使用且理解起来也更为容易. 所以你得在选择好的命名方式二多费心力, 特别是针对公共API 提供出来的时候.

我们的命名规范绝大部分和ECMAScript 和Flash Player 9 是一致的.

表意明确比为了少敲几下代码而采用缩写更为重要. 如果你不使用缩写, 开发人员就不用非得记住你是否采用了单词简写, 如把”qualified ”简写成”qual ”或”qlfd ”.

不过, 我们已经标准化了一些缩写词:

上述列表可能没有包含目前使用的所有缩写词. 如果你用到了上面没有列举出来的缩写词, 请搜索源代码看是否已经有相应的缩写词使用了. 如果没发现, 再考虑一下如果缩写是否合适.

在Flex 中有各种缩略语,像AIR, CSS, HLOC, IME, MX, MXML, RPC, RSL, SWF, UI, UID, URL, WSDL, 和XML 之类。

一条缩略语要么全部大写要么全部小写(e.g. SWF 或swf ,但不会是Swf )。使用全部小写的缩略语形式是当使用本身作为标识符或者作为某个标识符的开头,以及标识符需用小写字母开头时。可以参照一下关于标识符到底以大写还是小写开头的规则一条缩略语要么全部大写要么全部小写(e.g. SWF 或swf ,但不会是Swf )。使用全部小写的缩略语形式是使用本身作为标识符或者作为某个标识符的开头,标识符必须以小写字母开头。可以参照一下关于标识符到底以大写还是小写开头的规则.

有时候由于不清楚一个单词组合是不是已经成为一个独立的新词了,所以这种情况下会出现不一致的情况:deopdown , popUp ,popUp 。

常常, 对象最简单的名字就是它本身的类型,当然要采取和类型名不同的大小写方式。 以小写字母开头然后接下来的单词采用首字母大写:controls ,listClasses 。

包名总是名词或动名词(动词-ing 的名词形式),而非动词,连词或副词。

对于重要的APIs, 文件名必须要和公共API 内部的名字一致。但是包含文件必须要遵从这个规则:

常量值如果是string 类型的,那么它的value 要和常量名保持一致:

如果一个类重写了一个getter/setter,但还想继续公开基类的getter/setter,它就得单独用一个属性,属性吗为基类中属性名前加一个前缀$. 这个getter/setter要以final 标记且不做任何额外的coding 除了调用super getter/setter.

方法名应当总是动词

如果一个类重写了一个方法,但还想继续公开基类的方法, 它就得单独实现一个方法,方法名为基类中方法名前加一个前缀$. 这个method 要以final 标记且不做任何额外的coding 除了调用supermethod.

避免“object” 因为它意义模糊.

一个 “item” 是一个data item, 而不是一个DisplayObject.

一个“renderer” 是一个显示data item的 DisplayObject.

一个“type” 一个AS3 类型; 否则使用 "kind".

这部分我们将讨论如何使用AS3的语言构造,尤其当同一事物存在多种表述手段时。

建议使用基于属性的APIs 而不是基于方法的APIs 因为这些更加适合声明式的MXML 编程 为每个常量,变量,函数参数以及函数返回值甚至如果简单地使用:*表明“无类型”。 如果你声明Array 类型的变量, 你得添加一个/* of ElementType */形式的注释紧接着Array 表明该数组元素的类型。未来版本的语言可能会支持这种类型化的数组。

不要在integar 中使用小数点。.

RGB 颜色值总是采用这种6位十六进制数表示。

如果一个Number 值可以是小数, 则一般要加上一个小数点并补上0,即使实际值是个整数值

不过, 对于像素坐标即使是小数形式, 也最好使用整数值表示它.

使用引号标记(双引号), 而不是撇号(单引号) 限定字符串, 即使那个字符串包含一个引号作为其内部某个字符.

避免使用函数文本定义匿名函数; 使用一个类方法或包函数替代

如果你必须使用函数文本, 声明一个返回类型, 在函数体内用一个分号终止最后一条语句. 使用字面值而不是一个字符串构造的RegExp 实例.

使用字面值而不是XML 构造函数形式.U

对于XML 属性值使用双引号括起来:

仅当存在导入类型歧义时才采用类名的全路径形式声明一个类..

对于常用操作符如such as +, -, *, /, &&, ||, , >=, ==, and !=不要使用不必要的括号.

各个操作符的优先级很难记住, 所以我们可以运用括号就会十分有用了.

不要将Boolean 值和true 和false 比较, 因为它的值必然是其中之一.

很显然强制转换Number,String,XML,XMLList,Array,Object 或者*为Boolean ,转换错误会有多个值我们很难记住。

让Object 类型的子类(例如UIComponent )转换为Boolean ,因为很明显仅仅null 值表示转换失败,其他情况则是转换成功(注意:Object 及其子类无法存储undefined 值)。 对于int 和uint ,很明显只有0值表示false ,其他都为true 。所以如果你想要使用显式转换,将其与0比较是没有任何问题的,但是阅读不便。

偏向于塑型作为一个操作符,这个主要为了防止强制类型转换错误评估为null ,而不是抛出一个异常。

比较表达式最好以易读的方式书写:

为了防止前缀和后缀形式相同,使用后缀形式。如果想要提前使用变量值而不是增加/减少的值可以使用前缀形式

用条件运算符代替if/else形式,特别是想要检验是否有null 值时:

主要最好不要将多个条件运算符代替复杂的if/else逻辑结构。

使用括号紧随类型引用,即使这个类的构造函数不带任何参数。

每条语句后面都要接一个分号,虽然在AS 3中并没有这个强制要求.

使用相对路径而不是绝对路径。

导入特定类,接口和其他包级的函数而不是*通配符。

避免使用它们; 使用 ::语法提到syntax instead on each reference to something in a non-open namespace.

如果if/else的不同分支涉及到单条语句,不需要大括号包含它.

但是如果有多条语句时可以将大括号包含起来。

如果测试多个error 检查,可以使用一系列if 语句段测试错误并提前返回。正确的执行流放到最后返回true 。不要使用嵌套的if 语句来判断,这样会导致执行流整个块中都有. 即使for 语句块只有一条语句也要用大括号括起来。

对于上限我们用一个单独的变量来存储,这样不会使得每次判断的时候都要重复计算。 在循环括号里面声明循环变量,除非其他地方要用到这个变量

即使只有一条语句也要用括号括起来.

即使一条语句也要括起来t.

将每一个case 子句作为一个块,包括default 子句。将break 和return 语句置于块中。将default 子句也当做case 子句;避免出现case 穿透问题。

不需要将返回值用括号括起来.

从方法体中部返回也是可以的

不要在同一行声明多个变量或常量。

在需要访问限定的地方放置上访问限定符。不要不写,虽然这样表示默认的访问限定internal 。

在构造public 或者protected 的API 时,仔细想想是否需要这样做。Public 和protected 的APIs 必须进行文档化。在正式被终止之前需要支持好几个发布版本。

如果存在,请将这个关键字放在访问限定符之后。

如果存在,将它放在访问限定符后面。

所有的常量应该是static 的。不应将一个实例声明为常量,应该所有的哦实例将使用同样的值。

如果变量需要初始化为一个值,而不是使用默认值,在声明变量的时候就初始化而不用等到构造函数里面再初始化。

如果一个类简单地继承自Object ,不用显示写出extends Object子句。

如果一个类有实例变量,要书写一个构造函数,显示使用super(),即使它没做任何事情。 不要在构造函数中设置类实例变量;在实例声明时就初始化。不过,如果你需要重置从父类实例中继承的变量值,可以在构造函数中做。

在包语句中中的公共API (常常是一个类,有时是一个明明空间或函数)

帮助类

空语句。

这部分主要阐释Flex 框架文件应当如何组织.

在框架文件下每一个as 文件头部都应包括一个版权声明. 下面给出2008版开源版本的格式:

将类中元数据按Events,Styles,Effects,Excluded IPIs和其它元数据顺序分成几个部分. 在每个部分前面加一个小的说明头. 注意每个说明头是40个字符宽度在//和其后 区块名之间有两个空格.

每个区块将元数据名”…”按字母表顺序排列出来. 在其他元数据区块,将元数据标签名按字母表顺序列出。

将静态常量声明置于此。

ActionScript 3 不允许常量具有Array or Object类型. 声明那种常量使用static var而不是static const。将它们放在这个部分因为概念上它们也属于常量。

将任何Function 类型声明为静态变量而不是声明为方法减小类大小。

声明静态getters 和setters ,然后将它们按字母表顺序排列。使用

Declare static getters and setters here. Order them alphabetically by property name. Use a minor separator with the property name for each one. Put the getter before the setter.

Only document the first function of a get/set function pair for a property. The idiom for defining and documenting a property is:

有时我们(故意) 采用的缩写词不一致. 例如, 我们在很多时候都会拼写”horizontal ”和”vertical ”,像horizontalScrollPolicy 和 verticalScrollPolicy 。但是我们在常规容器类名

VBox 中却将它们缩写成了H 、V , HBox 和

缩略语

和缩略语有关的标识符有CSSStyleDeclaration , IUID , uid , IIME 和imeMode .

单词定限

当标识符包含多个单词时,我们采用两种方式表明单词界限:单词首字母大写 (比如 LayoutManager 、measuredWidth ) 和下划线连接 (比如object_proxy). 具体采用哪种方式请参照一下规则:.

即使出现两个缩略语相邻时也要遵循首字母大小写的规则。loadCSSURL()就是一个很符合这种情形的例子(实际上很少使用)。但是尽量避免使用那样的名字。

类型指定名

如果你想要在命名中纳入类型标示,将类型作为最后一个“词”。If you want to incorporate the type into the name, make it the last “word”. 不要使用ACTIONSCRIPT 1的类型连接后缀如_mc表明类型。例如,命名一个border shape,可以是border ,borderSkin 或borderShape ,但不是border_mc.

var button:Button = new Button();

包名

实现了许多相似东西的包的包名要采用该类事物的复数形式:: charts , collections , containers , controls , effects , events , formatters , managers , preloaders , resources , skins , states , styles , utils , validators .

对于实现了某种概念的包一般用动名词的形式: binding , logging , messaging , printing . 否则, 它们通常只是 " 概念名词 ": accessibility , core , graphics , rpc .

一个包含支持FooBar 组件的类应当命名为fooBarClasses .

文件名

对于含一个大写字母的元数据[Style(...)] 包含文件的文件名,后续单词采用首字母大写且将最后单词写为”sytles ”: BorderStyles.as , ModalTransparencyStyles.as .

以全部小写字母并且下划线进行单词连接的形式来命名个人资产文件: icon_align_left.png.

命名空间名

已全部小写字母并且消化腺进行单词连接的形式命名: mx_internal, object_proxy.

接口名

以I 开头并且后续单词使用首字母大写的形式: IList , IFocusManager , IUID .

类名

大写字母开头后续单词首字母大写: Button, FocusManager, UIComponent .

Event 子类命名 FooBarEvent .

Error 子类命名FooBarError .

Name the EffectInstance subclass associated with effect FooBar FooBarInstance . Formatter 子类命名FooBarFormatter .

Validator 子类命名FooBarValidator .

FooBarBackground , FooBarBorder , FooBarSkin , FooBarIcon ,

FooBarIndicator , FooBarSeparator , FooBarCursor 等. 外观类命名

工具类命名 FooBarUtil (不是 FooBarUtils ; 包名复数但类名要用单数).

常用基类命名方式 FooBarBase : ComboBase , DateBase , DataGridBase , ListBase .

事件名

小写字母开头并且后续单词首字母大写: "move" , "creationComplete" .

样式名

小写字母开头并且后续单词首字母大写: color , fontSize .

字符串属性枚举值

小写字母开头并且后续单词首字母大写: "auto" , "filesOnly" ,

常量名

全部大写且单词采用下划线连接: OFF , DEFAULT_WIDTH.

public static const FOO_BAR:String = "fooBar";

属性(变量和getter/setter) 名

小写字母开头并且后续单词首字母大写: i , width , numChildren .

使用i 作为for 循环的外层循环索引值,n 作为其上限值. 使用j 作为for 循环的内层循环索引值,m 作为其上限值.

for (var i:int = 0; i

for (var j:int = 0; j

...

}

}

使用 p (表示 “property”) 作为for-in 循环变量:

for (var p:String in o) {

...

}

mx_internal final function get $numChildren():int{

return super.numChildren;

}

存储变量名

替getter/setter foo命名一个存储变量名_foo.

方法名

小写字母开头并且后续单词首字母大写: measure(), updateDisplayList().

不带参数的方法不应当采取getFooBar() 或 setFooBar()命名形式, 而应设计成getter/setter。 不过,

getFooBar()是一个需要大量计算的缓慢方法, 应当将其命名为findFooBar(), calculateFooBar(), determineFooBar()等. 而不是一个ge tter. 如果

mx_internal final function

$addChild(child:DisplayObject):DisplayObject{

return super.addChild(child);

}

事件处理方法名

事件处理程序名应当在事件类型后面连接一个 “Handler”: mouseDownHandler().

如果处理程序是服务于派发给子控件的事件 (i.e., not this ), 在处理程序名前面加一个子控件名前缀然后以下划线后处理程序名组合: textInput_focusInHandler().

参数名

对任何setter 的参数使用value 作为参数名:

这样做:

public function set label(value:String):void

而不是:

public function set label(lab:String):void

或者这样做:

public function set label(labelValue:String):void

或者这样做:

public function set label(val:String):void

使用 event (而非 e , evt , or eventObj ) 作为每个事件处理程序的参数:

protected function mouseDownHandler(event:Event):void

资源包名

如果一个资源包名包含特定包的资源,应该以相同的名字命名这个资源包: controls , {formatters}}, validators .

资源键名

小写字母开头且后续单词首字母大写: pm , dayNamesShort .

杂项名

语言使用

编译选项

采用-strict and -show-actionscript-warnings 编译选项进行编译. (在flex-config.xml 文件中会有一些缺省值.)

基于属性的APIs

类型定义

这样做:

var value:*;

而不是这样:

var value;

使用合适的最紧致的类型。例如,循环变量索引应当是int 型,不是Number 型,当然更不会是Object 或*.另一个例子,mouseDownHandler 应当声明一个参数 event:MouseEvent, 而不是event:Event.

整型数使用int , 即使它不是负数. 使用uint 作为 RGB 颜色值, 位掩码和其他非数字值.

使用 *仅在该值没有定义的情况下. 你应当通常使用Object 而不是*You should generally use Object rather than *, 具有null 代表“对象不存在”值.

这样做:

var a:Array /* of String */ = [];

而不是这样:

var a:Array = [];

这样做:

function f(a:Array /* of Number */):Array /* of Object */

{

...

}

而不是这样:

function f(a:Array):Array

文本

undefined

避免使用如果可能的话。仅仅是在编译时变量的类型是*,It is only necessary when dealing with values whose compile-time is type is *, and you should be using * sparingly as well.

int /uint

这样做:

2

而不是这样:

2.

十六进制数使用一个小写字母x 和大写字母 A-Z 。

这样做:

0xFEDCBA

而不是这样:

0Xfedcba

这样做:

private const BLACK:uint = 0x000000;

而不是这样:

private const BLACK:uint = 0;

Number

这样做:

alphaFrom = 0.0;

alphaTo = 1.0;

而不是这样:

alphaFrom = 0;

alphaTo = 1;

这样做:

var xOffset:Number = 3;

而不是这样:

var xOffset:Number = 3.0;

指数表示法表示数字时使用 e , 而不是 E .

这样做:

1.0e12

而不是这样:

1.0E12

使用值NaN 作为非Number 类型的缺省值值.

String

这样做:

"What's up, \"Big Boy\"?"

而不是这样:

'What\'s up, "Big Boy"?'

使用\u, not \U, 作为Unicode 转义字符序列.

Array

使用数组文本而非new Array().

这样做:

[]

而不是这样:

new Array()

这样:

[ 1, 2, 3 ]

而不是:

new Array(1, 2, 3)

使用Array 构造函数仅仅是作为预留数组大小时, 比如new Array(3), 意为[ undefined, undefined, undefined ], not [ 3 ].

Object

使用Object 文本而非new Object().

这样做s:

{}

而不是这样:

new Object()

这样做:

o = { a: 1, b: 2, c: 3 };

而不是这样:

o = new Object();

o.a = 1;

o.b = 2;

o.c = 3;

或这样:

o = {};

o.a = 1;

o.b = 2;

o.c = 3;

Function

这样做s:

function(i:int):void { doIt(i - 1); doIt(i + 1); }

而不是这样:

function(i:int) { doIt(i - 1); doIt(i + 1) }

RegExp

这样做:

var pattern:RegExp = /\d+/g;

而不是这样:

var pattern:RegExp = new RegExp("\\d+", "g");

XML and XMLList

这样:

var node:XML = ;

而不是这样:

var node:XML = new XML(""); 这样做:

var node:XML = ;

而不是这样:

var node:XML = ;

Class

这样做:

import mx.controls.Button;

...

var b:Button = new Button();

而不是这样:

import mx.controls.Button;

...

var b:Button = new mx.controls.Button(); 但下面这种情况下使用全限定名才是合适的.:

import mx.controls.Button;

import my.controls.Button;

...

var b:Button = new mx.controls.Button();

表达式

括号

这样做:

var e:Number = a * b / (c + d);

而不是这样:

var e:Number = (a * b) / (c + d);

这样做:

var e:Boolean = a && b || c == d;

而不是这样:

var e:Boolean = ((a && b) || (c == d)); 强制转换

这样做:

if (flag)

而不是这样:

if (flag == true)

这样做:

var flag:Boolean = a && b;

而不是这样:

var flag:Boolean = (a && b) != false;

这样做:

if (s != null && s != "")

而不是这样:

if (s)

这样做:

if (child)

而不是这样:

if (child != null)

这样做:

if (!child)

而不是这样做:

if (child == null)

这样做:

IUIComponent(child).document

而不是这样s:

(child as IUIComponent).document

比较

这样做:

if (n == 3) // "if n is 3"

而不是这样做:

if (3 == n) // "if 3 is n"

++ /-- 操作符

这样做:

for (var i:int = 0; i

而不是这样:

for (var i:int = 0; i

条件运算符

这样做:

return item ? item.label : null;

而不是这样:

if (!item)

return null;

return item.label;

这样做:

if (a

return -1;

else if (a > b)

return 1;

return 0;

而不是这样:

return a b ? 1 : 0);

new 运算符

这样做:

var b:Button = new Button();

而不是这样:

var b:Button = new Button;

语句

这样做:

a = 1;

b = 2;

c = 3;

而不是这样:

a = 1

b = 2

c = 3

include 语句

使用include 而不是#include. 也像其他语句一样后面加个分号结束. 这样做:

include "../core/ComponentVersion.as"; 而不是这样做:

#include "../core/ComponentVersion.as" Import 语句

这样做:

import mx.controls.Button;

import flash.utils.getTimer;

而不是这样:

import mx.core.*;

use namespace语句

这样做:

import mx.core.mx_internal;

// Later, in some method... mx_internal::doSomething(); 而不是这样:

import mx.core.mx_internal; use namespace mx_internal;

// Later, in some method... doSomething();

if 语句

这样做:

if (flag)

doThing1();

而不是这样:

if (flag)

{

doThing1();

}

这样做:

if (flag)

doThing1();

else

doThing2():

而不是这样:

if (flag)

{

doThing1();

}

else

{

doThing2();

}

这样做:'

if (flag)

{

doThing1();

}

else

{

doThing2();

doThing3();

}

而不是这样:

if (flag)

doThing1();

else

{

doThing2();

doThing3();

}

这样做:

if (!condition1)

return false;

...

if (!condition2)

return false;

...

if (!condition2)

return false;

...

return true;

而不是这样:

if (condition1)

{

...

if (condition2)

{

...

if (condition3)

{

...

return true;

}

}

}

return false;

for 语句

这样做:

for (var i:int = 0; i

{

doSomething(i);

}

而不是这样:

for (var i:int = 0; i

doSomething(i);

这样做:

var n:int = a.length;

for (var i:int = 0; i

{

...

}

而不是这样:

for (var i:int = 0; i

{

...

}

这样做:

for (var i:int = 0; i

而不是这样:

var i:int;

for (i = 0; i

{

...

}

while 语句

这样做:

while (i

{

doSomething(i);

}

而不是这样:

while (i

doSomething(i);

do 语句

这样做:

do

{

doSomething(i);

}

while (i

而不是这样:

do

doSomething(i);

while (i

switch 语句

这样做:

switch (n)

{

case 0:

{

foo();

break;

}

case 1:

{

bar();

return;

}

case 2:

{

baz();

return;

}

default:

{

blech();

break;

}

}

而不是这样:

switch (n)

{

case 0:

foo();

break;

case 1:

{

bar();

}

break;

case 2:

baz();

return;

break;

default:

blech();

}

return 语句

这样做:

return n + 1;

而不是这样做:

return (n + 1);

声明

这样做:

var a:int = 1;

var b:int = 2;

而不是这样:

var a:int = 1, b:int = 2;

override 关键字

如果存在重载的情况,请将这个关键字放在第一位,在访问限定符前面。

这样做:

override protected method measure():void

而不是这样:

protected override method measure():void

访问限定符

Static 关键字

这样做:

public static const MOVE:String = "move"

而不是这样:

static public const MOVE:String = "move";

final 关键字

这样做:

public final class BoxDirection

而不是这样:

final public class BoxDirection

将所有“枚举类”声明为final 型的。

也常常将“基本”属性和方法(以$开头)为final 类型。

常量

这样做:

public static const ALL:String = "all";

而不是这样:

public const ALL:String = "all";

变量

这样做:

private var counter:int = 1;

而不是这样做:

private var counter:int;

...

public function MyClass()

{

super();

...

counter = 1;

}

局部变量

内部变量在使用的时候才进行声明,而不要都放在函数开始时。

这样做:

private function f(i:int, j:int):int

{

var a:int = g(i - 1) + g(i + 1);

var b:int = g(a - 1) + g(a + 1);

var c:int = g(b - 1) + g(b + 1);

return (a * b * c) / (a + b + c);

}

而不是这样做:

private function f(i:int, j:int):int

{

var a:int;

var b:int;

var c:int;

a = g(i - 1) + g(i + 1);

b = g(a - 1) + g(a + 1);

c = g(b - 1) + g(b + 1);

return (a * b * c) / (a + b + c);

}

Declare local variables only one per function. ActionScript 3 doesn't have block-scoped locals.

Do this:

var a:int;

if (flag)

{

a = 1;

...

}

else

{

a = 2;

...

}

Not this:

if (flag)

{

var a:int = 1;

...

}

else

{

var a:int = 2;

...

}

And this:

var i:int;

for (i = 0; i < n; i++)

{

...

}

for (i = 0; i < n; i++)

{

...

}

Not this:

for (var i:int = 0; i < n; i++)

{

...

}

for (var i:int = 0; i < n; i++)

{

...

}

The only “bare statements” in a class should be calls to static class initialization methods, such as loadResources().

构造函数

如果构造函数参数对应于实例变量,参数名可以使用与实例名同样的名字。

这样做:

public function MyClass(foo:int, bar:int)

{

this.foo = foo;

this.bar = bar;

}

而不是这样做:

public function MyClass(fooVal:int, barVal:int)

{

foo = fooVal;

bar = barVal;

}

接口

TBD

命名空间

TBD

实现属性

TBD

元数据

TBD

文件组织

版权声明

//////////////////////////////////////////////////////////////////////////////

//

// ADOBE SYSTEMS INCORPORATED

// Copyright 2008 Adobe Systems Incorporated

// All Rights Reserved.

//

// NOTICE: Adobe permits you to use, modify, and distribute this file // in accordance with the terms of the license agreement accompanying it.

//

////////////////////////////////////////////////////////////////////////////////

注意每一行最多包含80个字符.

包语句

TBD

导入语句

TBD

使用命名空间语句

TBD

Class 元数据

//--------------------------------------

// Events

//--------------------------------------

/

**

* ASDoc comment.

*/

[Event

/**

* ASDoc comment.

*/

[Event

//--------------------------------------

// Styles

//--------------------------------------

/**

* ASDoc comment.

*/

[Style

/**

* ASDoc comment.

*/

[Style]

//--------------------------------------

// Effects

//--------------------------------------

/**

* ASDoc comment.

*/

[Effect

/**

* ASDoc comment.

*/

[Effect]

//--------------------------------------

// Excluded APIs

//--------------------------------------

[Exclude(name="horizontalAlign", kind="style")]

[Exclude(name="verticalAlign", kind="style")]

//--------------------------------------

// Other metadata

//--------------------------------------

[DefaultBindingProperty(source="text",

destination="text")]

[IconFile("Text.png")]

Class 声明

TBD

Version.as include语句

每个类应当使用相对路径包含core/Version.as.这个文件包含static const VERSION:String声明.

include "../core/Version.as";

实现注释

TBD

类初始化

TBD

类常量

类最小化

类资源

TBD

类变量

TBD

类方法

放置静态方法声明.

构造函数

TBD

变量

TBD

重载属性

Put overrides of non-static getters and setters here. Order them alphabetically by property name. Use a minor separator with the property name for each one. Put the getter before the setter.

属性

Put new non-static getters and setters here. Order them alphabetically by property name. Use a

minor separator with the property name for each one. Put the getter before the setter.

重载方法

Put overrides of non-static functions here.

方法

Put new non-static functions here.

重载事件处理函数

Put overrides of event handlers here.

事件处理函数函数

Put new event handlers here.

包外帮助类

TBD

格式化

This section covers how a Flex framework class should be formatted.

Wrap code to 80-character lines. This has the following advantages:

∙ Developers with smaller screens don't have to scroll horizontally to read long lines. A comparison utility can display two versions of a file side-by-side. The font size can be increased for projection before a group without requiring scrolling.

∙ The source code can be printed without clipping or wrapping.

缩进

Use 4-space indentation. Configure your text editor to insert spaces rather than tabs. This allows another program that uses a different indentation setting, such as Notepad with its 8-character

indents, to display the code without disfiguring it. Section separators

The major section separators inside a class look like this:

//--------------------------------------------------------------------------

//

// Overridden methods

//

//--------------------------------------------------------------------------

They extend from column 4 through column 80. The text is indented to column 8.

The minor section separators inside a class, such as between properties, look like this: //----------------------------------

// visible

//----------------------------------

They extend from column 4 through column 40. The text is indented to column 8.

Put a single blank line above and below the separators. Separation of declarations

Use a single blank line as a vertical separator between constant, variable, or function declarations. /**

* @private

* Holds something.

*/

var a:Number;

/**

* @private

*/

var b:Number Metadata

TBD

Do this:

Inspectable[a="1", b="2"]

Not this:

Inspectable[a=1 b=2] Array indexing

Don't put any spaces before or after the left bracket or before the right bracket.

Do this:

a[0]

Not this:

a[ 0 ] Commas

Follow a comma with a single space. This applies to argument lists, array literals, and object

literals. Array literals

Put a single space after the left bracket and a single space before the right bracket, and put a single

space after (but none before) each comma.

Do this:

[ 1, 2, 3 ]

Not these:

[1, 2, 3]

[1,2,3]

An empty array is a special case.

Do this:

[]

Not this:

[ ]

Format lengthy array initializers requiring multiple lines with aligned brackets:

static var numberNames:Array /* of String */ =

[

"zero",

"one",

"two",

"three",

"four",

"five",

"six",

"seven",

"eight",

"nine"

]; Object literals

Put a single space after the left brace and a single space before the right brace, and put a single

space after the colon separating the property name and value.

Do this:

{ a: 1, b: 2, c: 3 }

Not these:

{a: 1, b: 2, c: 3}

{a:1, b:2, c:3}

{a:1,b:2,c:3}

An empty Object is a special case.

Do this:

{}

Not this:

{ }

Format lengthy object initializers requiring multiple lines with aligned braces:

private static var TextStyleMap:Object =

{

color: true,

fontFamily: true,

fontSize: true,

fontStyle: true,

fontWeight: true,

leading: true,

marginLeft: true,

marginRight: true,

textAlign: true,

textDecoration: true,

textIndent: true

}; Function literals

TBD

var f:Function;

f = function():void

{

doSomething();

};

Type declarations

Don't put any spaces before or after the colon that separates a variable, parameter, or function

from its type.

Do this:

var n:Number;

Not these:

var n : Number;

var n: Number;

And this:

function f(n:Number):void

Not these:

function f(n : Number) : void

function f(n: Number): void Operators and assignments

Put a single space around the assignment operator.

Do this:

a = 1;

Not this:

a=1;

Put a single space around infix operators.

Do this:

a + b * c

Not this:

a+b*c

Put a single space around comparison operators.

Do this:

a == b

Not this:

a==b

Don't put any spaces between a prefix operator and its operand.

Do this:

!o

Not this:

! o

Don't put any spaces between a postfix operator and its operand.

Do this:

i++

Not this:

i ++ Statements

Start each statement on a new line, so that you can set a breakpoint on any statement.

Do this:

a = 1;

b = 2;

c = 3;

Not this:

a = 1; b = 2; c = 3;

Align the braces of statement blocks.

Do this:

function f():void

{

var n:int = numChildren;

for (var i:int = 0; i

{

if ()

{

x = horizontalGap * i;

y = verticalGap * i;

}

}

}

Not this:

function f():void {

var n:int = numChildren;

for (var i:int = 0; i

if () {

x = horizontalGap * i;

y = verticalGap * i;

}

}

} Constant and variable declarations

TBD Function declarations

TBD

Do this:

f(a, b)

''Not these:''

f(a,b)

f( a, b )

If the parameters have to wrap, indent the subsequent lines after the left parenthesis. Put multiple parameters per line if they fit. Otherwise, put one per line. If even one won't fit, put the first one

on the second line, indented past the beginning of the function name.

public function foo(parameter1:Number, parameter2:String,

parameter3:Boolean):void

public function foo(parameter1:Number,

public function aVeryLongFunctionName(

parameter1:Number, parameter2:String,

parameter3:Boolean):void Function calls

TBD

Do this: parameter2:String, parameter3:Boolean):void

f(a, b)

Not these:

f(a,b)

f( a, b )

if statements

Follow the if keywords with a single space before the left parenthesis. Don't put any spaces after

the left parenthesis or before the right parenthesis.

Do this:

if (a

Not these:

if(a

if( a

if ( a

else if ?

multiline ?

for statements

Follow the for keyword with a single space before the left parenthesis. Don't put any spaces after

the left parenthesis or before the right parenthesis.

Do this:

for (var i:int = 0; i

Not these:

for(var i:int = 0; i

for( var i:int = 0; i

for ( var i:int = 0; i

If the for clause needs to wrap, indent the subsequent lines after the left parenthesis. for (var aLongLoopVariableName:int = aLongInitialExpression;

aLongLoopVariableName

aLongLoopVariableName++)

switch statements

Follow the switch keyword with a single space before the left parenthesis. Don't put any spaces

after the left parenthesis or before the right parenthesis.

Do this:

switch (n)

Not these:

switch(n)

switch( n )

switch ( n )

Follow the switch keyword with a single space before the left parenthesis. Don't put any spaces

after the left parenthesis or before the right parenthesis.

Do this:

switch (n)

{

case 1:

{

a = foo();

break;

}

case 2:

{ a = bar();

break;

}

default:

{

a = blech();

break;

}

}

Not these:

switch(n)

switch( n )

switch ( n )

class and interface declarations

braces are always balanced

no braces around single lines

single statement per line

ASDoc 文档

属性注释

/**

* @private

* The backing variable for the property.

*/

private var _someProp:Foo;

/**

* Place all comments for the property with the getter which is defined first.

* Comments should cover both get and set behavior as appropriate. */

public function get someProp():Foo

{

...

}

/**

* @private

*/

public function set someProp(value:Foo):void

{

...

}

Also, ASDoc comments are applied to metadata tags as well as other constructs within a class so take care that your comments apply to the proper target. If you tag a property as Bindable, your

property comment must precede the get function, not the Bindable metadata tag.

Do this:

[Bindable("somePropChanged")]

/**

* Comments for someProp

*/

public function get someProp():Foo

Not this:

/**

* Comments for someProp

*/

[Bindable("somePropChanged")]

public function get someProp():Foo

http://opensource.adobe.com/wiki/display/flexsdk/Coding+Conventions

Flex SDK 编码规范及最佳实践

注意:本文档目前还不完整且有些部分以TBD(待讨论) 标记, 但这对于起步已经足够了!

引言

这篇文档拟定了用AS3编写开源Flex 框架组件的编码规范. 遵照这些规范可以使得源代码看起来组织良好, 风格一致并且更加专业. 其中有些规范是很任意的, 因为并非总存在一种”最好方式”来编码. 然而, 为了照顾一致性的

要求, 所有付诸Flex SDK的项目都将遵循这些编码规范.

目录

命名

∙ 缩写词 缩略语 单词定界 类型指定名 包名 文件名 命名空间名 接口名 类名 事件名 样式名 字符串属性枚举值 常量名 属性 (变量和ge tter/setter) 名 存储变量名 方法名 事件处理方法名 参数名 资源包名 资源键名 杂项名

语言用法

编译选项 基于属性的 APIs 类型定义 Literals Expressions

∙ Declarations

文件组织

格式化

Copyright notice package statement import statements use namespace statement Class metadata Class declaration include statement for Version.as Implementation notes Class initialization Class constants Class mix-ins Class resources Class variables Class properties Class methods Constructor Variables Overridden properties Properties Overridden methods Methods Overridden event handlers Event handlers Out-of-package helper classes Line width Indentation Section separators Separation of declarations Metadata Array indexing Commas Array literals Object literals Function literals Type declarations Operators and assignments Statements

∙ Function declarations Function calls if statements for statements switch statements class and interface declarations

ASDoc 文档

∙ Property comments

命名

缩写词

作为通用规则而避免使用. 例如calculateOptimalValue()比calcOptVal()的命名方式更优. ∙

∙ acc 代表 accessibility, 比如 ButtonAccImpl auto 代表automatic, 比如autoLayout eval 代表evaluate, 比如EvalBindingResponder impl 代表implementation, 比如ButtonAccImpl info 代表information, 比如GridRowInfo num 代表number of, 比如numChildren min 代表minimum, 比如minWidth max 代表maximum, 比如maxHeight nav 代表navigation, 比如NavBar regexp 代表regular expression, 比如RegExpValidator util 代表utility, 比如StringUtil

编码时采用合适的命名既便于使用且理解起来也更为容易. 所以你得在选择好的命名方式二多费心力, 特别是针对公共API 提供出来的时候.

我们的命名规范绝大部分和ECMAScript 和Flash Player 9 是一致的.

表意明确比为了少敲几下代码而采用缩写更为重要. 如果你不使用缩写, 开发人员就不用非得记住你是否采用了单词简写, 如把”qualified ”简写成”qual ”或”qlfd ”.

不过, 我们已经标准化了一些缩写词:

上述列表可能没有包含目前使用的所有缩写词. 如果你用到了上面没有列举出来的缩写词, 请搜索源代码看是否已经有相应的缩写词使用了. 如果没发现, 再考虑一下如果缩写是否合适.

在Flex 中有各种缩略语,像AIR, CSS, HLOC, IME, MX, MXML, RPC, RSL, SWF, UI, UID, URL, WSDL, 和XML 之类。

一条缩略语要么全部大写要么全部小写(e.g. SWF 或swf ,但不会是Swf )。使用全部小写的缩略语形式是当使用本身作为标识符或者作为某个标识符的开头,以及标识符需用小写字母开头时。可以参照一下关于标识符到底以大写还是小写开头的规则一条缩略语要么全部大写要么全部小写(e.g. SWF 或swf ,但不会是Swf )。使用全部小写的缩略语形式是使用本身作为标识符或者作为某个标识符的开头,标识符必须以小写字母开头。可以参照一下关于标识符到底以大写还是小写开头的规则.

有时候由于不清楚一个单词组合是不是已经成为一个独立的新词了,所以这种情况下会出现不一致的情况:deopdown , popUp ,popUp 。

常常, 对象最简单的名字就是它本身的类型,当然要采取和类型名不同的大小写方式。 以小写字母开头然后接下来的单词采用首字母大写:controls ,listClasses 。

包名总是名词或动名词(动词-ing 的名词形式),而非动词,连词或副词。

对于重要的APIs, 文件名必须要和公共API 内部的名字一致。但是包含文件必须要遵从这个规则:

常量值如果是string 类型的,那么它的value 要和常量名保持一致:

如果一个类重写了一个getter/setter,但还想继续公开基类的getter/setter,它就得单独用一个属性,属性吗为基类中属性名前加一个前缀$. 这个getter/setter要以final 标记且不做任何额外的coding 除了调用super getter/setter.

方法名应当总是动词

如果一个类重写了一个方法,但还想继续公开基类的方法, 它就得单独实现一个方法,方法名为基类中方法名前加一个前缀$. 这个method 要以final 标记且不做任何额外的coding 除了调用supermethod.

避免“object” 因为它意义模糊.

一个 “item” 是一个data item, 而不是一个DisplayObject.

一个“renderer” 是一个显示data item的 DisplayObject.

一个“type” 一个AS3 类型; 否则使用 "kind".

这部分我们将讨论如何使用AS3的语言构造,尤其当同一事物存在多种表述手段时。

建议使用基于属性的APIs 而不是基于方法的APIs 因为这些更加适合声明式的MXML 编程 为每个常量,变量,函数参数以及函数返回值甚至如果简单地使用:*表明“无类型”。 如果你声明Array 类型的变量, 你得添加一个/* of ElementType */形式的注释紧接着Array 表明该数组元素的类型。未来版本的语言可能会支持这种类型化的数组。

不要在integar 中使用小数点。.

RGB 颜色值总是采用这种6位十六进制数表示。

如果一个Number 值可以是小数, 则一般要加上一个小数点并补上0,即使实际值是个整数值

不过, 对于像素坐标即使是小数形式, 也最好使用整数值表示它.

使用引号标记(双引号), 而不是撇号(单引号) 限定字符串, 即使那个字符串包含一个引号作为其内部某个字符.

避免使用函数文本定义匿名函数; 使用一个类方法或包函数替代

如果你必须使用函数文本, 声明一个返回类型, 在函数体内用一个分号终止最后一条语句. 使用字面值而不是一个字符串构造的RegExp 实例.

使用字面值而不是XML 构造函数形式.U

对于XML 属性值使用双引号括起来:

仅当存在导入类型歧义时才采用类名的全路径形式声明一个类..

对于常用操作符如such as +, -, *, /, &&, ||, , >=, ==, and !=不要使用不必要的括号.

各个操作符的优先级很难记住, 所以我们可以运用括号就会十分有用了.

不要将Boolean 值和true 和false 比较, 因为它的值必然是其中之一.

很显然强制转换Number,String,XML,XMLList,Array,Object 或者*为Boolean ,转换错误会有多个值我们很难记住。

让Object 类型的子类(例如UIComponent )转换为Boolean ,因为很明显仅仅null 值表示转换失败,其他情况则是转换成功(注意:Object 及其子类无法存储undefined 值)。 对于int 和uint ,很明显只有0值表示false ,其他都为true 。所以如果你想要使用显式转换,将其与0比较是没有任何问题的,但是阅读不便。

偏向于塑型作为一个操作符,这个主要为了防止强制类型转换错误评估为null ,而不是抛出一个异常。

比较表达式最好以易读的方式书写:

为了防止前缀和后缀形式相同,使用后缀形式。如果想要提前使用变量值而不是增加/减少的值可以使用前缀形式

用条件运算符代替if/else形式,特别是想要检验是否有null 值时:

主要最好不要将多个条件运算符代替复杂的if/else逻辑结构。

使用括号紧随类型引用,即使这个类的构造函数不带任何参数。

每条语句后面都要接一个分号,虽然在AS 3中并没有这个强制要求.

使用相对路径而不是绝对路径。

导入特定类,接口和其他包级的函数而不是*通配符。

避免使用它们; 使用 ::语法提到syntax instead on each reference to something in a non-open namespace.

如果if/else的不同分支涉及到单条语句,不需要大括号包含它.

但是如果有多条语句时可以将大括号包含起来。

如果测试多个error 检查,可以使用一系列if 语句段测试错误并提前返回。正确的执行流放到最后返回true 。不要使用嵌套的if 语句来判断,这样会导致执行流整个块中都有. 即使for 语句块只有一条语句也要用大括号括起来。

对于上限我们用一个单独的变量来存储,这样不会使得每次判断的时候都要重复计算。 在循环括号里面声明循环变量,除非其他地方要用到这个变量

即使只有一条语句也要用括号括起来.

即使一条语句也要括起来t.

将每一个case 子句作为一个块,包括default 子句。将break 和return 语句置于块中。将default 子句也当做case 子句;避免出现case 穿透问题。

不需要将返回值用括号括起来.

从方法体中部返回也是可以的

不要在同一行声明多个变量或常量。

在需要访问限定的地方放置上访问限定符。不要不写,虽然这样表示默认的访问限定internal 。

在构造public 或者protected 的API 时,仔细想想是否需要这样做。Public 和protected 的APIs 必须进行文档化。在正式被终止之前需要支持好几个发布版本。

如果存在,请将这个关键字放在访问限定符之后。

如果存在,将它放在访问限定符后面。

所有的常量应该是static 的。不应将一个实例声明为常量,应该所有的哦实例将使用同样的值。

如果变量需要初始化为一个值,而不是使用默认值,在声明变量的时候就初始化而不用等到构造函数里面再初始化。

如果一个类简单地继承自Object ,不用显示写出extends Object子句。

如果一个类有实例变量,要书写一个构造函数,显示使用super(),即使它没做任何事情。 不要在构造函数中设置类实例变量;在实例声明时就初始化。不过,如果你需要重置从父类实例中继承的变量值,可以在构造函数中做。

在包语句中中的公共API (常常是一个类,有时是一个明明空间或函数)

帮助类

空语句。

这部分主要阐释Flex 框架文件应当如何组织.

在框架文件下每一个as 文件头部都应包括一个版权声明. 下面给出2008版开源版本的格式:

将类中元数据按Events,Styles,Effects,Excluded IPIs和其它元数据顺序分成几个部分. 在每个部分前面加一个小的说明头. 注意每个说明头是40个字符宽度在//和其后 区块名之间有两个空格.

每个区块将元数据名”…”按字母表顺序排列出来. 在其他元数据区块,将元数据标签名按字母表顺序列出。

将静态常量声明置于此。

ActionScript 3 不允许常量具有Array or Object类型. 声明那种常量使用static var而不是static const。将它们放在这个部分因为概念上它们也属于常量。

将任何Function 类型声明为静态变量而不是声明为方法减小类大小。

声明静态getters 和setters ,然后将它们按字母表顺序排列。使用

Declare static getters and setters here. Order them alphabetically by property name. Use a minor separator with the property name for each one. Put the getter before the setter.

Only document the first function of a get/set function pair for a property. The idiom for defining and documenting a property is:

有时我们(故意) 采用的缩写词不一致. 例如, 我们在很多时候都会拼写”horizontal ”和”vertical ”,像horizontalScrollPolicy 和 verticalScrollPolicy 。但是我们在常规容器类名

VBox 中却将它们缩写成了H 、V , HBox 和

缩略语

和缩略语有关的标识符有CSSStyleDeclaration , IUID , uid , IIME 和imeMode .

单词定限

当标识符包含多个单词时,我们采用两种方式表明单词界限:单词首字母大写 (比如 LayoutManager 、measuredWidth ) 和下划线连接 (比如object_proxy). 具体采用哪种方式请参照一下规则:.

即使出现两个缩略语相邻时也要遵循首字母大小写的规则。loadCSSURL()就是一个很符合这种情形的例子(实际上很少使用)。但是尽量避免使用那样的名字。

类型指定名

如果你想要在命名中纳入类型标示,将类型作为最后一个“词”。If you want to incorporate the type into the name, make it the last “word”. 不要使用ACTIONSCRIPT 1的类型连接后缀如_mc表明类型。例如,命名一个border shape,可以是border ,borderSkin 或borderShape ,但不是border_mc.

var button:Button = new Button();

包名

实现了许多相似东西的包的包名要采用该类事物的复数形式:: charts , collections , containers , controls , effects , events , formatters , managers , preloaders , resources , skins , states , styles , utils , validators .

对于实现了某种概念的包一般用动名词的形式: binding , logging , messaging , printing . 否则, 它们通常只是 " 概念名词 ": accessibility , core , graphics , rpc .

一个包含支持FooBar 组件的类应当命名为fooBarClasses .

文件名

对于含一个大写字母的元数据[Style(...)] 包含文件的文件名,后续单词采用首字母大写且将最后单词写为”sytles ”: BorderStyles.as , ModalTransparencyStyles.as .

以全部小写字母并且下划线进行单词连接的形式来命名个人资产文件: icon_align_left.png.

命名空间名

已全部小写字母并且消化腺进行单词连接的形式命名: mx_internal, object_proxy.

接口名

以I 开头并且后续单词使用首字母大写的形式: IList , IFocusManager , IUID .

类名

大写字母开头后续单词首字母大写: Button, FocusManager, UIComponent .

Event 子类命名 FooBarEvent .

Error 子类命名FooBarError .

Name the EffectInstance subclass associated with effect FooBar FooBarInstance . Formatter 子类命名FooBarFormatter .

Validator 子类命名FooBarValidator .

FooBarBackground , FooBarBorder , FooBarSkin , FooBarIcon ,

FooBarIndicator , FooBarSeparator , FooBarCursor 等. 外观类命名

工具类命名 FooBarUtil (不是 FooBarUtils ; 包名复数但类名要用单数).

常用基类命名方式 FooBarBase : ComboBase , DateBase , DataGridBase , ListBase .

事件名

小写字母开头并且后续单词首字母大写: "move" , "creationComplete" .

样式名

小写字母开头并且后续单词首字母大写: color , fontSize .

字符串属性枚举值

小写字母开头并且后续单词首字母大写: "auto" , "filesOnly" ,

常量名

全部大写且单词采用下划线连接: OFF , DEFAULT_WIDTH.

public static const FOO_BAR:String = "fooBar";

属性(变量和getter/setter) 名

小写字母开头并且后续单词首字母大写: i , width , numChildren .

使用i 作为for 循环的外层循环索引值,n 作为其上限值. 使用j 作为for 循环的内层循环索引值,m 作为其上限值.

for (var i:int = 0; i

for (var j:int = 0; j

...

}

}

使用 p (表示 “property”) 作为for-in 循环变量:

for (var p:String in o) {

...

}

mx_internal final function get $numChildren():int{

return super.numChildren;

}

存储变量名

替getter/setter foo命名一个存储变量名_foo.

方法名

小写字母开头并且后续单词首字母大写: measure(), updateDisplayList().

不带参数的方法不应当采取getFooBar() 或 setFooBar()命名形式, 而应设计成getter/setter。 不过,

getFooBar()是一个需要大量计算的缓慢方法, 应当将其命名为findFooBar(), calculateFooBar(), determineFooBar()等. 而不是一个ge tter. 如果

mx_internal final function

$addChild(child:DisplayObject):DisplayObject{

return super.addChild(child);

}

事件处理方法名

事件处理程序名应当在事件类型后面连接一个 “Handler”: mouseDownHandler().

如果处理程序是服务于派发给子控件的事件 (i.e., not this ), 在处理程序名前面加一个子控件名前缀然后以下划线后处理程序名组合: textInput_focusInHandler().

参数名

对任何setter 的参数使用value 作为参数名:

这样做:

public function set label(value:String):void

而不是:

public function set label(lab:String):void

或者这样做:

public function set label(labelValue:String):void

或者这样做:

public function set label(val:String):void

使用 event (而非 e , evt , or eventObj ) 作为每个事件处理程序的参数:

protected function mouseDownHandler(event:Event):void

资源包名

如果一个资源包名包含特定包的资源,应该以相同的名字命名这个资源包: controls , {formatters}}, validators .

资源键名

小写字母开头且后续单词首字母大写: pm , dayNamesShort .

杂项名

语言使用

编译选项

采用-strict and -show-actionscript-warnings 编译选项进行编译. (在flex-config.xml 文件中会有一些缺省值.)

基于属性的APIs

类型定义

这样做:

var value:*;

而不是这样:

var value;

使用合适的最紧致的类型。例如,循环变量索引应当是int 型,不是Number 型,当然更不会是Object 或*.另一个例子,mouseDownHandler 应当声明一个参数 event:MouseEvent, 而不是event:Event.

整型数使用int , 即使它不是负数. 使用uint 作为 RGB 颜色值, 位掩码和其他非数字值.

使用 *仅在该值没有定义的情况下. 你应当通常使用Object 而不是*You should generally use Object rather than *, 具有null 代表“对象不存在”值.

这样做:

var a:Array /* of String */ = [];

而不是这样:

var a:Array = [];

这样做:

function f(a:Array /* of Number */):Array /* of Object */

{

...

}

而不是这样:

function f(a:Array):Array

文本

undefined

避免使用如果可能的话。仅仅是在编译时变量的类型是*,It is only necessary when dealing with values whose compile-time is type is *, and you should be using * sparingly as well.

int /uint

这样做:

2

而不是这样:

2.

十六进制数使用一个小写字母x 和大写字母 A-Z 。

这样做:

0xFEDCBA

而不是这样:

0Xfedcba

这样做:

private const BLACK:uint = 0x000000;

而不是这样:

private const BLACK:uint = 0;

Number

这样做:

alphaFrom = 0.0;

alphaTo = 1.0;

而不是这样:

alphaFrom = 0;

alphaTo = 1;

这样做:

var xOffset:Number = 3;

而不是这样:

var xOffset:Number = 3.0;

指数表示法表示数字时使用 e , 而不是 E .

这样做:

1.0e12

而不是这样:

1.0E12

使用值NaN 作为非Number 类型的缺省值值.

String

这样做:

"What's up, \"Big Boy\"?"

而不是这样:

'What\'s up, "Big Boy"?'

使用\u, not \U, 作为Unicode 转义字符序列.

Array

使用数组文本而非new Array().

这样做:

[]

而不是这样:

new Array()

这样:

[ 1, 2, 3 ]

而不是:

new Array(1, 2, 3)

使用Array 构造函数仅仅是作为预留数组大小时, 比如new Array(3), 意为[ undefined, undefined, undefined ], not [ 3 ].

Object

使用Object 文本而非new Object().

这样做s:

{}

而不是这样:

new Object()

这样做:

o = { a: 1, b: 2, c: 3 };

而不是这样:

o = new Object();

o.a = 1;

o.b = 2;

o.c = 3;

或这样:

o = {};

o.a = 1;

o.b = 2;

o.c = 3;

Function

这样做s:

function(i:int):void { doIt(i - 1); doIt(i + 1); }

而不是这样:

function(i:int) { doIt(i - 1); doIt(i + 1) }

RegExp

这样做:

var pattern:RegExp = /\d+/g;

而不是这样:

var pattern:RegExp = new RegExp("\\d+", "g");

XML and XMLList

这样:

var node:XML = ;

而不是这样:

var node:XML = new XML(""); 这样做:

var node:XML = ;

而不是这样:

var node:XML = ;

Class

这样做:

import mx.controls.Button;

...

var b:Button = new Button();

而不是这样:

import mx.controls.Button;

...

var b:Button = new mx.controls.Button(); 但下面这种情况下使用全限定名才是合适的.:

import mx.controls.Button;

import my.controls.Button;

...

var b:Button = new mx.controls.Button();

表达式

括号

这样做:

var e:Number = a * b / (c + d);

而不是这样:

var e:Number = (a * b) / (c + d);

这样做:

var e:Boolean = a && b || c == d;

而不是这样:

var e:Boolean = ((a && b) || (c == d)); 强制转换

这样做:

if (flag)

而不是这样:

if (flag == true)

这样做:

var flag:Boolean = a && b;

而不是这样:

var flag:Boolean = (a && b) != false;

这样做:

if (s != null && s != "")

而不是这样:

if (s)

这样做:

if (child)

而不是这样:

if (child != null)

这样做:

if (!child)

而不是这样做:

if (child == null)

这样做:

IUIComponent(child).document

而不是这样s:

(child as IUIComponent).document

比较

这样做:

if (n == 3) // "if n is 3"

而不是这样做:

if (3 == n) // "if 3 is n"

++ /-- 操作符

这样做:

for (var i:int = 0; i

而不是这样:

for (var i:int = 0; i

条件运算符

这样做:

return item ? item.label : null;

而不是这样:

if (!item)

return null;

return item.label;

这样做:

if (a

return -1;

else if (a > b)

return 1;

return 0;

而不是这样:

return a b ? 1 : 0);

new 运算符

这样做:

var b:Button = new Button();

而不是这样:

var b:Button = new Button;

语句

这样做:

a = 1;

b = 2;

c = 3;

而不是这样:

a = 1

b = 2

c = 3

include 语句

使用include 而不是#include. 也像其他语句一样后面加个分号结束. 这样做:

include "../core/ComponentVersion.as"; 而不是这样做:

#include "../core/ComponentVersion.as" Import 语句

这样做:

import mx.controls.Button;

import flash.utils.getTimer;

而不是这样:

import mx.core.*;

use namespace语句

这样做:

import mx.core.mx_internal;

// Later, in some method... mx_internal::doSomething(); 而不是这样:

import mx.core.mx_internal; use namespace mx_internal;

// Later, in some method... doSomething();

if 语句

这样做:

if (flag)

doThing1();

而不是这样:

if (flag)

{

doThing1();

}

这样做:

if (flag)

doThing1();

else

doThing2():

而不是这样:

if (flag)

{

doThing1();

}

else

{

doThing2();

}

这样做:'

if (flag)

{

doThing1();

}

else

{

doThing2();

doThing3();

}

而不是这样:

if (flag)

doThing1();

else

{

doThing2();

doThing3();

}

这样做:

if (!condition1)

return false;

...

if (!condition2)

return false;

...

if (!condition2)

return false;

...

return true;

而不是这样:

if (condition1)

{

...

if (condition2)

{

...

if (condition3)

{

...

return true;

}

}

}

return false;

for 语句

这样做:

for (var i:int = 0; i

{

doSomething(i);

}

而不是这样:

for (var i:int = 0; i

doSomething(i);

这样做:

var n:int = a.length;

for (var i:int = 0; i

{

...

}

而不是这样:

for (var i:int = 0; i

{

...

}

这样做:

for (var i:int = 0; i

而不是这样:

var i:int;

for (i = 0; i

{

...

}

while 语句

这样做:

while (i

{

doSomething(i);

}

而不是这样:

while (i

doSomething(i);

do 语句

这样做:

do

{

doSomething(i);

}

while (i

而不是这样:

do

doSomething(i);

while (i

switch 语句

这样做:

switch (n)

{

case 0:

{

foo();

break;

}

case 1:

{

bar();

return;

}

case 2:

{

baz();

return;

}

default:

{

blech();

break;

}

}

而不是这样:

switch (n)

{

case 0:

foo();

break;

case 1:

{

bar();

}

break;

case 2:

baz();

return;

break;

default:

blech();

}

return 语句

这样做:

return n + 1;

而不是这样做:

return (n + 1);

声明

这样做:

var a:int = 1;

var b:int = 2;

而不是这样:

var a:int = 1, b:int = 2;

override 关键字

如果存在重载的情况,请将这个关键字放在第一位,在访问限定符前面。

这样做:

override protected method measure():void

而不是这样:

protected override method measure():void

访问限定符

Static 关键字

这样做:

public static const MOVE:String = "move"

而不是这样:

static public const MOVE:String = "move";

final 关键字

这样做:

public final class BoxDirection

而不是这样:

final public class BoxDirection

将所有“枚举类”声明为final 型的。

也常常将“基本”属性和方法(以$开头)为final 类型。

常量

这样做:

public static const ALL:String = "all";

而不是这样:

public const ALL:String = "all";

变量

这样做:

private var counter:int = 1;

而不是这样做:

private var counter:int;

...

public function MyClass()

{

super();

...

counter = 1;

}

局部变量

内部变量在使用的时候才进行声明,而不要都放在函数开始时。

这样做:

private function f(i:int, j:int):int

{

var a:int = g(i - 1) + g(i + 1);

var b:int = g(a - 1) + g(a + 1);

var c:int = g(b - 1) + g(b + 1);

return (a * b * c) / (a + b + c);

}

而不是这样做:

private function f(i:int, j:int):int

{

var a:int;

var b:int;

var c:int;

a = g(i - 1) + g(i + 1);

b = g(a - 1) + g(a + 1);

c = g(b - 1) + g(b + 1);

return (a * b * c) / (a + b + c);

}

Declare local variables only one per function. ActionScript 3 doesn't have block-scoped locals.

Do this:

var a:int;

if (flag)

{

a = 1;

...

}

else

{

a = 2;

...

}

Not this:

if (flag)

{

var a:int = 1;

...

}

else

{

var a:int = 2;

...

}

And this:

var i:int;

for (i = 0; i < n; i++)

{

...

}

for (i = 0; i < n; i++)

{

...

}

Not this:

for (var i:int = 0; i < n; i++)

{

...

}

for (var i:int = 0; i < n; i++)

{

...

}

The only “bare statements” in a class should be calls to static class initialization methods, such as loadResources().

构造函数

如果构造函数参数对应于实例变量,参数名可以使用与实例名同样的名字。

这样做:

public function MyClass(foo:int, bar:int)

{

this.foo = foo;

this.bar = bar;

}

而不是这样做:

public function MyClass(fooVal:int, barVal:int)

{

foo = fooVal;

bar = barVal;

}

接口

TBD

命名空间

TBD

实现属性

TBD

元数据

TBD

文件组织

版权声明

//////////////////////////////////////////////////////////////////////////////

//

// ADOBE SYSTEMS INCORPORATED

// Copyright 2008 Adobe Systems Incorporated

// All Rights Reserved.

//

// NOTICE: Adobe permits you to use, modify, and distribute this file // in accordance with the terms of the license agreement accompanying it.

//

////////////////////////////////////////////////////////////////////////////////

注意每一行最多包含80个字符.

包语句

TBD

导入语句

TBD

使用命名空间语句

TBD

Class 元数据

//--------------------------------------

// Events

//--------------------------------------

/

**

* ASDoc comment.

*/

[Event

/**

* ASDoc comment.

*/

[Event

//--------------------------------------

// Styles

//--------------------------------------

/**

* ASDoc comment.

*/

[Style

/**

* ASDoc comment.

*/

[Style]

//--------------------------------------

// Effects

//--------------------------------------

/**

* ASDoc comment.

*/

[Effect

/**

* ASDoc comment.

*/

[Effect]

//--------------------------------------

// Excluded APIs

//--------------------------------------

[Exclude(name="horizontalAlign", kind="style")]

[Exclude(name="verticalAlign", kind="style")]

//--------------------------------------

// Other metadata

//--------------------------------------

[DefaultBindingProperty(source="text",

destination="text")]

[IconFile("Text.png")]

Class 声明

TBD

Version.as include语句

每个类应当使用相对路径包含core/Version.as.这个文件包含static const VERSION:String声明.

include "../core/Version.as";

实现注释

TBD

类初始化

TBD

类常量

类最小化

类资源

TBD

类变量

TBD

类方法

放置静态方法声明.

构造函数

TBD

变量

TBD

重载属性

Put overrides of non-static getters and setters here. Order them alphabetically by property name. Use a minor separator with the property name for each one. Put the getter before the setter.

属性

Put new non-static getters and setters here. Order them alphabetically by property name. Use a

minor separator with the property name for each one. Put the getter before the setter.

重载方法

Put overrides of non-static functions here.

方法

Put new non-static functions here.

重载事件处理函数

Put overrides of event handlers here.

事件处理函数函数

Put new event handlers here.

包外帮助类

TBD

格式化

This section covers how a Flex framework class should be formatted.

Wrap code to 80-character lines. This has the following advantages:

∙ Developers with smaller screens don't have to scroll horizontally to read long lines. A comparison utility can display two versions of a file side-by-side. The font size can be increased for projection before a group without requiring scrolling.

∙ The source code can be printed without clipping or wrapping.

缩进

Use 4-space indentation. Configure your text editor to insert spaces rather than tabs. This allows another program that uses a different indentation setting, such as Notepad with its 8-character

indents, to display the code without disfiguring it. Section separators

The major section separators inside a class look like this:

//--------------------------------------------------------------------------

//

// Overridden methods

//

//--------------------------------------------------------------------------

They extend from column 4 through column 80. The text is indented to column 8.

The minor section separators inside a class, such as between properties, look like this: //----------------------------------

// visible

//----------------------------------

They extend from column 4 through column 40. The text is indented to column 8.

Put a single blank line above and below the separators. Separation of declarations

Use a single blank line as a vertical separator between constant, variable, or function declarations. /**

* @private

* Holds something.

*/

var a:Number;

/**

* @private

*/

var b:Number Metadata

TBD

Do this:

Inspectable[a="1", b="2"]

Not this:

Inspectable[a=1 b=2] Array indexing

Don't put any spaces before or after the left bracket or before the right bracket.

Do this:

a[0]

Not this:

a[ 0 ] Commas

Follow a comma with a single space. This applies to argument lists, array literals, and object

literals. Array literals

Put a single space after the left bracket and a single space before the right bracket, and put a single

space after (but none before) each comma.

Do this:

[ 1, 2, 3 ]

Not these:

[1, 2, 3]

[1,2,3]

An empty array is a special case.

Do this:

[]

Not this:

[ ]

Format lengthy array initializers requiring multiple lines with aligned brackets:

static var numberNames:Array /* of String */ =

[

"zero",

"one",

"two",

"three",

"four",

"five",

"six",

"seven",

"eight",

"nine"

]; Object literals

Put a single space after the left brace and a single space before the right brace, and put a single

space after the colon separating the property name and value.

Do this:

{ a: 1, b: 2, c: 3 }

Not these:

{a: 1, b: 2, c: 3}

{a:1, b:2, c:3}

{a:1,b:2,c:3}

An empty Object is a special case.

Do this:

{}

Not this:

{ }

Format lengthy object initializers requiring multiple lines with aligned braces:

private static var TextStyleMap:Object =

{

color: true,

fontFamily: true,

fontSize: true,

fontStyle: true,

fontWeight: true,

leading: true,

marginLeft: true,

marginRight: true,

textAlign: true,

textDecoration: true,

textIndent: true

}; Function literals

TBD

var f:Function;

f = function():void

{

doSomething();

};

Type declarations

Don't put any spaces before or after the colon that separates a variable, parameter, or function

from its type.

Do this:

var n:Number;

Not these:

var n : Number;

var n: Number;

And this:

function f(n:Number):void

Not these:

function f(n : Number) : void

function f(n: Number): void Operators and assignments

Put a single space around the assignment operator.

Do this:

a = 1;

Not this:

a=1;

Put a single space around infix operators.

Do this:

a + b * c

Not this:

a+b*c

Put a single space around comparison operators.

Do this:

a == b

Not this:

a==b

Don't put any spaces between a prefix operator and its operand.

Do this:

!o

Not this:

! o

Don't put any spaces between a postfix operator and its operand.

Do this:

i++

Not this:

i ++ Statements

Start each statement on a new line, so that you can set a breakpoint on any statement.

Do this:

a = 1;

b = 2;

c = 3;

Not this:

a = 1; b = 2; c = 3;

Align the braces of statement blocks.

Do this:

function f():void

{

var n:int = numChildren;

for (var i:int = 0; i

{

if ()

{

x = horizontalGap * i;

y = verticalGap * i;

}

}

}

Not this:

function f():void {

var n:int = numChildren;

for (var i:int = 0; i

if () {

x = horizontalGap * i;

y = verticalGap * i;

}

}

} Constant and variable declarations

TBD Function declarations

TBD

Do this:

f(a, b)

''Not these:''

f(a,b)

f( a, b )

If the parameters have to wrap, indent the subsequent lines after the left parenthesis. Put multiple parameters per line if they fit. Otherwise, put one per line. If even one won't fit, put the first one

on the second line, indented past the beginning of the function name.

public function foo(parameter1:Number, parameter2:String,

parameter3:Boolean):void

public function foo(parameter1:Number,

public function aVeryLongFunctionName(

parameter1:Number, parameter2:String,

parameter3:Boolean):void Function calls

TBD

Do this: parameter2:String, parameter3:Boolean):void

f(a, b)

Not these:

f(a,b)

f( a, b )

if statements

Follow the if keywords with a single space before the left parenthesis. Don't put any spaces after

the left parenthesis or before the right parenthesis.

Do this:

if (a

Not these:

if(a

if( a

if ( a

else if ?

multiline ?

for statements

Follow the for keyword with a single space before the left parenthesis. Don't put any spaces after

the left parenthesis or before the right parenthesis.

Do this:

for (var i:int = 0; i

Not these:

for(var i:int = 0; i

for( var i:int = 0; i

for ( var i:int = 0; i

If the for clause needs to wrap, indent the subsequent lines after the left parenthesis. for (var aLongLoopVariableName:int = aLongInitialExpression;

aLongLoopVariableName

aLongLoopVariableName++)

switch statements

Follow the switch keyword with a single space before the left parenthesis. Don't put any spaces

after the left parenthesis or before the right parenthesis.

Do this:

switch (n)

Not these:

switch(n)

switch( n )

switch ( n )

Follow the switch keyword with a single space before the left parenthesis. Don't put any spaces

after the left parenthesis or before the right parenthesis.

Do this:

switch (n)

{

case 1:

{

a = foo();

break;

}

case 2:

{ a = bar();

break;

}

default:

{

a = blech();

break;

}

}

Not these:

switch(n)

switch( n )

switch ( n )

class and interface declarations

braces are always balanced

no braces around single lines

single statement per line

ASDoc 文档

属性注释

/**

* @private

* The backing variable for the property.

*/

private var _someProp:Foo;

/**

* Place all comments for the property with the getter which is defined first.

* Comments should cover both get and set behavior as appropriate. */

public function get someProp():Foo

{

...

}

/**

* @private

*/

public function set someProp(value:Foo):void

{

...

}

Also, ASDoc comments are applied to metadata tags as well as other constructs within a class so take care that your comments apply to the proper target. If you tag a property as Bindable, your

property comment must precede the get function, not the Bindable metadata tag.

Do this:

[Bindable("somePropChanged")]

/**

* Comments for someProp

*/

public function get someProp():Foo

Not this:

/**

* Comments for someProp

*/

[Bindable("somePropChanged")]

public function get someProp():Foo

http://opensource.adobe.com/wiki/display/flexsdk/Coding+Conventions


相关文章

  • 通信原理课程设计-DPCM编译码器设计及应用
  • 程 设 计 报 课题名称 DPCM编译码器设计及应用 专 业班 级学 号 姓 名 指导教师 2013年12月21 日 课告 湖南工程学院 课 程 设 计 任 务 书 课程名称 通信原理 课 题 DPCM编译码器设计及应用 专业班级 学生姓名 ...查看


  • 浙江教师招聘考试教育基础知识名词解释部分
  • 学习资料 2015年浙江省小学教师招聘考试 教 育 基 础 知 识 (名词解释篇) 不保证最好,但一定很好 浙江省小学教师招聘考试--教育基础知识 名词解释(重点)汇总 教育学 1.教育:是人类有目的地培养人的一种社会活动,是传承文化.传递 ...查看


  • 医院信息系统理论考试复习提纲
  • <医院信息系统>课程复习提纲 1. 信息.数据与知识的关系. 数据是信息的基础, 信息是对人们有用的数据, 知识是在信息的基础上进一步提炼而成的关于自然和社会的认识和经验的总和,指导人们从大量的数据中认识信息的某种规律. 2. ...查看


  • 学校校园智能监控系统设计方案
  • 校园 智能监控系统 设 计 方 案 怀化旭市科技有限公司 目 录 1. 概述 ................................................................................. ...查看


  • "基于网络的成人学习特点与教学模式研究"成果公报
  • 作者:全国教育科学规划领导小组办公室 当代教育论坛(宏观教育研究) 2008年09期 由江苏省成人教育协会会长陈乃林主持的全国教育科学"十五"规划教育部重点课题"基于网络的成人学习特点与教学模式研究" ...查看


  • 知识管理的基本过程与知识的分类管理模式
  • 文章出处:   发布时间:2005-03-31 一.知识管理的兴起 随着知识经济的出现和发展 ,知识作为一种关键的组织资源 ,在企业发展和经济增长中所起的重要作用已被广泛认识.越来越多的工商界领导人和咨询界人士认为知识是组织的首要资产 ,是 ...查看


  • 消防产品身份信息标志印刷规范
  • 消防产品身份信息标志 印刷技术规范 2014 . 9 一 本体标志描述 .................................................................................... ...查看


  • 审计署计算机中级考试-计算机网络试总复习题库
  • 填空题(每空0.5分,共计 34分) 网络----35 网络传输介质 01.数字信号相对于模拟信号的优点:抗干扰能力强.传输设备简单. 02.一个信号有效谐波所占的频带宽度,称为信号频宽(带宽). 一个电缆能够不失真地传输信号的频带宽度,称 ...查看


  • 卷积码的设计与实现
  • 湖南文理学院课程设计报告 课程名称: 通信系统课程设计 院 部: 电气与信息工程学院 专业班级: 学生姓名: 指导教师: 完成时间: 2011 年 12 月 29日 报告成绩: 目录 目录 . ....................... ...查看


热门内容