flex入门1

1,flex有两部分语言构成:mxml,ActionScript.
2,初学者可以认为 mxml=html  actionscript=javascript;
3,开发flex快速查阅apid的方式:
   打开动态帮助窗口,鼠标放在那个组件代码上,动态帮助窗口自动显示该组件的超链接。
   悬停帮助:鼠标停留在某个组件代码上一会儿就会弹出帮助层。
   shift+
3,javascript的事件处理机制和Actionscript的机会相同:主要区别在于ActionScript的事件处理机制还提供了一个事件对象。
   在ActionScript中,所有的事件都发端于一个通用的事件对象,事件通过继承添加其他详细信息。有了事件对象,就能轻松编写出具有高度可重用性的事件处理程序,因为事件处理程序可以从事件对象中获得事件的详细信息包括:
     1,事件的来源   clickEvelt.cameFrom
     2,数据的引用。
     3,事件的类型(例如是鼠标单击还是鼠标进入)
注意:CDATA标签的使用:
      由于mxml文件符合xml标准,因此必须遵循xml的规则。cdata在这里告诉flex builder方括号中的内容原样不动,不作为xml代码处理,如果不使用cdata那么如果出现大于,小于等符号flex会认为是标签的结束, 所以始终把Actionscript代码放进cdata中是明智的选择。
   下面是实例:
    <?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
			   xmlns:s="library://ns.adobe.com/flex/spark" 
			   xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600">
	<fx:Declarations>
		<!-- 将非可视元素(例如服务、值对象)放在此处 -->
	</fx:Declarations>
	<!--类似javascript的Actionscript-->
	<fx:Script>
		<![CDATA[
			import mx.controls.Alert;
			public function clickHandler(clickEvent:Event):void
			{
			  Alert.show("Event Type:" + clickEvent.type +
			             " came from:" + clickEvent.currentTarget.id);
			}
		]]>
	</fx:Script>
	<!--Mxml文件中添加的一切都可成为组建,像button这种可以看得见的组建又叫做控件-->
	<s:Panel x="84" y="86" width="367" height="211">
		<s:Button id="me" label="Hello World!" fontSize="40" x="0" y="0" click="clickHandler(event)"/>
	</s:Panel>
</s:Application>


2,调用函数
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
			   xmlns:s="library://ns.adobe.com/flex/spark" 
			   xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600">
	<s:layout>
		<s:BasicLayout/>
	</s:layout>
	<fx:Declarations>
		<!-- 将非可视元素(例如服务、值对象)放在此处 -->
	</fx:Declarations>
	<fx:Script>
		<![CDATA[
			import mx.controls.Alert;
			public function textMerge(input1:String,input2:String):String
			{
			var x:String = input1 + input2;
			return x;
			}
		]]>
	</fx:Script>
	<s:Group>
		<s:layout>
			<s:HorizontalLayout/>
		</s:layout>
		<s:TextInput id="value1"/>
		<s:Label text="and"/>
		<s:TextInput id="value2"/>
		<s:Button label="Join the two"
				  click="Alert.show(textMerge(value1.text,value2.text))"/>
	</s:Group>
</s:Application>


3,把Actionscript代码放进一个单独的文件中
   创建myFunctions.as文件内容如下:
   // ActionScript file
public function textMerge(input1:String,input2:String):String{
    var x = input1 + input2;
	return x;
}

   创建mxml文件并包含上面的Actionscript文件:
   <?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
			   xmlns:s="library://ns.adobe.com/flex/spark" 
			   xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600">
	<s:layout>
		<s:BasicLayout/>
	</s:layout>
	<fx:Declarations>
		<!-- 将非可视元素(例如服务、值对象)放在此处 -->
	</fx:Declarations>
	<fx:Script source="myFunctions.as"></fx:Script>
	<fx:Script>
		<![CDATA[
			import mx.controls.Alert;
		]]>
	</fx:Script>
	<s:Group>
		<s:layout>
			<s:HorizontalLayout/>
		</s:layout>
		<s:TextInput id="value1"/>
		<s:Label text="and"/>
		<s:TextInput id="value2"/>
		<s:Button label="Join the two"
				  click="Alert.show(textMerge(value1.text,value2.text))"/>
	</s:Group>
</s:Application>

你可能感兴趣的:(flex入门)