`
xuejianshan
  • 浏览: 222475 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Flex程序如何获取html容器传递的URL参数值

阅读更多

我们经常在Flex程序需要用从外部html向swf文件传递参数,(类似 test.html?name=jex&address=chengdu 地址中问号后面的参数对值)

首先要明确的是,一般我们在使用Flex Builder进行Flex开发时,编译后自动以html容器将swf文件包装起来了,所以一般来说,我们直接运行的是html,而非直接运行生成的swf文件。而Flex应用程序要获取外部html容器传入的参数,通常是用JavaScript来获取到相应参数,再让javaScript传递给ActionScript。

在Flex应用程序中,我们通常要用到ExternalInterface类,ExternalInterface主要用来让ActionScript直接与Flash Player容器进行通信。ExernalInterface类通常作为ActionScript与JavaScript进行通信的桥梁。

为了获取从html传入的URL参数,通常传递的顺序是:html容器—>JavaScript—>ExternalInterface—>ActionScript

 

具体实现:
在Flex中,通过调用ExternalInterface的call方法,参数为要调用的JavaScript函数,并返回JS函数调用的结果。如:

ExternalInterface.call("JavaScript函数");

 

在JS中,Window对象用来代表一个Web浏览器窗口,而窗口的Location对象则代表了当前显示的URL,于是,要想获取URL中的参数,

通常使用下面的语句:

 

window.location.href.toString  //得到URL的完整文本
 
window.location.search.substring  //得到问号后面部分的URL文本

 

:这里window属性引用的Window对象自身,而Window对象的location属性引用的是Location对象。

 


通常的参数对以test.html?name=jex&address=chengdu 这样的形式给出,在获取到问号后面的URL文本后,还需要对其分解,这时有两种途径,一种是分解过程在JS中完成,然后将最终的结果值传递给Flex,另一种是将分解的过程放在Flex中去完成。在这里使用的后者(这样只需写AS代码,而不用去写JS代码了^_^)

 

示例程序代码如下:

 

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
    creationComplete="init()">
<mx:Script>
    <![CDATA[
        import mx.controls.Alert;
 
        private var params:Object;
 
        private function init():void {
            btnID.addEventListener(MouseEvent.CLICK, clickHandler);
        }
 
        private function clickHandler(evt:Event):void {
            var args:Object = getParams();
            if(args.name != null && args.address != null) {
                dispID.text = "name:" + args.name + "\n" + "address:" + args.address;
            }
        }
 
        private function getParams():Object {
            params = {};
            var query:String = ExternalInterface.call("window.location.search.substring", 1);
            // Alert.show(ExternalInterface.call("window.location.href.toString",1));
            // Alert.show(query);
            if(query) {
                var pairs:Array = query.split("&");
                for(var i:uint=0; i < pairs.length; i++) {
                    var pos:int = pairs[i].indexOf("=");
                    //Alert.show(String(pos));
                    if(pos != -1) {
                        var argname:String = pairs[i].substring(0, pos);
                        var value:String = pairs[i].substring(pos+1);
 
                        params[argname] = value;
                    }
                }
            }
            return params;
        }
    ]]>
</mx:Script>
    <mx:Button id="btnID" y="118" label="GetParams" horizontalCenter="0"/>
    <mx:TextArea id="dispID" y="47" width="200" horizontalCenter="0"/>
 
</mx:Application>

 

 

Jex 原创,转载请注明出自:http://www.jexchen.com

 

 

分享到:
评论
3 楼 jzzero 2010-04-11  
  
2 楼 harman001 2009-10-14  
1 楼 roger_588 2009-03-05  

相关推荐

    flex获得html容器传递的url参数值

    总的来说,要从HTML容器传递的URL参数值到Flex应用,你需要: 1. 使用`ExternalInterface.call()`调用JavaScript函数获取URL查询字符串。 2. 在JavaScript中处理查询字符串,分解为参数对。 3. 将处理后的参数对通过...

    Flex程序如何获取html容器传递的URL参数值(转)

    这篇博客文章将讨论如何在Flex程序中获取HTML容器传递的URL参数值,这对于实现灵活的参数传递和配置至关重要。 在HTML中,我们可以为嵌入的SWF对象设置查询字符串参数,这些参数可以通过Flash Player传递给Flex应用...

    Flex获得URL参数值.doc

    本文将详细讲解如何在Flex中获取HTML容器传递的URL参数值,以及如何利用JavaScript和ExternalInterface类来实现这个过程。 首先,我们要明白,当我们使用Flex Builder进行开发时,编译后的Flex应用程序会被自动封装...

    html嵌入flex swf

    你需要提供 SWF 文件的 URL、容器 ID、以及可选的参数: ```javascript var flashvars = {}; // 用于传递给 SWF 的变量 var params = { // SWF 参数,如质量、背景色等 quality: "high", bgcolor: "#ffffff" ...

    将 Flex 集成到 Java EE 应用程序的最佳实践(完整源代码)

    不过,针对 Java EE 开发的服务器端应用,可以通过集成 BlazeDS,充分利用 AMF 协议并能轻易与 Flex 前端交换数据,这种方式是 Java EE 应用程序集成 Flex 的首选。 BlazeDS 是 Adobe LifeCycle Data Services 的...

    SSH+Flex之创建工程并测试成功

    - 修改`flex编译器`面板中的“附加编译参数”,例如设置为`-services "../WebRoot/WEB-INF/flex/services-config.xml" -locale en_US`。 #### 四、解决创建过程中的问题 1. **重新创建HTML模板** - 如果遇到HTML...

    +Flex+集成到+Java+EE+应用程序的最佳实践(完整源代码)

    通过 RemoteObject 进行调用虽然简单,但存在不少问题:首先,RemoteObject 是一个 Dynamic Class,Flex Builder 的编译器无法替我们检查参数类型和参数个数,这样,在编写 ActionScript 代码时极易出错。...

    上一篇的flex的远程对象调用,flex和spring集成分页的jar和截图

    4. 调用服务:在Flex客户端,通过RemoteObject调用Spring服务的方法,传递分页参数(如页码和每页大小)。 5. 处理返回结果:Spring服务执行查询并返回分页数据,Flex应用接收到数据后进行展示。 在实际开发中,还...

    flex通过my97实现时分秒

    在Flex中嵌入HTML容器,然后在HTML代码中引入My97的JavaScript库,通过JavaScript与Flex的通信接口(如ExternalInterface)来传递数据和控制事件。 4. 时间选择器实现:My97控件提供了小时、分钟和秒的选择功能,...

    整合Flex和Java--配置篇

    在IT行业中,Flex和Java的整合是开发富互联网应用程序(RIA)时常见的一种技术组合。Flex作为Adobe开发的开源框架,主要用于构建具有丰富用户界面的Web应用,而Java则提供了强大的后端处理能力。本篇文章将详细介绍...

    spring-flex官方文档

    BlazeDS是Adobe开源的一个项目,它提供了将Flex前端与Java后端服务连接的基础通信层,包括远程调用和消息传递功能。虽然之前也可以通过BlazeDS与Spring管理的服务进行交互,但Spring BlazeDS Integration提供了一个...

    Flex面试题及答案

    在Flex应用中,获取当前运行的URL可以通过`System.current.url`属性。然而,需要注意的是,这个属性在某些环境下可能不可用,尤其是当应用运行在本地文件系统或受限的沙箱环境中时。为了确保兼容性,建议使用`window...

    Flex用的IFrame组件

    这个组件允许你在Flex应用程序中展示网页或者交互式的HTML内容,而无需直接修改HTML模板。这种功能对于需要在Flex应用中集成外部服务、网页内容或者进行跨域通信的情况非常有用。 1. **IFrame组件介绍** IFrame...

    flex 入门必看,flex,java 操作

    Flex是一种用于构建富互联网应用程序(RIA,Rich Internet Applications)的技术,它由Adobe公司开发,主要用于创建动态、交互式的用户界面。在本文中,我们将深入探讨Flex与Java的集成以及如何通过RemoteObject进行...

    Flex与java通讯例子

    Flex与Java之间的通讯是Web开发中的重要一环,特别是在构建富互联网应用程序(RIA)时。Flex作为Adobe开发的开源框架,主要用于创建具有丰富用户界面的Web应用,而Java则是一种广泛应用的后端开发语言,提供了强大的...

    Flex 整合java基础资料

    `blazeds.war`是Flex BlazeDS项目,同样提供了Flex和Java之间的消息传递服务。根据需求,你可以选择其中一种,并调整Output folder的目录。 2. **创建Flex工程**:首先创建一个新的Flex项目,这是构建应用程序的...

    flex多组上传功能

    在多组上传中,我们可能需要为每组文件设置不同的目标URL或者传递不同的参数,这可以通过在上传前动态设置`FileReference`的`url`属性来实现。 为了更好地管理多组上传,我们可以使用ActionScript的异步处理能力,...

    MyEclipse+Flex+Blzeds入门浅谈.doc

    - **Blazeds**:Adobe 开发的一款实时消息传递服务器,用于构建基于 Flex 的富客户端应用程序。 - **Flex Builder Eclipse Plug-in**:用于 Eclipse 和 MyEclipse 的 Flex 开发工具。 ##### 1.1 安装 Flex Builder ...

Global site tag (gtag.js) - Google Analytics