Flex中TitleWindow传值

1、设计思路

(1)新建一个DataGrid,在其中最后一列加入三个按钮:新增、修改和删除;

(2)点击新增按钮,可以将表格新增一行;

(3)单击“修改”按钮,可以修改表格中该行的一些属性;

(4)单击“删除”按钮,会将表格中该行删除。

2、实现步骤

(1)新建一个应用程序,DataGrid.mxml

DataGrid.mxml:

<?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.collections.ArrayCollection;

			[Bindable]
			//表格数据源绑定
			private var grid:ArrayCollection = new ArrayCollection([
				{number:"2014010101",name:"张三",sex:"男",age:"19"},
				{number:"2014010102",name:"李思",sex:"女",age:"20"},
				{number:"2014010103",name:"蔡华",sex:"男",age:"21"},
				{number:"2014010104",name:"牛耳",sex:"女",age:"22"},
				{number:"2014010105",name:"兆司",sex:"男",age:"18"},
				{number:"2014010106",name:"胡柳",sex:"女",age:"19"},
				{number:"2014010107",name:"刘斯",sex:"男",age:"20"},
				{number:"2014010108",name:"孙阳",sex:"女",age:"22"},
				{number:"2014010109",name:"郑武",sex:"男",age:"21"},
				{number:"2014010110",name:"王雪",sex:"女",age:"20"},
				{number:"2014010111",name:"胡柳",sex:"女",age:"19"},
				{number:"2014010112",name:"刘斯",sex:"男",age:"20"},
				{number:"2014010113",name:"孙阳",sex:"女",age:"22"},
				{number:"2014010114",name:"郑武",sex:"男",age:"21"},
				{number:"2014010115",name:"王雪",sex:"女",age:"20"}
			]);
		]]>
	</fx:Script>

	<mx:VBox width="100%" height="100%" paddingBottom="100" paddingLeft="100" paddingRight="100" paddingTop="100">
		<mx:DataGrid id="dataGrid" dataProvider="{grid}" rowCount="{grid.length+1}" width="100%" textAlign="center">
			<mx:columns>
				<mx:DataGridColumn headerText="学号" dataField="number" id="stuNumber"/>
				<mx:DataGridColumn headerText="姓名" dataField="name"/>
				<mx:DataGridColumn headerText="性别" dataField="sex"/>
				<mx:DataGridColumn headerText="年龄" dataField="age"/>
				<mx:DataGridColumn headerText="操作">
					<mx:itemRenderer>
						<fx:Component>
							<mx:HBox width="100%" paddingLeft="40">

								<fx:Script>
									<![CDATA[
										import mx.managers.PopUpManager;

										/*添加按钮事件函数*/
										protected function addHandler(event:MouseEvent):void
										{
											var childWindow:ChildWindow = ChildWindow(PopUpManager.createPopUp(this,ChildWindow,true));
											var point:Point = new Point(100,100);
											childWindow.x = point.x + 400;
											childWindow.y = point.y + 50;
										}

										/*修改按钮事件函数*/
										protected function updateHandler(event:MouseEvent):void
										{
											var updateWindow:UpdateWindow = UpdateWindow(PopUpManager.createPopUp(this,UpdateWindow,true));
											var point:Point = new Point(100,100);
											updateWindow.x = point.x + 400;
											updateWindow.y = point.y + 50;
											updateWindow.stuNo = event.currentTarget.selectedItem.content;
										}

									]]>
								</fx:Script>

								<mx:LinkButton label="新增" click="addHandler(event)"/>
								<s:Label width="10"/>
								<mx:LinkButton label="修改" click="updateHandler(event)"/>
								<s:Label width="10"/>
								<mx:LinkButton label="删除"/>
							</mx:HBox>
						</fx:Component>
					</mx:itemRenderer>
				</mx:DataGridColumn>
			</mx:columns>
		</mx:DataGrid>

	</mx:VBox>
</s:Application>

(2)新建一个新增窗口组件,ChildWindow.mxml

ChildWindow.mxml:

<?xml version="1.0" encoding="utf-8"?>
<s:TitleWindow xmlns:fx="http://ns.adobe.com/mxml/2009"
			   xmlns:s="library://ns.adobe.com/flex/spark"
			   xmlns:mx="library://ns.adobe.com/flex/mx" width="400" height="300"
			   close="closeHandler(event)" title="新增窗口">
	<s:layout>
		<s:BasicLayout/>
	</s:layout>
	<fx:Script>
		<![CDATA[
			import mx.events.CloseEvent;
			import mx.managers.PopUpManager;

			/*关闭按钮函数*/
			protected function closeHandler(event:CloseEvent):void
			{
				PopUpManager.removePopUp(this);
			}

			/*取消按钮函数*/
			protected function cancelHandler(event:MouseEvent):void
			{
				PopUpManager.removePopUp(this);
			}

		]]>
	</fx:Script>
	<fx:Declarations>
		<!-- 将非可视元素(例如服务、值对象)放在此处 -->
	</fx:Declarations>

	<mx:VBox width="100%" height="100%" horizontalAlign="center">
		<mx:Form borderStyle="solid" borderColor="#CCCCCC" width="100%">
			<mx:FormHeading label="新增界面" fontSize="14"/>
			<mx:FormItem label="学号:">
				<s:TextInput id="stuNo" width="200"/>
			</mx:FormItem>
			<mx:FormItem label="姓名:">
				<s:TextInput id="stuName" width="200"/>
			</mx:FormItem>
			<mx:FormItem label="性别:">
				<s:TextInput id="stuSex" width="200"/>
			</mx:FormItem>
			<mx:FormItem label="年龄:">
				<s:TextInput id="stuAge" width="200"/>
			</mx:FormItem>
		</mx:Form>
		<mx:HBox width="100%" height="25">
			<s:Label width="60"/>
			<s:Button label="新增"/>
			<s:Label width="48"/>
			<s:Button label="取消" click="cancelHandler(event)"/>
		</mx:HBox>
	</mx:VBox>
</s:TitleWindow>

(3)新建一个修改界面组件,UpdateWindow.mxml

UpdateWindow.mxml:

<?xml version="1.0" encoding="utf-8"?>
<s:TitleWindow xmlns:fx="http://ns.adobe.com/mxml/2009"
			   xmlns:s="library://ns.adobe.com/flex/spark"
			   xmlns:mx="library://ns.adobe.com/flex/mx" width="400" height="300"
			   close="closeHandler(event)" title="修改窗口">
	<s:layout>
		<s:BasicLayout/>
	</s:layout>
	<fx:Script>
		<![CDATA[
			import mx.events.CloseEvent;
			import mx.managers.PopUpManager;

			/*关闭按钮函数*/
			protected function closeHandler(event:CloseEvent):void
			{
				PopUpManager.removePopUp(this);
			}

			/*取消按钮函数*/
			protected function cancelHandler(event:MouseEvent):void
			{
				PopUpManager.removePopUp(this);
			}

		]]>
	</fx:Script>
	<fx:Declarations>
		<!-- 将非可视元素(例如服务、值对象)放在此处 -->
	</fx:Declarations>

	<mx:VBox width="100%" height="100%" horizontalAlign="center">
		<mx:Form borderStyle="solid" borderColor="#CCCCCC" width="100%">
			<mx:FormHeading label="修改界面" fontSize="14"/>
			<mx:FormItem label="学号:">
				<s:TextInput id="stuNo" width="200"/>
			</mx:FormItem>
			<mx:FormItem label="姓名:">
				<s:TextInput id="stuName" width="200"/>
			</mx:FormItem>
			<mx:FormItem label="性别:">
				<s:TextInput id="stuSex" width="200"/>
			</mx:FormItem>
			<mx:FormItem label="年龄:">
				<s:TextInput id="stuAge" width="200"/>
			</mx:FormItem>
		</mx:Form>
		<mx:HBox width="100%" height="25">
			<s:Label width="60"/>
			<s:Button label="修改"/>
			<s:Label width="48"/>
			<s:Button label="取消" click="cancelHandler(event)"/>
		</mx:HBox>
	</mx:VBox>
</s:TitleWindow>

3、设计结果

(1)初始化时

Flex中TitleWindow传值的更多相关文章

  1. struts(二) ---中参数传值

    struts中参数传值的方式有 种: 第一种:直接通过属性来传值 第二种: 第三种:

  2. java中的传值与传引用

    java函数中的传值和传引用问题一直是个比较“邪门”的问题,其实java函数中的参数都是传递值的,所不同的是对于基本数据类型传递的是参数的一份拷贝,对于类类型传递的是该类参数的引用的拷贝,当在函数体中 ...

  3. Flex中设置Camera的视频清晰质量的最佳配合

    今天需要设置Flex中的Camera组件的一些属性,后来发现清晰度不是很高,于是捣鼓了上午半天,设置了很多的参数,竟然发现手册上就是有现成的一些设置方法,郁闷!不过我还是专门设置了几个有用和必要的属性 ...

  4. ArcGIS for Flex中引入google map作底图

    上篇文章到在ArcGIS View中引入google map,这里讲ArcGIS for Flex中引入google map作底图. 同样道理,以google map作底图,需要编写继承自TiledM ...

  5. Android中Intent传值与Bundle传值的区别详解

    Android中Intent传值与Bundle传值的区别详解 举个例子我现在要从A界面跳转到B界面或者C界面   这样的话 我就需要写2个Intent如果你还要涉及的传值的话 你的Intent就要写两 ...

  6. c#ASP.NET中页面传值共有这么几种方式

    一.目前在ASP.NET中页面传值共有这么几种方式: 1.Response.Redirect("http://www.hao123.com",false); 目标页面和原页面可以在 ...

  7. AS与JS相互通信(Flex中调用js函数)

    转载自http://www.blogjava.net/Alpha/archive/2009/06/27/284373.html Flex中As调用Js的方法是:     1.导入包 (import f ...

  8. SharedObject使用:在FluorineFx.net与Flex中使用共享对象维护在线用户列表实例【转】

    一.添加一个新的FluorineFx的服务类项目OnLineService,删除原有的Sample.cs,并添加一个用户类定义与一个ApplicationAdpater类:如下: /*-- User. ...

  9. Flex中NetConnection与NetStream的关系、及浏览器并发连接数测试[转]

    最近在做一个基于BS结构的视频会议系统,决定采用开源的FluorineFx.net与Flex结合的方法进行开发,前期开发都非常顺利,包括同步白板等.但到了实时视频传输的时候,原本设计是每个客户端可以显 ...

随机推荐

  1. Spring MVC执行的流程

    1.Spring MVC应用的开发步骤 a.在web.xml文件中定义前端控制器DispatcherServlet来拦截用户请求.由于Web应用是基于请求/响应架构的应用,所以 不管哪个MVC Web ...

  2. 解决axios传递参数后台无法接收问题

    1.根据下面几个方法改变前台传递参数方式 这样后台就可以直接根据传递的参数获取数据,如下图用户登录时直接传递用户名和密码 2.不改变前台传递样式修改后台接收方式

  3. SPOJ 7258 Lexicographical Substring Search [后缀自动机 DP]

    题意:给一个长度不超过90000的串S,每次询问它的所有不同子串中,字典序第K小的,询问不超过500个. 第一道自己做的1A的SAM啦啦啦 很简单,建SAM后跑kth就行了 也需要按val基数排序倒着 ...

  4. 关于WebApi 跨域问题的解决的方式

    最近在做WebApi 进行开发的时候 一直会遇到跨域方面的问题那么如何进行跨域问题其实非常的简单. 1.一直在使用WebApi的时候总是遇到跨域的问题 那么 什么是跨域?跨域,指的是浏览器不能执行其他 ...

  5. 汇编语言1(mooc)

  6. cocos2d-x代码阅读笔记 - 入口

    每一个C\C++程序都有一个非常有名的入口函数 main(),在Windows系统下,这个函数就变成了WinMain函数. 在cocos2d-x 2.0.4的Windows版本中,main函数非常简单 ...

  7. 简述java中equals()方法和==的区别

    ==与equals的主要区别是: ==: ==常用于比较原生类型(基本数据类型):byte,short,char,int,long,float,double,boolean,比较的是他们的值. 若用= ...

  8. qt中的tcp编程

    server .server.h #define DIALOG_H #include <QDialog> #include <QTcpServer> #include < ...

  9. JS工厂模式开发实践

    JS工厂模式开发实践 基于JS工厂模式的H5应用,实现了轮播图功能与滑屏功能,并且实现了文字大小的自适应功能,基于SASS样式开发. 核心的JS代码如下: index.js define(functi ...

  10. git取消文件跟踪

    在使用git的时候,有些文件是不需要上传的,所以就可以修改   .gitignore 例如: 如果是对所有文件都取消跟踪的话,就是 git rm -r -cached .  //不删除本地文件 git ...