加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Flex 接收HTML以GET方式传递的参数

发布时间:2020-12-15 04:31:18 所属栏目:百科 来源:网络整理
导读:?我们经常在Flex程序需要用从外部html向swf文件传递参数,(类似 test.html?name=jexaddress=chengdu 地址中问号后面的参数对值) 首 先要明确的是,一般我们在使用Flex Builder进行Flex开发时,编译后自动以html容器将swf文件包装起来了,所以一般来说,我

?我们经常在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函数调用的结果。如:

Xml代码

  1. ExternalInterface.call("JavaScript函数");??

?

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

通常使用下面的语句:

?

Xml代码

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

?

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

?


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

?

示例程序代码如下:

Xml代码?

?

 
 
  1. <?xml?version="1.0"?encoding="utf-8"?>???
  2. <mx:Application?xmlns:mx="http://www.adobe.com/2006/mxml"?layout="absolute"???
  3. ????creationComplete="init()">???
  4. <mx:Script>???
  5. ????<![CDATA[?
  6. ?????????import?mx.controls.Alert;?
  7. ?????????private?var?params:Object;?
  8. ?????????private?function?init():void?{?
  9. ?????????????btnID.addEventListener(MouseEvent.CLICK,?clickHandler);?
  10. ?????????}?
  11. ?????????private?function?clickHandler(evt:Event):void?{?
  12. ?????????????var?args:Object?=?getParams();?
  13. ?????????????if(args.name?!=?null?&&?args.address?!=?null)?{?
  14. ?????????????????dispID.text?=?"name:"?+?args.name?+?"n"?+?"address:"?+?args.address;?
  15. ?????????????}?
  16. ?????????}?
  17. ?????????private?function?getParams():Object?{?
  18. ?????????????params?=?{};?
  19. ?????????????var?query:String?=?ExternalInterface.call("window.location.search.substring",?1);?
  20. ?????????????//?Alert.show(ExternalInterface.call("window.location.href.toString",1));?
  21. ?????????????//?Alert.show(query);?
  22. ?????????????if(query)?{?
  23. ?????????????????var?pairs:Array?=?query.split("&");?
  24. ?????????????????for(var?i:uint=0;?i?<?pairs.length;?i++)?{?
  25. ?????????????????????var?pos:int?=?pairs[i].indexOf("=");?
  26. ?????????????????????//Alert.show(String(pos));?
  27. ?????????????????????if(pos?!=?-1)?{?
  28. ?????????????????????????var?argname:String?=?pairs[i].substring(0,?pos);?
  29. ?????????????????????????var?value:String?=?pairs[i].substring(pos+1);?
  30. ?????????????????????????params[argname]?=?value;?
  31. ?????????????????????}?
  32. ?????????????????}?
  33. ?????????????}?
  34. ?????????????return?params;?
  35. ?????????}?
  36. ?????]]>???
  37. </mx:Script>???
  38. ????<mx:Button?id="btnID"?y="118"?label="GetParams"?horizontalCenter="0"/>???
  39. ????<mx:TextArea?id="dispID"?y="47"?width="200"?horizontalCenter="0"/>???
  40. ????
  41. </mx:Application>???

转自:http://hi.baidu.com/fandywang_jlu/item/f8fb14dc951dc04ddcf9bee4

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读