`
hehailin1986_163.com
  • 浏览: 153942 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

Flash/Flex获取外部参数

阅读更多
原文地址http://www.jexchen.com/?p=27
原文地址http://www.jexchen.com/?p=18

Part One: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);
            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>



Part Two:Flex程序如何获取html容器传递的URL参数值
在前面的一篇文章中我们讨论了利用Flex中的ExternalInterface类向swf传递参数。今天我们来谈谈另外一种更简捷的方法!
这次的方法是利用 SWFObject,SWFObject一个开源的JS模块,专门用来在HTML中嵌入Flash(*.swf)文件,利用该模块,使得插入Flash文件更加便捷、安全;并且使用SWFObject能自动检测各主流浏览器对Flash插件的支持并能作相应的处理。
目前SWFObject最新版为2.0,关于SWFObject的一些资源见下面:
官方站点
http://blog.deconcept.com/swfobject/
在google code的地址,这里有SWFObject 2.0的JS包及相关自动代码生成器的下载
http://code.google.com/p/swfobject/
SWFObject 2.0 官方文档(英文)
http://code.google.com/p/swfobject/wiki/SWFObject_2_0_documentation
SWFObject 2.0 官方文档(中文翻译)
http://farthinker.cn/2007/12/27/swfobject-2_0-doc-translation/
SWFObject 的使用非常简单,相信大家看了上面的文档就很清楚了,下面结合实例,谈谈利用SWFObject来获取URL参数值的做法。
我们的做法是,利用SWFObject的HTML容器代码自动产生器产生嵌入模板代码,点此处下载,注意在代码生成器中我们选定Publishing method(发布方式)为 Dynamic publishing(动态发布),编码设定为utf-8,关于静态发布与动态发布的详细介绍见官方文档。SWFObject 2.0 为开发人员提供了一些非常有用的函数,例如,我们要想获取*.html?name=JexChan&address=ChengDu这样的参数,就可以使用swfobject的getQueryParamValue函数,此函数可以直接获取以前面形式出现的get方式提交的参数值对,获取到参数值后赋给flashvars变量,最后再作为embedSWF方法的参数传递给相应的SWF文件。

包含SWF文件HTML容器代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
	<head>
		<title></title>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
		<script type="text/javascript" src="swfobject.js"></script>
		<script type="text/javascript">
			var flashvars = {};
			//获取URL参数对值,并赋给flashvars变量
			if (swfobject.getQueryParamValue("name") && swfobject.getQueryParamValue("address")) {
 				flashvars.name = swfobject.getQueryParamValue("name");
 		 		flashvars.address= swfobject.getQueryParamValue("address");
			}
 
			var params = {};
			var attributes = {};
			attributes.id = "myContent";
			//将嵌入的SWF文件写入对应id的div中去,并向SWF文件传入相应的参数
			swfobject.embedSWF("GetParamSWFObj.swf", "myAlternativeContent", "1000", "500", "9.0.0", "expressInstall.swf", flashvars, params, attributes);
		</script>
	</head>
	<body>
		<div id="myAlternativeContent">
			<a href="http://www.adobe.com/go/getflashplayer">
				<img src="http://www.adobe.com/images/shared/download_buttons/get_flash_player.gif" alt="Get Adobe Flash player" />
			</a>
		</div>
	</body>
</html>



通过SWFObject将SWF文件嵌入了HTML文件,那怎样在SWF文件中获取传过来的参数呢?在ActionScript3.0中,需要使用到LoaderInfo类,LoaderInfo类提供了被载入的SWF文件或其它图像文件(JPEG, GIF, 或 PNG)的相关信息。
要访问LoaderInfo对象有两种途径,如下图所示:

通过flash.display.Loader对象contentLoaderInfo属性来访问
通过显示对象(display object)的loaderInfo属性来访问
我们这里的SWF文件要想获取传递进来的参数,使用的是第二个途径,即显示对象的loaderInfo 属性来访问,这里的显示对象指根对象,可以使用stage,也可以使用root,它们在这里指向是同一个Stage(舞台),loaderInfo的parameters属性则包含了由外部向SWF传递进来的参数值对,它返回的值类型为Object。
我们这里仅使用了Flex生成出的SWF文件,而未使用Flex自动产生的HTML模板容器。
在Flex端的代码如下:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
<mx:Script>
	<![CDATA[
		private function clickHandler(evt:Event):void {
			//获取外部传给SWF文件的参数值对
			var obj:Object = stage.loaderInfo.parameters;
 
			if(obj.name != null && obj.address != null) {
				txtArea.text = "name: " + obj.name + "\n" 
								+ "address: " + obj.address;
			}
		}
	]]>
</mx:Script>
	<mx:Button y="96" label="GetParams" horizontalCenter="0" 
		click="clickHandler(event)"/>
	<mx:TextArea y="34" horizontalCenter="0" id="txtArea"/>
 
</mx:Application>


  • 大小: 12.3 KB
分享到:
评论
2 楼 jzzero 2010-04-11  
 
1 楼 jzzero 2010-04-11  

相关推荐

    flex3 接受外部参数

    本话题聚焦于Flex 3如何接受外部参数,这是一个关键功能,允许开发者传递数据到Flex应用程序,从而实现更灵活的交互和动态内容。 在Flex 3中,接受外部参数主要通过以下几种方式实现: 1. **URL变量**: 当Flex...

    Flex 4 接收外部参数(1)

    在 Flex 4 中,我们可以从不同来源接收外部参数,如启动参数、URL 参数或通过 XML 配置文件。这些参数可以用来初始化应用状态、设置默认值或根据用户需求动态调整界面。 1. **启动参数**:当应用程序被启动时,可以...

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

    由于Flash Player和浏览器之间的安全限制,Flex程序不能直接访问URL中的参数。因此,需要借助JavaScript作为中间层来读取这些参数。JavaScript可以通过`window.location`对象获取当前页面的URL,然后解析出参数部分...

    Flex获得URL参数值.doc

    在Flex开发中,有时我们需要从外部HTML页面向SWF文件传递参数,以便在Flex应用程序中使用这些参数。本文将详细讲解如何在Flex中获取HTML容器传递的URL参数值,以及如何利用JavaScript和ExternalInterface类来实现这...

    Flex 编译参数选项

    8. **外部资源**:如果应用使用了外部资源,如XML或CSS文件,可以使用`-include-resource`参数将它们包含进来。 9. **发布设置**:`-static-link-runtime-shared-libraries`选项可将运行时库静态链接到SWF中,减少...

    flex 和 js 交互

    1. **跨域策略文件**:由于Flash Player的安全限制,Flex应用在与JavaScript交互前需要加载一个跨域策略文件,允许它与不同源的JavaScript进行通信。这个文件通常命名为crossdomain.xml,放置在服务器的根目录下。 ...

    纯flex网站前台(httpservice、webservice进行数据交互)

    4. **数据交互流程**:在Flex应用中,通常会创建一个HTTPService或WebService对象,配置其URL、方法和其他参数,然后定义一个事件监听器来处理返回的数据。当用户触发某个操作时,如点击按钮,服务会被调用,然后在...

    Flex4.6-js修正版,之前一版JS无法调用flex,特此纠正

    - **添加外部接口**:在Flex应用中,需要通过`externalInterface.addCallback()`方法注册一个可被JavaScript调用的函数。同时,JavaScript可以通过`window['functionName']`来调用这个函数。 - **数据传递**:参数...

    CGI 传递参数给SWF (flex)

    在这个场景中,CGI被用来获取浏览器地址栏中传递的参数,并将这些参数转发给SWF(Shockwave Flash)文件。SWF是Adobe Flex开发的富互联网应用程序(RIA)的基础,它能够展示动态内容,如动画和交互式用户界面。 ...

    flex和javascript交互

    - **`closure`** 参数是指要在Flex应用内部执行的实际方法或对象实例。它可以是一个简单的函数,也可以是一个对象实例上的方法。 例如,在Flex应用中添加如下代码片段: ```actionscript import flash.external.*...

    Flex实现天气预报服务

    在本项目中,“Flex实现天气预报服务”指的是利用Flex的技术来创建一个应用,该应用能够通过调用外部的Web服务接口获取并显示天气预报信息。 Flex中的WebService组件是用于与SOAP(Simple Object Access Protocol)...

    flexpaper Flex中显示PDF功能

    使用FlexPaper,开发人员可以轻松地将PDF显示功能整合到他们的Flex项目中,无需依赖外部浏览器插件或第三方应用。作为一个Flex库,它可以被灵活地导入并定制以适应各种用户界面需求。FlexPaper提供了许多高级特性,...

    flex试题打包面试题挺好的

    根据提供的文件信息,我们可以归纳出一系列与Flex相关的知识点,这些知识点涵盖了Flex开发中的基础概念、事件处理、数据类型转换、数组操作等多个方面。下面将详细解释这些知识点。 ### 1. Flex 默认背景颜色的修改...

    Flex与处部的数据通信和图表

    在Flex开发中,与外部数据通信是至关重要的,这使得Flex应用程序能够从服务器获取和更新实时信息。Flex提供了三种主要的数据通信方式:HTTPService、WebService和Remoting。 **4.1.1 使用HTTPService** ...

    Flex与.NET互操作

    Flex作为一种基于Adobe Flash平台的应用程序开发框架,以其丰富的用户体验和高性能而著称;而.NET框架则是由微软公司开发的一套强大的应用程序开发平台。这两者之间的互操作性不仅能够拓展应用程序的功能边界,还能...

    Flex中采用Flex-config.xml进行命令行的编译

    在Flex开发中,`flex-config.xml`文件是一个至关重要的配置文件,它允许开发者自定义Adobe Flex编译器的参数和设置。这个文件控制了编译过程中的许多方面,包括优化级别、错误处理、库路径、元数据等。下面将详细...

    MapGIS IGServer Flex 问题集锦

    具体步骤包括安装FlexBuilder3集成开发环境以及两个FlashPlayer插件。程序安装过程中会自动安装Flexsdk3,Adobe公司FlexBuilder官方下载地址为:***,而Flexsdk3的下载地址为:***。 2. 创建MapGIS IGServer Flex...

    flex 利用FileReference上传firefox报2038错误

    对于需要身份验证的服务器,您可以使用Flash Player浏览器插件下载文件,但在所有播放器上进行上传以及在独立或外部播放器上进行下载都会失败。监听`FileReference`事件以确定操作是否成功完成并处理错误。” 2. **...

Global site tag (gtag.js) - Google Analytics