`
caiyi
  • 浏览: 18045 次
  • 性别: Icon_minigender_1
  • 来自: 广州
最近访客 更多访客>>
社区版块
存档分类
最新评论

AS3编码规范2

    博客分类:
  • as3
 
阅读更多

Flex SDK 编码规范及最佳实践

(资料共享)

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

引言

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

目录

命名

<!--[if !supportLists]-->·         <!--[endif]-->缩写

<!--[if !supportLists]-->·         <!--[endif]-->缩略语

<!--[if !supportLists]-->·         <!--[endif]-->单词定界

<!--[if !supportLists]-->·         <!--[endif]-->类型指定名

<!--[if !supportLists]-->·         <!--[endif]-->包名

<!--[if !supportLists]-->·         <!--[endif]-->文件名

<!--[if !supportLists]-->·         <!--[endif]-->命名空间名

<!--[if !supportLists]-->·         <!--[endif]-->接口名

<!--[if !supportLists]-->·         <!--[endif]-->类名

<!--[if !supportLists]-->·         <!--[endif]-->事件名

<!--[if !supportLists]-->·         <!--[endif]-->样式名

<!--[if !supportLists]-->·         <!--[endif]-->字符串属性枚举值

<!--[if !supportLists]-->·         <!--[endif]-->常量名

<!--[if !supportLists]-->·         <!--[endif]-->属性 (变量和getter/setter)

<!--[if !supportLists]-->·         <!--[endif]-->存储变量名

<!--[if !supportLists]-->·         <!--[endif]-->方法名

<!--[if !supportLists]-->·         <!--[endif]-->事件处理方法名

<!--[if !supportLists]-->·         <!--[endif]-->参数名

<!--[if !supportLists]-->·         <!--[endif]-->资源包名

<!--[if !supportLists]-->·         <!--[endif]-->资源键名

<!--[if !supportLists]-->·         <!--[endif]-->杂项名

语言用法

<!--[if !supportLists]-->·         <!--[endif]-->编译选项

<!--[if !supportLists]-->·         <!--[endif]-->基于属性的 APIs

<!--[if !supportLists]-->·         <!--[endif]-->类型定义

<!--[if !supportLists]-->·         <!--[endif]-->Literals

<!--[if !supportLists]-->·         <!--[endif]-->Expressions

<!--[if !supportLists]-->·         <!--[endif]-->Statements

<!--[if !supportLists]-->·         <!--[endif]-->Declarations

文件组织

<!--[if !supportLists]-->·         <!--[endif]-->Copyright notice

<!--[if !supportLists]-->·         <!--[endif]-->package statement

<!--[if !supportLists]-->·         <!--[endif]-->import statements

<!--[if !supportLists]-->·         <!--[endif]-->use namespace statement

<!--[if !supportLists]-->·         <!--[endif]-->Class metadata

<!--[if !supportLists]-->·         <!--[endif]-->Class declaration

<!--[if !supportLists]-->·         <!--[endif]-->include statement for Version.as

<!--[if !supportLists]-->·         <!--[endif]-->Implementation notes

<!--[if !supportLists]-->·         <!--[endif]-->Class initialization

<!--[if !supportLists]-->·         <!--[endif]-->Class constants

<!--[if !supportLists]-->·         <!--[endif]-->Class mix-ins

<!--[if !supportLists]-->·         <!--[endif]-->Class resources

<!--[if !supportLists]-->·         <!--[endif]-->Class variables

<!--[if !supportLists]-->·         <!--[endif]-->Class properties

<!--[if !supportLists]-->·         <!--[endif]-->Class methods

<!--[if !supportLists]-->·         <!--[endif]-->Constructor

<!--[if !supportLists]-->·         <!--[endif]-->Variables

<!--[if !supportLists]-->·         <!--[endif]-->Overridden properties

<!--[if !supportLists]-->·         <!--[endif]-->Properties

<!--[if !supportLists]-->·         <!--[endif]-->Overridden methods

<!--[if !supportLists]-->·         <!--[endif]-->Methods

<!--[if !supportLists]-->·         <!--[endif]-->Overridden event handlers

<!--[if !supportLists]-->·         <!--[endif]-->Event handlers

<!--[if !supportLists]-->·         <!--[endif]-->Out-of-package helper classes

格式化

<!--[if !supportLists]-->·         <!--[endif]-->Line width

<!--[if !supportLists]-->·         <!--[endif]-->Indentation

<!--[if !supportLists]-->·         <!--[endif]-->Section separators

<!--[if !supportLists]-->·         <!--[endif]-->Separation of declarations

<!--[if !supportLists]-->·         <!--[endif]-->Metadata

<!--[if !supportLists]-->·         <!--[endif]-->Array indexing

<!--[if !supportLists]-->·         <!--[endif]-->Commas

<!--[if !supportLists]-->·         <!--[endif]-->Array literals

<!--[if !supportLists]-->·         <!--[endif]-->Object literals

<!--[if !supportLists]-->·         <!--[endif]-->Function literals

<!--[if !supportLists]-->·         <!--[endif]-->Type declarations

<!--[if !supportLists]-->·         <!--[endif]-->Operators and assignments

<!--[if !supportLists]-->·         <!--[endif]-->Statements

<!--[if !supportLists]-->·         <!--[endif]-->Constant and variable declarations

<!--[if !supportLists]-->·         <!--[endif]-->Function declarations

<!--[if !supportLists]-->·         <!--[endif]-->Function calls

<!--[if !supportLists]-->·         <!--[endif]-->if statements

<!--[if !supportLists]-->·         <!--[endif]-->for statements

<!--[if !supportLists]-->·         <!--[endif]-->switch statements

<!--[if !supportLists]-->·         <!--[endif]-->class and interface declarations

ASDoc文档

<!--[if !supportLists]-->·         <!--[endif]-->Property comments

命名

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

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

缩写词

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

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

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

<!--[if !supportLists]-->·         <!--[endif]-->acc 代表 accessibility, 比如 ButtonAccImpl

<!--[if !supportLists]-->·         <!--[endif]-->auto 代表automatic, 比如autoLayout

<!--[if !supportLists]-->·         <!--[endif]-->eval 代表evaluate, 比如EvalBindingResponder

<!--[if !supportLists]-->·         <!--[endif]-->impl 代表implementation, 比如ButtonAccImpl

<!--[if !supportLists]-->·         <!--[endif]-->info 代表information, 比如GridRowInfo

<!--[if !supportLists]-->·         <!--[endif]-->num 代表number of, 比如numChildren

<!--[if !supportLists]-->·         <!--[endif]-->min 代表minimum, 比如minWidth

<!--[if !supportLists]-->·         <!--[endif]-->max 代表maximum, 比如maxHeight

<!--[if !supportLists]-->·         <!--[endif]-->nav 代表navigation, 比如NavBar

<!--[if !supportLists]-->·         <!--[endif]-->regexp 代表regular expression, 比如RegExpValidator

<!--[if !supportLists]-->·         <!--[endif]-->util 代表utility, 比如StringUtil

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

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

缩略语

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)。使用全部小写的缩略语形式是使用本身作为标识符或者作为某个标识符的开头,标识符必须以小写字母开头。可以参照一下关于标识符到底以大写还是小写开头的规则.

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

单词定限

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

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

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

类型指定名

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

常常, 对象最简单的名字就是它本身的类型,当然要采取和类型名不同的大小写方式。

var button:Button = new Button();

包名

以小写字母开头然后接下来的单词采用首字母大写:controlslistClasses

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

实现了许多相似东西的包的包名要采用该类事物的复数形式:: 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.

文件名

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

对于含一个大写字母的元数据[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.

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

public static const FOO_BAR:String = "fooBar";

属性(变量和getter/setter)

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

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

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

    for (var j:int = 0; j < m; j++) {

        ...

    }

}

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

for (var p:String in o) {

    ...

}

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

mx_internal final function get $numChildren():int{

    return super.numChildren;

}

存储变量名

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

方法名

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

方法名应当总是动词

不带参数的方法不应当采取getFooBar() setFooBar()命名形式,而应设计成getter/setter 不过, 如果getFooBar()是一个需要大量计算的缓慢方法, 应当将其命名为findFooBar(), calculateFooBar(), determineFooBar().而不是一个getter.

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

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.

杂项名

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

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

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

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

语言使用

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

编译选项

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

基于属性的APIs

建议使用基于属性的APIs而不是基于方法的APIs因为这些更加适合声明式的MXML编程

为每个常量,变量,函数参数以及函数返回值甚至如果简单地使用:*表明“无类型”。

这样做:

var value:*;

而不是这样:

var value;

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

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

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

如果你声明Array类型的变量,你得添加一个/* of ElementType */形式的注释紧接着Array表明该数组元素的类型。未来版本的语言可能会支持这种类型化的数组。

这样做:

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

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

这样做:

2

而不是这样:

2.

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

这样做:

0xFEDCBA

而不是这样:

0Xfedcba 

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

这样做:

private const BLACK:uint = 0x000000;

而不是这样:

private const BLACK:uint = 0; 

Number

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

这样做:

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

使用字面值而不是一个字符串构造的RegExp实例.

这样做:

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

而不是这样:

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

XML and XMLList

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

这样:

var node:XML = <name first="Jane" last="Doe"/>;

而不是这样:

var node:XML = new XML("<name first=\"Jane\" last=\"Doe\"/>");

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

这样做:

var node:XML = <name first="Jane" last="Doe"/>;

而不是这样:

var node:XML = <name first='Jane' last='Doe'/>;

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();

表达式

括号

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

这样做:

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));

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

强制转换

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

这样做:

if (flag)

而不是这样:

if (flag == true)

这样做:

var flag:Boolean = a && b;

而不是这样:

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

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

类型

你能记起一下哪个是强制转换失败时的值吗?

Number

0, NaN

String

null, ""

XML / XMLList

null, </>

Array

null, []

Object

null, {}, 0, NaN, false, </>

*

undefined, null, {}, 0, NaN, false, </>

这样做:

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

而不是这样:

if (s)

Object类型的子类(例如UIComponent)转换为Boolean,因为很明显仅仅null值表示转换失败,其他情况则是转换成功(注意:Object及其子类无法存储undefined值)。

这样做:

if (child)

而不是这样:

if (child != null)

这样做:

if (!child)

而不是这样做:

if (child == null)

对于intuint,很明显只有0值表示false,其他都为true。所以如果你想要使用显式转换,将其与0比较是没有任何问题的,但是阅读不便。

偏向于塑型作为一个操作符,这个主要为了防止强制类型转换错误评估为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 < n; i++)

而不是这样:

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

条件运算符

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

这样做:

return item ? item.label : null;

而不是这样:

if (!item)

    return null;

return item.label;

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

这样做:

if (a < b)

    return -1;

else if (a > b)

    return 1;

return 0;

而不是这样:

return a < b ? -1 : (a > b ? 1 : 0);

new运算符

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

这样做:

var b:Button = new Button();

而不是这样:

var b:Button = new Button;

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

这样做:

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语句

避免使用它们; 使用 ::语法提到syntax instead on each reference to something in a non-open 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/else的不同分支涉及到单条语句,不需要大括号包含它.

这样做:

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();

}

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

这样做:

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语句块只有一条语句也要用大括号括起来。

这样做:

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

{

   doSomething(i);

}

而不是这样:

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

    doSomething(i);

对于上限我们用一个单独的变量来存储,这样不会使得每次判断的时候都要重复计算。

这样做:

var n:int = a.length;

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

{

    ...

}

而不是这样:

for (var i:int = 0; i < a.length; i++)

{

    ...

}

在循环括号里面声明循环变量,除非其他地方要用到这个变量

这样做:

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

而不是这样:

var i:int;

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

{

   ...

}

while 语句

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

这样做:

while (i < n)

{

   doSomething(i);

}

而不是这样:

while (i < n)

    doSomething(i);

do 语句

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

这样做:

do

{

   doSomething(i);

}

while (i < n);

而不是这样:

do

    doSomething(i);

while (i < n);

switch 语句

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

这样做:

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

访问限定符

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

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

Static关键字

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

这样做:

public static const MOVE:String = &quot;move&quot;

而不是这样:

static public const MOVE:String = &quot;move&quot;;

final关键字

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

这样做:

public final class BoxDirection

而不是这样:

final public class BoxDirection

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

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

常量

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

这样做:

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 &lt; n; i++)

{

    ...

}

 

for (i = 0; i &lt; n; i++)

{

    ...

}

Not this:

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

{

    ...

}

 

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

{

    ...

}

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

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

构造函数

如果一个类有实例变量,要书写一个构造函数,显示使用super(),即使它没做任何事情。

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

这样做:

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

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

帮助类

空语句。

文件组织

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

版权声明

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

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

//

//  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,Styles,Effects,Excluded IPIs和其它元数据顺序分成几个部分.

在每个部分前面加一个小的说明头.注意每个说明头是40个字符宽度在//和其后 区块名之间有两个空格.

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

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

//  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=&quot;horizontalAlign&quot;, kind=&quot;style&quot;)]

[Exclude(name=&quot;verticalAlign&quot;, kind=&quot;style&quot;)]

 

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

//  Other metadata

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

 

[DefaultBindingProperty(source=&quot;text&quot;, destination=&quot;text&quot;)]

[IconFile(&quot;Text.png&quot;)]

Class声明

TBD

Version.as include语句

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

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

实现注释

TBD

类初始化

TBD

类常量

将静态常量声明置于此。

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

类最小化

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

类资源

TBD

类变量

TBD

类属性

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

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.

类方法

放置静态方法声明.

构造函数

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:

<!--[if !supportLists]-->·         <!--[endif]-->Developers with smaller screens don't have to scroll horizontally to read long lines.

<!--[if !supportLists]-->·         <!--[endif]-->A comparison utility can display two versions of a file side-by-side.

<!--[if !supportLists]-->·         <!--[endif]-->The font size can be increased for projection before a group without requiring scrolling.

<!--[if !supportLists]-->·         <!--[endif]-->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 < n; i++)

    {

        if ()

        {

            x = horizontalGap * i;

            y = verticalGap * i;

        }

    }

}

Not this:

function f():void {

    var n:int = numChildren;

    for (var i:int = 0; i < n; 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,

               parameter2:String,

                    parameter3:Boolean):void

 

public function aVeryLongFunctionName(

    parameter1:Number, parameter2:String,

    parameter3:Boolean):void

Function calls

TBD

Do this:

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 < b)

Not these:

if(a < b)

 

if( a < b )

 

if ( a < b )

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 < n; i++)

Not these:

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

 

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

 

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

If the for clause needs to wrap, indent the subsequent lines after the left parenthesis.

for (var aLongLoopVariableName:int = aLongInitialExpression;

     aLongLoopVariableName < aLongUpperLimit;

     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文档

属性注释

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

/**

 *  @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+ConventionsFlex SDK 编码规范及最佳实践

(资料共享)

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

引言

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

目录

命名

<!--[if !supportLists]-->·         <!--[endif]-->缩写

<!--[if !supportLists]-->·         <!--[endif]-->缩略语

<!--[if !supportLists]-->·         <!--[endif]-->单词定界

<!--[if !supportLists]-->·         <!--[endif]-->类型指定名

<!--[if !supportLists]-->·         <!--[endif]-->包名

<!--[if !supportLists]-->·         <!--[endif]-->文件名

<!--[if !supportLists]-->·         <!--[endif]-->命名空间名

<!--[if !supportLists]-->·         <!--[endif]-->接口名

<!--[if !supportLists]-->·         <!--[endif]-->类名

<!--[if !supportLists]-->·         <!--[endif]-->事件名

<!--[if !supportLists]-->·         <!--[endif]-->样式名

<!--[if !supportLists]-->·         <!--[endif]-->字符串属性枚举值

<!--[if !supportLists]-->·         <!--[endif]-->常量名

<!--[if !supportLists]-->·         <!--[endif]-->属性 (变量和getter/setter)

<!--[if !supportLists]-->·         <!--[endif]-->存储变量名

<!--[if !supportLists]-->·         <!--[endif]-->方法名

<!--[if !supportLists]-->·         <!--[endif]-->事件处理方法名

<!--[if !supportLists]-->·         <!--[endif]-->参数名

<!--[if !supportLists]-->·         <!--[endif]-->资源包名

<!--[if !supportLists]-->·         <!--[endif]-->资源键名

<!--[if !supportLists]-->·         <!--[endif]-->杂项名

语言用法

<!--[if !supportLists]-->·         <!--[endif]-->编译选项

<!--[if !supportLists]-->·         <!--[endif]-->基于属性的 APIs

<!--[if !supportLists]-->·         <!--[endif]-->类型定义

<!--[if !supportLists]-->·         <!--[endif]-->Literals

<!--[if !supportLists]-->·         <!--[endif]-->Expressions

<!--[if !supportLists]-->·         <!--[endif]-->Statements

<!--[if !supportLists]-->·         <!--[endif]-->Declarations

文件组织

<!--[if !supportLists]-->·         <!--[endif]-->Copyright notice

<!--[if !supportLists]-->·         <!--[endif]-->package statement

<!--[if !supportLists]-->·         <!--[endif]-->import statements

<!--[if !supportLists]-->·         <!--[endif]-->use namespace statement

<!--[if !supportLists]-->·         <!--[endif]-->Class metadata

<!--[if !supportLists]-->·         <!--[endif]-->Class declaration

<!--[if !supportLists]-->·         <!--[endif]-->include statement for Version.as

<!--[if !supportLists]-->·         <!--[endif]-->Implementation notes

<!--[if !supportLists]-->·         <!--[endif]-->Class initialization

<!--[if !supportLists]-->·         <!--[endif]-->Class constants

<!--[if !supportLists]-->·         <!--[endif]-->Class mix-ins

<!--[if !supportLists]-->·         <!--[endif]-->Class resources

<!--[if !supportLists]-->·         <!--[endif]-->Class variables

<!--[if !supportLists]-->·         <!--[endif]-->Class properties

<!--[if !supportLists]-->·         <!--[endif]-->Class methods

<!--[if !supportLists]-->·         <!--[endif]-->Constructor

<!--[if !supportLists]-->·         <!--[endif]-->Variables

<!--[if !supportLists]-->·         <!--[endif]-->Overridden properties

<!--[if !supportLists]-->·         <!--[endif]-->Properties

<!--[if !supportLists]-->·         <!--[endif]-->Overridden methods

<!--[if !supportLists]-->·         <!--[endif]-->Methods

<!--[if !supportLists]-->·         <!--[endif]-->Overridden event handlers

<!--[if !supportLists]-->·         <!--[endif]-->Event handlers

<!--[if !supportLists]-->·         <!--[endif]-->Out-of-package helper classes

格式化

<!--[if !supportLists]-->·         <!--[endif]-->Line width

<!--[if !supportLists]-->·         <!--[endif]-->Indentation

<!--[if !supportLists]-->·         <!--[endif]-->Section separators

<!--[if !supportLists]-->·         <!--[endif]-->Separation of declarations

<!--[if !supportLists]-->·         <!--[endif]-->Metadata

<!--[if !supportLists]-->·         <!--[endif]-->Array indexing

<!--[if !supportLists]-->·         <!--[endif]-->Commas

<!--[if !supportLists]-->·         <!--[endif]-->Array literals

<!--[if !supportLists]-->·         <!--[endif]-->Object literals

<!--[if !supportLists]-->·         <!--[endif]-->Function literals

<!--[if !supportLists]-->·         <!--[endif]-->Type declarations

<!--[if !supportLists]-->·         <!--[endif]-->Operators and assignments

<!--[if !supportLists]-->·         <!--[endif]-->Statements

<!--[if !supportLists]-->·         <!--[endif]-->Constant and variable declarations

<!--[if !supportLists]-->·         <!--[endif]-->Function declarations

<!--[if !supportLists]-->·         <!--[endif]-->Function calls

<!--[if !supportLists]-->·         <!--[endif]-->if statements

<!--[if !supportLists]-->·         <!--[endif]-->for statements

<!--[if !supportLists]-->·         <!--[endif]-->switch statements

<!--[if !supportLists]-->·         <!--[endif]-->class and interface declarations

ASDoc文档

<!--[if !supportLists]-->·         <!--[endif]-->Property comments

命名

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

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

缩写词

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

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

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

<!--[if !supportLists]-->·         <!--[endif]-->acc 代表 accessibility, 比如 ButtonAccImpl

<!--[if !supportLists]-->·         <!--[endif]-->auto 代表automatic, 比如autoLayout

<!--[if !supportLists]-->·         <!--[endif]-->eval 代表evaluate, 比如EvalBindingResponder

<!--[if !supportLists]-->·         <!--[endif]-->impl 代表implementation, 比如ButtonAccImpl

<!--[if !supportLists]-->·         <!--[endif]-->info 代表information, 比如GridRowInfo

<!--[if !supportLists]-->·         <!--[endif]-->num 代表number of, 比如numChildren

<!--[if !supportLists]-->·         <!--[endif]-->min 代表minimum, 比如minWidth

<!--[if !supportLists]-->·         <!--[endif]-->max 代表maximum, 比如maxHeight

<!--[if !supportLists]-->·         <!--[endif]-->nav 代表navigation, 比如NavBar

<!--[if !supportLists]-->·         <!--[endif]-->regexp 代表regular expression, 比如RegExpValidator

<!--[if !supportLists]-->·         <!--[endif]-->util 代表utility, 比如StringUtil

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

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

缩略语

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)。使用全部小写的缩略语形式是使用本身作为标识符或者作为某个标识符的开头,标识符必须以小写字母开头。可以参照一下关于标识符到底以大写还是小写开头的规则.

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

单词定限

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

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

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

类型指定名

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

常常, 对象最简单的名字就是它本身的类型,当然要采取和类型名不同的大小写方式。

var button:Button = new Button();

包名

以小写字母开头然后接下来的单词采用首字母大写:controlslistClasses

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

实现了许多相似东西的包的包名要采用该类事物的复数形式:: 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.

文件名

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

对于含一个大写字母的元数据[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.

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

public static const FOO_BAR:String = "fooBar";

属性(变量和getter/setter)

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

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

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

    for (var j:int = 0; j < m; j++) {

        ...

    }

}

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

for (var p:String in o) {

    ...

}

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

mx_internal final function get $numChildren():int{

    return super.numChildren;

}

存储变量名

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

方法名

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

方法名应当总是动词

不带参数的方法不应当采取getFooBar() setFooBar()命名形式,而应设计成getter/setter 不过, 如果getFooBar()是一个需要大量计算的缓慢方法, 应当将其命名为findFooBar(), calculateFooBar(), determineFooBar().而不是一个getter.

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

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.

杂项名

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

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

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

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

语言使用

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

编译选项

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

基于属性的APIs

建议使用基于属性的APIs而不是基于方法的APIs因为这些更加适合声明式的MXML编程

为每个常量,变量,函数参数以及函数返回值甚至如果简单地使用:*表明“无类型”。

这样做:

var value:*;

而不是这样:

var value;

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

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

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

如果你声明Array类型的变量,你得添加一个/* of ElementType */形式的注释紧接着Array表明该数组元素的类型。未来版本的语言可能会支持这种类型化的数组。

这样做:

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

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

这样做:

2

而不是这样:

2.

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

这样做:

0xFEDCBA

而不是这样:

0Xfedcba 

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

这样做:

private const BLACK:uint = 0x000000;

而不是这样:

private const BLACK:uint = 0; 

Number

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

这样做:

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

使用字面值而不是一个字符串构造的RegExp实例.

这样做:

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

而不是这样:

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

XML and XMLList

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

这样:

var node:XML = <name first="Jane" last="Doe"/>;

而不是这样:

var node:XML = new XML("<name first=\"Jane\" last=\"Doe\"/>");

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

这样做:

var node:XML = <name first="Jane" last="Doe"/>;

而不是这样:

var node:XML = <name first='Jane' last='Doe'/>;

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();

表达式

括号

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

这样做:

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));

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

强制转换

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

这样做:

if (flag)

而不是这样:

if (flag == true)

这样做:

var flag:Boolean = a && b;

而不是这样:

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

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

类型

你能记起一下哪个是强制转换失败时的值吗?

Number

0, NaN

String

null, ""

XML / XMLList

null, </>

Array

null, []

Object

null, {}, 0, NaN, false, </>

*

undefined, null, {}, 0, NaN, false, </>

这样做:

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

而不是这样:

if (s)

Object类型的子类(例如UIComponent)转换为Boolean,因为很明显仅仅null值表示转换失败,其他情况则是转换成功(注意:Object及其子类无法存储undefined值)。

这样做:

if (child)

而不是这样:

if (child != null)

这样做:

if (!child)

而不是这样做:

if (child == null)

对于intuint,很明显只有0值表示false,其他都为true。所以如果你想要使用显式转换,将其与0比较是没有任何问题的,但是阅读不便。

偏向于塑型作为一个操作符,这个主要为了防止强制类型转换错误评估为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 < n; i++)

而不是这样:

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

条件运算符

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

这样做:

return item ? item.label : null;

而不是这样:

if (!item)

    return null;

return item.label;

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

这样做:

if (a < b)

    return -1;

else if (a > b)

    return 1;

return 0;

而不是这样:

return a < b ? -1 : (a > b ? 1 : 0);

new运算符

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

这样做:

var b:Button = new Button();

而不是这样:

var b:Button = new Button;

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

这样做:

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语句

避免使用它们; 使用 ::语法提到syntax instead on each reference to something in a non-open 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/else的不同分支涉及到单条语句,不需要大括号包含它.

这样做:

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();

}

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

这样做:

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语句块只有一条语句也要用大括号括起来。

这样做:

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

{

   doSomething(i);

}

而不是这样:

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

    doSomething(i);

对于上限我们用一个单独的变量来存储,这样不会使得每次判断的时候都要重复计算。

这样做:

var n:int = a.length;

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

{

    ...

}

而不是这样:

for (var i:int = 0; i < a.length; i++)

{

    ...

}

在循环括号里面声明循环变量,除非其他地方要用到这个变量

这样做:

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

而不是这样:

var i:int;

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

{

   ...

}

while 语句

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

这样做:

while (i < n)

{

   doSomething(i);

}

而不是这样:

while (i < n)

    doSomething(i);

do 语句

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

这样做:

do

{

   doSomething(i);

}

while (i < n);

而不是这样:

do

    doSomething(i);

while (i < n);

switch 语句

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

这样做:

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

访问限定符

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

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

Static关键字

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

这样做:

public static const MOVE:String = &quot;move&quot;

而不是这样:

static public const MOVE:String = &quot;move&quot;;

final关键字

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

这样做:

public final class BoxDirection

而不是这样:

final public class BoxDirection

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

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

常量

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

这样做:

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 &lt; n; i++)

{

    ...

}

 

for (i = 0; i &lt; n; i++)

{

    ...

}

Not this:

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

{

    ...

}

 

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

{

    ...

}

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

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

构造函数

如果一个类有实例变量,要书写一个构造函数,显示使用super(),即使它没做任何事情。

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

这样做:

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

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

帮助类

空语句。

文件组织

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

版权声明

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

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

//

//  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,Styles,Effects,Excluded IPIs和其它元数据顺序分成几个部分.

在每个部分前面加一个小的说明头.注意每个说明头是40个字符宽度在//和其后 区块名之间有两个空格.

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

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

//  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=&quot;horizontalAlign&quot;, kind=&quot;style&quot;)]

[Exclude(name=&quot;verticalAlign&quot;, kind=&quot;style&quot;)]

 

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

//  Other metadata

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

 

[DefaultBindingProperty(source=&quot;text&quot;, destination=&quot;text&quot;)]

[IconFile(&quot;Text.png&quot;)]

Class声明

TBD

Version.as include语句

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

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

实现注释

TBD

类初始化

TBD

类常量

将静态常量声明置于此。

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

类最小化

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

类资源

TBD

类变量

TBD

类属性

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

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.

类方法

放置静态方法声明.

构造函数

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:

<!--[if !supportLists]-->·         <!--[endif]-->Developers with smaller screens don't have to scroll horizontally to read long lines.

<!--[if !supportLists]-->·         <!--[endif]-->A comparison utility can display two versions of a file side-by-side.

<!--[if !supportLists]-->·         <!--[endif]-->The font size can be increased for projection before a group without requiring scrolling.

<!--[if !supportLists]-->·         <!--[endif]-->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 < n; i++)

    {

        if ()

        {

            x = horizontalGap * i;

            y = verticalGap * i;

        }

    }

}

Not this:

function f():void {

    var n:int = numChildren;

    for (var i:int = 0; i < n; 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,

               parameter2:String,

                    parameter3:Boolean):void

 

public function aVeryLongFunctionName(

    parameter1:Number, parameter2:String,

    parameter3:Boolean):void

Function calls

TBD

Do this:

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 < b)

Not these:

if(a < b)

 

if( a < b )

 

if ( a < b )

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 < n; i++)

Not these:

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

 

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

 

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

If the for clause needs to wrap, indent the subsequent lines after the left parenthesis.

for (var aLongLoopVariableName:int = aLongInitialExpression;

     aLongLoopVariableName < aLongUpperLimit;

     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文档

属性注释

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

/**

 *  @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

分享到:
评论

相关推荐

    AS3编码规范

    ### AS3编码规范详解 #### 一、概述 AS3编码规范是一套旨在提升Adobe Flash平台应用程序质量和可维护性的指导原则。本规范由Artlee在2010年提出,结合了作者多年来的Flash项目开发及管理经验,吸收了驼峰命名法与...

    阿里巴巴编码规范AS工具插件

    阿里巴巴编码规范AS工具插件是Java开发者遵循高质量编程标准的重要辅助工具。该插件名为"Alibaba Java Coding Guidelines",版本为1.0.5,旨在帮助开发人员在使用IntelliJ IDEA或Android Studio等集成开发环境(IDE...

    flex+AS3编程规范

    在Flex与AS3的编程环境中,遵循一套统一的编码规范对于提高代码的可读性和可维护性至关重要。以下将详细介绍Flex + AS3编程规范中涉及的关键知识点,包括缩写规则、文件命名、包与命名空间管理、接口与常量命名、...

    DotNet编码规范.doc

    《C#通用编码规范》是GDTEC公司为新员工培训和技术部门制定的一份详尽的编程指导文档,旨在提高代码质量和团队协作效率。本文档主要涵盖了注释规范、.NET编码规范和数据库编码规范等多个方面,以下是这些规范的详细...

    C#编码规范编码规范编码规范

    C#编码规范是编程实践中非常重要的一个环节,它有助于提高代码的可读性、可维护性和团队间的协作效率。以下是对这些规范的详细说明: **一、类型级单位的命名** 1. **类(Class)**:类的命名应当以名词或名词短语...

    SQL高性能编码(编码规范)

    ### SQL高性能编码规范详解 #### 一、引言 在软件开发过程中,SQL作为数据库查询语言,被广泛应用于数据检索和处理。为了提高SQL代码的性能及可读性,制定一套标准化的编码规范至关重要。本文将详细介绍《SQL高...

    Adobe Flex 编码规范

    在开发Flex项目时,遵循一套编码规范至关重要,这有助于提高代码的可读性、可维护性和团队协作效率。以下是关于“Adobe Flex 编码规范”的详细解读: 1. **命名规范**: - 变量和函数名应使用下划线分隔的驼峰式...

    VB的编码规范,对VB感兴趣的可收藏。

    VB(Visual Basic)编码规范是为了提高代码的可读性、可维护性和团队协作效率而设定的一系列编程标准。以下是对VB编码规范的一些关键点的详细解释: 1. **IDE设置**: - **要求变量声明**:开启此选项,确保在编写...

    DotNet项目编码规范

    ### DotNet项目编码规范 #### 一、程序代码的注释 **1. 存储过程的头部注释** 在DotNet项目中,为确保代码的可读性和维护性,每个存储过程都应当包含头部注释。这些注释通常位于存储过程的最前面,包含了重要的元...

    JAVA编码规范全集

    ### JAVA编码规范全集 #### 1. 介绍 ##### 1.1 为什么要有编码规范 编码规范在软件开发过程中扮演着至关重要的角色。它不仅有助于提高代码的可读性和可维护性,还能增强团队协作效率。以下是几个关键理由: - **...

    DELPHI真正的编码规范

    **DELPHI真正的编码规范** Delphi是一种强大的Object Pascal编程语言,它以其高效、灵活性和丰富的组件库而受到开发者的喜爱。为了确保代码的可读性、可维护性和团队协作的有效性,遵循一定的编码规范至关重要。...

    go编码规范正文

    ### Go编码规范详解 #### 一、命名规范 在Go语言开发中,良好的命名习惯能够显著提高代码的可读性和可维护性。 ##### 1.1 文件名命名规范 - **命名方式**:文件名应使用小写字母,并且尽可能直观地反映出文件中...

    VB.NET编码规范

    VB.NET编码规范是软件开发中的一个重要环节,它确保了代码的可读性、可维护性和团队协作的高效性。以下是对这些规范的详细解释: 1. **工程**: 工程组织应清晰,每个项目应有明确的功能划分。避免在一个项目中...

    AS3仿web菜单

    AS3是面向对象的编程语言,基于ECMAScript 4规范,具有类、包、接口等特性。创建自定义控件时,我们通常会定义一个类,这个类继承自已有的UIComponent或DisplayObject类,以便利用它们提供的基本绘图和事件处理功能...

    Adobe Flex编码指南v1.2(AS3 Flex3程序代码编写规范)

    3. 编码规范: - 命名规则:变量、函数和类的命名应遵循驼峰式命名法,避免使用保留字。 - 注释:良好的注释可以提高代码可读性,注释应简洁明了,描述功能和用途。 - 代码结构:使用适当的缩进、空行和空格,...

    python编码规范

    ### Python编码规范详解 #### 背景介绍 Python作为一种广泛应用的高级编程语言,在软件开发、数据科学、网络爬虫等多个领域发挥着重要作用。为了提高代码的可读性、可维护性和一致性,遵循一定的编码规范变得尤为...

    Scala编码规范(来自zhangyi教练博客)1

    在 Scala 编程中,遵循一定的编码规范可以提高代码质量和团队协作效率。以下是对给定的 Scala 编码规范的详细解释: **格式与命名** 1. **代码格式**:保持良好的代码格式至关重要。使用两个空格进行缩进,避免...

    磁编码传感器AS5600驱动程序

    磁编码传感器AS5600是一种高性能的磁性位置检测器,常用于精确的位置和速度测量,尤其在工业自动化、机器人技术以及精密机械设备等领域。AS5600由奥地利微电子公司(Austrian Microsystems)生产,它利用磁场的变化来...

Global site tag (gtag.js) - Google Analytics