Flash/Flex学习笔记(8):ActionScript3.0中的面对对象

简介: 首先要习惯AS3.0的几个BT约定: 1.一个.as文件中,只能定义一个类2.类名称必须与.as的文件名相同3.类定义中必须要有package包声明4.一个类最多只能有一个构造函数 5.包package的路径/名称约定: 这个初次接触时感觉有点小复杂,这样描述吧: 如果您在定义一个类时,pa...

首先要习惯AS3.0的几个BT约定:

1.一个.as文件中,只能定义一个类
2.类名称必须与.as的文件名相同
3.类定义中必须要有package包声明
4.一个类最多只能有一个构造函数

5.包package的路径/名称约定:

这个初次接触时感觉有点小复杂,这样描述吧:

如果您在定义一个类时,package的声明指定了名称,比如 package jimmy{ public class MyClass{...}},那么也就意味着需要对它引用的fla/as文件同级目录下,必须要有jimmy目录,而且jimmy目录下必须要有MyClass.as文件,而且MyClass文件中定义的类名必须为MyClass

然后你再引用该类时,必须导入该包

import jimmy.MyClass;

然后才能引用比如: var mycls:MyClass = new MyClass();

简单来讲,就是package名必须与目录名准确匹配。

这里还有一种特殊情况:

假如定义的package名称为jimmy.yang,根据上面的解释,则同级目录下必须要有jimmy.yang目录,这是没问题的,但是还可以这样组织目录结构,先创建一个jimmy目录,然后再创建一个yang目录,然后把as文件放到jimmy/yang/目录下,即:如果package名称中有"点"时(比如package a.b),则目录./a.b/ 与./a/b/效果相同,推荐用后者,这样层次更分明

 

好了,开始定义第一个类:

package {
	public class Human {

		public function Human(){
			this._name = "暂无名字";
			trace("Human构造函数被调用!");
		}
		
		private var _name:String;
		public function get Name():String{
			return _name;
		}
		
		////仅本类及子类定义中可用(实际上这个编译能过,但无法在子类中使用)
//		protected function set Name(n:String):void{
//			this._name = n;
//		}
		
		
		public function SetName(n:String):void{
			this._name = n;
		}
		
		//属性 set get示例
		private var _sex:Boolean 		
		public function set Sex(v:Boolean):void{
			_sex = v;
		}		
		public function get Sex():Boolean{
			return _sex;
		}
		
		public function Hello():void{
			trace(_name + " say:Hello World!");
			HiChildren();//测试在本类中调用受保护方法
		}
		
		//受保护方法
		protected function HiChildren():void{
			trace(_name + ":HiChildren");
		}
		
		//静态方法
		public static function WhoAmI():String{
			return "This is a Human Class"
		}			
	}	
}

 上面演示了构造器,属性(set/get),静态方法,受保护方法,注意:AS3中不支抽象类

package {
	public class Man extends Human {
		public function Man(n:String):void {
			super();
			SetName(n);
			super.Sex=true;
			trace("Man构造函数被调用!");
			HiChildren();//调用父类的受保护方法
		}

		//覆盖父类的性别设置函数
		public override function set Sex(v:Boolean):void {
			//Sex = true;//既然已经是男的,肯定是男的,这里就用不着了,除非咱们的系统支持"变性"
			trace("无法修改Man的性别");
		}

		
		//protected override function set Name(n:String):void{
//			//Name = n;//报错:对Name的引用有歧义
//		}
		
		
		public function ChaseGirls():void{
			trace(Name + "正在泡妞...");
		}
	}
}

 上面演示了类继承、覆写,下面调用这二个类测试一番:

var h:Human = new Human();
trace(h.Name);
h.Sex = true;
trace(h.Sex);
trace(Human.WhoAmI())
h.Hello();
//h.Name = "菩提树下的杨过";//这里会报错:属性只读,因为Name的set方法受保护
//h.HiChildren(); //同理无法调用 

var _man:Man = new Man("菩提树下的杨过");
_man.Sex = false;
trace("_man的性别:" + _man.Sex);
//trace(Man.WhoAmI());//静态方法将不被继承
_man.Hello();
//_man.HiChildren();//受保护方法无法在子类实例中使用
_man.ChaseGirls();

输出结果:
Human构造函数被调用!
暂无名字
true
This is a Human Class
暂无名字 say:Hello World!
暂无名字:HiChildren
Human构造函数被调用!
Man构造函数被调用!
菩提树下的杨过:HiChildren
无法修改Man的性别
_man的性别:true
菩提树下的杨过 say:Hello World!
菩提树下的杨过:HiChildren
菩提树下的杨过正在泡妞...

另外:做为符合ECMA规范的语言,ActionScript同样具有类似JavaScript的动态语言能力,我们把Human.cs再改一下:

package {
	public dynamic class Human {

		public function Human() {
			trace("Human构造函数被调用!");
		}

		public function toString():String {
			return "This is a Human instance!";
		}
	}
}

 注意dynamic关键字,加上这个后,Human就具备了动态修改属性的能力,看下面的测试代码:

var h:Human = new Human();
h.age = 10;
h.name = "菩提树下的杨过";
h.Say = function(){
	trace(h.name + ":Hello!" );
}
trace(h.toString());
trace(h.age);
trace(h.name);
h.Say();

var h2:Human = new Human();
trace(h2.age);//输出undefiend

输出结果:

Human构造函数被调用!
This is a Human instance!
10
菩提树下的杨过
菩提树下的杨过:Hello!
Human构造函数被调用!
undefined

如果一个类不想被继承,可以用final关键字标识,通常可以把一些辅助方法以static方式定义在final标识的类中,构成自己的工具类库(有点象c#中的静态类)

package {
	public final class MyUtils {

		public static function Test(s:String):String {
			trace(s);
			return s;
		}

		public static function Now():String {
			trace(new Date());
			return new Date().toLocaleString();
		}
	}
}

调用:

MyUtils.Test("hello test");
MyUtils.Now();

用final + static组合还能实现类似枚举的效果:

package {
	public final class LOGIN_REG_ERROR {
		public static const USERNAME_EXISTS = "用户名已存在";
		public static const PASSWORD_ERROR = "密码错误";
		public static const USENAME_ERROR = "用户名错误";
		//...
	}
}

使用示例:

var _loginResult:String;
if (_loginResult==LOGIN_REG_ERROR.USERNAME_EXISTS) {
	trace("用户名已存在!");
}

AS3.0还支持接口,看下面的代码

package {
	public interface IFly {
		function Fly():void;
	}
}


package {
	public class Duck implements IFly {
		public function Duck() {
			trace("来来,我是一只鸭子...");
		}
		
		public function Fly():void{
			trace("请叫我小飞侠,谢谢!")
		}
	}
}

最后看下原型链prototype:在javascript中正是得益于prototype才实现了很多惊人的应用,同样在as3.0中也存在原型链,所有动态属性的继承都可以通过原型继承实现,不过要注意的是:如果你准备对一个类进行prototype扩展以实现原型继承,则该类必须标识为dynamic,下面是示例代码:

var d:Duck = new Duck();
d.Fly();

Duck.prototype.Swim = function(){
	trace("正在游泳...请回避(裸泳?)");
}

d.Swim(); //请先将上一段代码中的Duck类定义加上dynamic关键字,否则本行代码无法执行


 

目录
相关文章
|
JavaScript 前端开发 内存技术
Flash/Flex学习笔记(9):ActionScript3.0与Javascript的相互调用
原理跟Silverlight中的几乎如出一辙(见Silverlight如何与JS相互调用): ActionScript3代码: btnCallJs.addEventListener(MouseEvent.
815 0
|
内存技术
Flash/Flex学习笔记(13):对象拖动(startDrag/stopDrag)
Flash中只有影片MovieClip(准确的讲是Sprite)可以调用startDrag,endDrag,创建对象拖动最简单的办法只要调用这二个方法即可 myobj.addEventListener(MouseEvent.
881 0
|
内存技术
Flash/Flex学习笔记(30):不用startDrag和stopDrag的对象拖动
对于从Sprite类继承来的对象,要实现拖放当然是Flash/Flex学习笔记(13):对象拖动(startDrag/stopDrag) 里讲的方法最方便,但是对于不是从Sprite类继承得来的对象,这startDrag/stopDrag是不能用的,这时候只能采用最通常用做法:利用Mouse_Dow...
763 0
|
4月前
|
开发者 容器
flex 布局属性在实际项目中的应用场景有哪些?
flex 布局属性在实际项目中的应用场景有哪些?
|
2月前
|
容器
Bootstrap5 Flex(弹性)布局4
排序:.order 类可设置弹性子元素的排序,范围从 .order-1 至 .order-12,数字越小优先级越高。外边距:.ms-auto 和 .me-auto 分别用于设置子元素的右侧和左侧外边距为 auto。包裹:.flex-nowrap(默认)、.flex-wrap 和 .flex-wrap-reverse 用于控制弹性容器中的子元素是否换行及换行方向。
|
3月前
|
前端开发 UED 容器
使用 Flex 布局实现垂直居中效果
【10月更文挑战第7天】
326 57
|
1月前
|
容器
Bootstrap5 Flex(弹性)布局6
使用 `.align-self-*` 类可控制指定子元素的对齐方式,包括 `.align-self-start`, `.align-self-end`, `.align-self-center`, `.align-self-baseline`, 和 `.align-self-stretch`。示例代码展示了如何在一个弹性布局中应用这些类,以实现不同设备上的响应式设计。
Bootstrap5 Flex(弹性)布局5
使用 .align-content-* 控制多行子元素在垂直方向上的堆叠方式,如 .align-content-start、.align-content-center 等。对于单行子元素,使用 .align-items-* 控制对齐,例如 .align-items-start、.align-items-center 等。示例代码展示了不同对齐效果的应用。
Bootstrap5 Flex(弹性)布局2
介绍Flex布局的水平和垂直方向控制。`.flex-row`使子元素水平排列,默认左对齐;`.flex-row-reverse`则右对齐。`.flex-column`让子元素垂直排列;`.flex-column-reverse`则反向排列。示例展示了不同类的效果,通过改变类名实现布局调整。
Bootstrap5 Flex(弹性)布局3
`.justify-content-*` 类用于调整弹性子元素的对齐方式,支持 start、end、center、between、around 等值。`.flex-fill` 类使所有子元素等宽,而 `.flex-grow-1` 则让指定子元素占据剩余空间。这些类在布局设计中非常实用。