云自无心水自闲

天平山上白云泉,云自无心水自闲。何必奔冲山下去,更添波浪向人间!
posts - 288, comments - 524, trackbacks - 0, articles - 6
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

一、在JavaScript中调用Flex方法
在Flex中可以用ExternalInterface来调用Flex的方法,途径是通过在Flex应用可调用方法列表中添加指定的公用方法。在Flex应用中通过调用addCallback()可以把一个方法添加到此列表中。addCallback将一个ActionScript的方法注册为一个JavaScript和VBScript可以调用的方法。
addCallback()函数的定义如下:
addCallback(function_name:String, closure:Function):void
function_name参数就是在Html页面中脚本调用的方法名。closure参数是要调用的本地方法,这个参数可以是一个方法也可以是对象实例。

举个例子:
<mx:Script>
    import flash.external.*;
    public function myFunc():Number {
        return 42;
    }
    public function initApp():void {
        ExternalInterface.addCallback("myFlexFunction",myFunc);
    }
</mx:Script>
那么在Html页面中,先获得SWF对象的引用,也就是用<object .../>声明的Swf的Id属性,比如说是MyFlexApp。然后就可以用以下方式调用Flex中的方法。
<SCRIPT language='JavaScript' charset='utf-8'>
    function callApp() {
        var x = MyFlexApp.myFlexFunction();
        alert(x);
    }
</SCRIPT>
<button onclick="callApp()">Call App</button>



二、在Flex中调用 JavaScript
你可以调用Html页面中的JavaScript,通过与JavaScript的交互,可以改变Style,调用远程方法。还可以将数据传递给Html页面,处理后再返回给Flex,完成这样的功能主要有两种方法:ExternalInterface()和navigateToUrl()。
在Flex中调用JavaScript最简单的方法是使用ExternalInterface(),可以使用此API调用任意JavaScript,传递参数,获得返回值,如果调用失败,Flex抛出一个异常。
ExternalInterface封装了对浏览器支持的检查,可以用available属性来查看。
ExternalInterface的使用非常简单,语法如下:
flash.external.ExternalInterface.call(function_name: String[, arg1, ...]):Object;
参数function_name是要调用的JavaScript的函数名,后面的参数是JavaScript需要的参数。
举个例子说明如何调用JavaScript函数
Flex应用中,添加如下方法:
<mx:Script>
<?xml version="1.0" encoding="iso-8859-1"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml">
    <mx:Script>
        import flash.external.*;
    
        public function callWrapper():void {
            var f:String = "changeDocumentTitle";
            var m:String = ExternalInterface.call(f,"New Title");
            trace(m);
        }
    </mx:Script>
    <mx:Button label="Change Document Title" click="callWrapper()"/>
</mx:Application>
Html页面中有如下函数定义:
<SCRIPT LANGUAGE="JavaScript">
    function changeDocumentTitle(a) {
        window.document.title=a;
        return "successful";
    }
</SCRIPT>


评论

# re: Flex与JavaScript的交互:调用JavaScipt或者被JavaScript调用  回复  更多评论   

2006-12-04 10:44 by IT DAIMON
非常感谢,这篇文章对于我这个初学者来说真是太有帮助了 ^_^

# re: Flex与JavaScript的交互:调用JavaScipt或者被JavaScript调用[未登录]  回复  更多评论   

2008-04-28 21:09 by gg
good

# re: Flex与JavaScript的交互:调用JavaScipt或者被JavaScript调用  回复  更多评论   

2008-10-29 10:01 by 杨爱友
根据我刚才的迷惑给你添加一句,楼主的“Html页面中有如下函数定义:”这句中html页面指的是与你mxml文件对象的页面,比如上面的flex应用名为first.mxml,那么那段Javascript函数加在first.html里。
其实在eclipse里运行mxml时运行的就是对应的html文件,只是这个html文件里被嵌入了mxml。

# re: Flex与JavaScript的交互:调用JavaScipt或者被JavaScript调用  回复  更多评论   

2009-07-07 13:26 by 三十岁
好像firefox中不行啊

# re: Flex与JavaScript的交互:调用JavaScipt或者被JavaScript调用  回复  更多评论   

2009-09-17 20:38 by HalZhang
正要用,学习了

# re: Flex与JavaScript的交互:调用JavaScipt或者被JavaScript调用  回复  更多评论   

2012-04-06 09:47 by 孙波波
@杨爱友
请问clean一下就没了,这怎么办?

# re: Flex与JavaScript的交互:调用JavaScipt或者被JavaScript调用  回复  更多评论   

2012-09-13 10:48 by heson
嗯,还不错。

只有注册用户登录后才能发表评论。


网站导航: