`
gdljg0460
  • 浏览: 43078 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

初学Flex的一点小小经验

    博客分类:
  • flex
阅读更多

 1. Flex结合tomcat
Flex只是个运行库或者说是web application,用来处理mxml类型的文件,其运行库就是Flex.war,所以它可以部署到任何一个兼容的jsp服务器上:比如 Tomcat, weblogic、websphere、Jrun,Jboss等,而Coldfusion目前也是运行库或者说是web application,用来处理cfml类型的文件,其运行库就是cfusion.war,所谓standalone版本的coldfusion只是把 jrun和cfusion.war一起打包安装而已,所以就没有Flex和Coldfusion结合之说了。
所以要想tomcat做flex的服务器,很简单的说安装完Flex Dada Services,目前名字叫Adobe_LiveCycle_Data_Services,我本人安装的版本是 (Adobe_LiveCycle_Data_Services_ES_2.5.1)
需要的话可以共享给大家,你也可以自己去下载,下载完不用去找序列号,因为我差了半天也没查到,默认可以有60天的试用期。
下一步需要做的就是把flex项目下的flex.war和samples.war拷贝到tomcat下的webapp目录里,考完后, tomcat会自动部署文件,不需操作,这样输入项目路径 : http://localhost:8080/samples 就可以看到里面的flex程序了,就是这么简单。
2.FLEX结合JSP
其实flex里夹杂了ajax异步调用的技术,因为本身ACTIONSCRIPT就和JAVASCRIPT有着异曲同工之妙。我做了一个例子是参 考手册上面的,不过自己改了一下,大概的程序就是这样的,首页当然是flex服务器来解析hxml,然后后台通过jsp文件交互数据库,然后把数据动态的 封装成xml格式,最后在把xml标签与flex程序绑定在一起,就可以了。 这样当运行flex前端程序的时候,后台就会把绑定好的数据显示到了flex的组件里,看起来很有成就感。哈哈。。。。。。

我的mxml代码:

 

<?xml version="1.0" encoding="utf-8"?> 
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" creationComplete="feedRequest.send()" backgroundGradientColors="[#000000, #000000]"> 
<mx:HTTPService id="feedRequest" url="http://localhost:8080/test/index.jsp" useProxy="false"> 
<mx:request xmlns=""> 
<directory>{test.text}</directory> 
</mx:request> 
</mx:HTTPService> 

<mx:Panel id="blog" width="359" height="520" title="{feedRequest.lastResult.rss.channel.title}" verticalCenter="188.5" horizontalCenter="179"> 
<mx:DataGrid id="dgPosts" dataProvider="{feedRequest.lastResult.rss.channel.item}" width="340" height="167"> 
<mx:columns> 
<mx:DataGridColumn headerText="题目" dataField="title"/> 
<mx:DataGridColumn headerText="路径" dataField="url"/> 
</mx:columns> 
</mx:DataGrid> 
<mx:TextArea width="388" height="129" htmlText="{dgPosts.selectedItem.description}"/> 
<mx:LinkButton label="查看详细" click="navigateToURL(new URLRequest(dgPosts.selectedItem.url));"/> 

<mx:Label text="选择ID号" /> 
<mx:TextInput id="test" width="115" height="23"/> 
<mx:Label text="{test.text}" /> 
<mx:Button label="登陆" id="Submit" click="feedRequest.send();"/> 
</mx:Panel> 
<mx:Image width="717" height="151" top="31" horizontalCenter="0"> 
<mx:source>file:///C|/Documents and Settings/Administrator/桌面/banner.gif</mx:source> 
</mx:Image> 
<mx:MenuBar x="188" y="203" width="539" height="45"></mx:MenuBar> 
</mx:Application> 
  


注释:
(1).application里creationComplete="feedRequest.send()" 这一属性是每次程序运行时,调用httpservice 里的Send()方法,在这个程序里实际上是请求http://localhost:8080/test/index.jsp,
把得到的数据以xml形式返回,把内容绑定到DataGrid 的组件上,flex是这样来绑定的:

(2).dataProvider="{feedRequest.lastResult.rss.channel.item}" 此句的语法,应该是,得到最后的返回结果,按照rss,channel,item此三层标签去绑定所遍历的数据,
<mx:columns>
<mx:DataGridColumn headerText="题目" dataField="title"/>
<mx:DataGridColumn headerText="路径" dataField="url"/>
</mx:columns>
以上代码就是创建分别叫题目和路径的2个列,title和url即为遍历出来的信息源标签。
(3).click="navigateToURL(new URLRequest(dgPosts.selectedItem.url));" linkbutton的属性,强调一点的是dgPosts是datagrid中所产生的选项,而navigateToURL(new URLRequest(url))此句就是另外打开一个url。

3. Flex 和数据库MYSQL(目前公司用的MYSQL)
这个时候可能有的人要问了,flex如何传值呢? 后台怎么接收有FLEX界面提交的值呢?
带着这个问题,让我们进入下个简单的程序:
先写一个简单的flex组件,代码如下
<mx:Label x="10" y="10" text="用户名" id="label1"/>
<mx:TextInput x="53" y="8" id="username"/>
<mx:Label x="10" y="66" text="密码" id="label2"/>
<mx:TextInput x="55" y="64" id="password" displayAsPassword="true"/>
<mx:Button x="55" y="113" label="登陆" id="Submit" click="login_user.send();"/>
这就是一个基本的用户交互界面,做完特效可以变成如下界面:


这个时候需要注意的是数据绑定,
数据的绑定也是通过FLEX标签来定义的。。

<mx:HTTPService id="login_user" result="checkLogin(event)" showBusyCursor="true" method="POST" url="http://localhost:8080/test/MyJsp.jsp" useProxy="false">
<mx:request xmlns="">
<username>
{username.text}
</username>
<password>
{password.text}
</password>



</mx:request>
</mx:HTTPService>

这个代码说明了,我本地项目的MyJsp.jsp会去接受此控件传过来的值,之前我测试是否接收到了FLEX传值的时候,是这样测试的 :
在MyJsp.jsp页面打印
<% out.println(“success”); %>

结果半天就没看到jsp页面输出成功信息。


后来经过MSN里探讨,原来flex本身就有着异步调用的过程,所以它不会显示JSP页面的内容,

呵呵,,原来是这样,,浪费我半天的时间,还以为程序错误呢。。很感谢他。。

这样以来,我在jsp页面 直接打印
<% System.out.println(username); %>
<% System.out.println(password); %>

这样在后台就打印出来了 username 和 password;

所以,可以得到了flex 页面传来的数据,这样后台就完全可以用 jsp 或者 struts 等来实现和数据库的交互过程。

看来flex入门真是不容易啊。。如果没有人引路,估计我还自己停留在某一个地方,原地不动呢,
所以总体看来,程序都是相同的,高人的指点也是必须的,呵呵
以上内容都是我自己总结的,希望能相互学习。。呵呵




4. flex 和 xml
以下内容 是我查资料时候看到的,代码可以直接用,很快捷。。。。。。。

其实很久以前我就有过用Flash动态生成xml菜单的想法,可是…(种种原因)…没实现,当时非常不甘心。
现在有Flex了,我又想把xml菜单做一下,昨天搞了一天,终于小有成果,就来和大家分享一下,我认为代码其实写的不好,因为我是从网上七拼八凑拿来的代码,好的是一种思路,‘拖动式的思路’(暂且用这个词吧)
代码说明:主要代码段都在Panel组件里,而在Panel里Tree的作用 举足轻重,Tree的功能很强大,在内部就拖动根节点和叶节点,任意拖动节点就免去了代码实现节点们顺序的问题,我当时就被它这点折服了,还又个垃圾箱, 你可以将根节点或叶节点拖到垃圾箱里,这样也免去了删除节点的麻烦,我其实就只完成了个增加节点的功能,并且还只是在最后增加节点(不过由于其天生可拖动 性,我这样就完全可以了,你可以把生成的最后节点拖到想要的位置啊!!)。好了,我也不多说了,取之于网民,给之于网民,代码和大体效果下面都有,(里面 又很多效果,希望你都理解!毕竟flex太强大了)Enjoy it!!

<?xml version="1.0" encoding="utf-8"?> 
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"> 
<mx:Script> 
<![CDATA[ 
import mx.collections.XMLListCollection; 

[Bindable] 
var companyList:XMLListCollection=new XMLListCollection(); 

private function addFolder():void 
{ 
var newNode:XML = <node label="单击此处修改" url="" isBranch="true"> 
<node label="单击此处修改" url=""/> 
</node>; 
companyList.addItem(newNode); 
} 

private function addLeaf():void 
{ 
var newNode:XML =<node label="单击此处修改" url=""/> 
companyList.addItem(newNode); 
} 

]]> 
</mx:Script> 

<mx:Panel id="panel" width="500" height="450" layout="absolute" horizontalCenter="-1" verticalCenter="0" title="修改Lebel"> 

<mx:Tree id="XmlTree" width="282" height="223" x="0" showRoot="false" editable="true" 
dataProvider="{companyList}" labelField="@label" dragEnabled="true" dropEnabled="true"/> 

<mx:Tree id="DirtyTree" width="75" height="25" x="302" showRoot="false" dropEnabled="true" y="198"/> 

<mx:Button x="96" y="231" label="Creater Xml" 
click="txt.text=''+XmlTree.dataProvider;menu.dataProvider=XmlTree.dataProvider;menu.labelField='@label'"/> 
<mx:TextArea id="txt" x="0" y="261" width="100%" height="127"/> 
<mx:Button x="290" y="71" label="Add Folder" click="addFolder()" width="97"/> 
<mx:Button x="290" y="118" label="Add Leaf" width="97" click="addLeaf()"/> 

<mx:ComboBox x="290" y="19" id="cobox" 
dataProvider="{[{label:'修改Label', data:'@label'}, {label:'修改Url', data:'@url'}]}" 
change="XmlTree.labelField=cobox.selectedItem.data;panel.title=cobox.selectedLabel"> 
</mx:ComboBox> 
<mx:Label x="324" y="172" text="垃圾箱" width="35" textAlign="center"/> 


</mx:Panel> 
<mx:MenuBar id="menu" y="97" horizontalCenter="0"> 
</mx:MenuBar> 

</mx:Application> 

 

分享到:
评论

相关推荐

    初学FLEX必看资料

    本资料是为初学者准备的,旨在帮助初次接触Flex的人快速掌握基本概念和实践操作。以下是针对压缩包文件中的内容进行的知识点解析: 1. **Global.asax**:在ASP.NET中,Global.asax文件是应用程序全局事件处理程序,...

    flex 初步认识 初学者的必读

    本篇文章将带你初步了解Flex,并为初学者提供一些必要的学习指南。 Flex的主要目标是简化用户界面的开发,使开发者能够创建具有丰富交互性和动态视觉效果的Web应用。它提供了强大的组件库,可以用来快速构建常见的...

    Flex 登录界面 开发经验分享

    ### Flex登录界面开发经验分享——CSS层叠样式表的应用 #### 一、引言 随着Flex技术的发展,越来越多的企业和个人...希望本文档能够帮助正在学习Flex的初学者更好地理解和掌握相关知识,从而提升自己的开发技能。

    Flex+入门(适用于初学者)

    标题:Flex+入门(适用于初学者) 描述:本文旨在为初学者提供详细的Flex+入门知识,涵盖MXML和ActionScript的基础应用。 知识点详述: ### 1. Flex+概述 Flex+是一种基于ActionScript的开源框架,用于构建高...

    flex4初学者程序

    这个"flex4初学者程序"是一个很好的资源,适合那些想要了解或深入学习Flex4和Flash Builder 4.0的开发者。下面将详细介绍Flex4、Flash Builder 4.0以及压缩包中包含的文件可能涉及的知识点。 1. **Flex4**:Flex4是...

    Flex资料大全(Flex白皮书 Flex cookbok Flex编程指南 Flex设计模式等)

    这些资源的集合为学习和精通Flex提供了丰富的素材,无论你是初学者还是有一定经验的开发者,都能从中找到所需的知识点,提升自己的技能水平。通过深入学习这些文档,你可以掌握如何使用Flex构建交互性强、用户体验...

    Flex 初学大礼包 内容很多

    Flex初学大礼包 flex 的配置 Flex 教程 源代码 很好 愿与君共享

    FLEX安装和配置全步骤

    本篇文章将详细介绍FLEX的安装与配置过程,帮助初学者快速上手。 首先,我们需要下载FLEX的开发工具。Adobe提供了FLEX Builder和Apache Flex SDK两种选择。FLEX Builder是一款集成开发环境(IDE),内置了Flex SDK...

    flex 官方文档 中文教程

    Flex是由Adobe公司开发的一种开放...总之,Flex中文教程涵盖了Flex开发的各个方面,无论你是初学者还是有经验的开发者,都能从中受益。通过深入学习和实践,你可以创建出功能强大、用户体验优秀的富互联网应用程序。

    flex实战项目,flex开发

    7. **Flex入门**:对于初学者,Flex入门通常从安装Flex SDK和Flex Builder开始,然后学习基本的ActionScript语法和MXML元素。通过搭建简单的Hello World程序,逐步熟悉Flex开发环境和工作流程。 8. **Flexstore**:...

    flex全书籍 flex全书籍

    Flex全书籍涵盖了Adobe Flex这一开发框架的广泛知识,它是一个用于构建富互联网应用程序(RIA)的开源SDK。...无论是初学者还是有经验的开发者,这些书籍都提供了深入浅出的指导,帮助你充分利用Flex的优势。

    Flex3学习指南-是初学者学习Flex必备资料,这是第一套

    Flex3学习指南是一份专为初学者设计的全面教程,旨在帮助他们掌握Adobe Flex 3这一强大的富互联网应用程序(RIA)开发框架。Flex 3是一个基于ActionScript 3.0的开源框架,它允许开发者创建交互性强、功能丰富的Web...

    flex + java 初学者 笔记 学习资料

    本文档是针对Flex和Java初学者的学习笔记,涵盖了Flex中的基础组件、文本处理、样式设计、行为对象以及动画效果。 一、Flex基础组件 1. Button:按钮组件,可以设置文字和图标,图标通过`icon="@Embed('图片路径')...

    flex简介项目--适合初学者

    这个“flex简介项目”是为初学者设计的,旨在帮助他们快速入门Flex开发,了解其基本概念和功能。 1. Flex框架:Flex是一个基于MX和Spark组件模型的开发框架,它提供了丰富的UI组件库,包括按钮、表格、图表等多种...

    FLEX网站源码 FLEX网站源码 FLEX网站源码

    10. **学习资源**:对于初学者,可以通过Adobe官方文档、在线教程和社区论坛获取学习资料。了解Flex的基本概念、语法和最佳实践,是掌握Flex网站开发的关键。 综上所述,这个“FLEX网站源码”压缩包可能是多个Flex...

    flex例子大全,对初学者很受用

    这个“flex例子大全”压缩包很显然是为了帮助初学者深入理解Flex技术而准备的,包含了多个实例,旨在通过实践来教授Flex的基础概念和应用。 1. **Flex基础**:Flex是一个开源的开发框架,主要用于创建交互式、高...

    flex笔记(对初学者有所帮助)

    此笔记为本人刚开始学习flex的时候自己对日常使用过程中自己整理的笔记,希望对初学者有所帮助。

    Flex学习宝典初学者的好帮手

    Flex学习宝典是一本专为初学者设计的资源丰富的学习指南,旨在帮助用户快速掌握Adobe Flex这一强大的富互联网应用程序(RIA)开发框架。Flex是一种基于ActionScript 3.0的开放源代码SDK,用于构建可在多种浏览器和...

    flex中文教程伴有flexbuilder

    这个“Flex中文教程”显然是为了帮助初学者掌握Flex开发技术,通过配合使用FlexBuilder这一强大的集成开发环境(IDE),让学习过程更为便捷高效。 教程中,你可以期待以下几个关键知识点的讲解: 1. **Flex基础**...

Global site tag (gtag.js) - Google Analytics