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

JavaScript与ActionScript函数相互调用

阅读更多

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

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

2、在Flex(ActionScript)中调用 JavaScript(后面有实例)
在Flex中调用JS代码就方便得多。你可以调用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>

应用例子
1。在Flex程序中打开一个浏览器窗口
在线演示 | 源码下载

//---CallJSApp.mxml

<?xml version="1.0" encoding="utf-8"?>

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" viewSourceURL="srcview/index.html">

      <mx:Script>

            <![CDATA[

                  import mx.validators.ValidationResult;

                  import cwmlab.util.*;                 

                  private function openBrowser():void

                  {

                        MyURLUtil.openWindow("http://www.google.com/");

                  }                                  

            ]]>

      </mx:Script>

      <mx:HBox width="100%">

            <mx:Button label="open" click="openBrowser()"/>      

      </mx:HBox>     

</mx:Application>

//--MyURLUtil.as


package cwmlab.util

{   

      import flash.external.ExternalInterface;   

      public class MyURLUtil   

      {       

            protected static const WINDOW_OPEN_FUNCTION : String = "window.open";

           

            public static function openWindow(url : String, window : String = "_blank",

                  features : String = "") : void{

                  ExternalInterface.call(WINDOW_OPEN_FUNCTION, url, window, features);       

          }

      }

}// ActionScript file

 

分享到:
评论

相关推荐

    ActionScript与JavaScript相互调用

    ### ActionScript与JavaScript相互调用 #### 概述 随着互联网技术的发展,网页设计与开发逐渐成为一门重要的技能。在这一领域中,多种脚本语言和技术被广泛应用,以实现更加丰富的用户体验。其中,ActionScript与...

    ActionScript与JavaScript相互调用(论文)

    ### ActionScript与JavaScript相互调用 #### 摘要 随着网络技术的发展,网页互动性的增强变得至关重要。本文探讨了如何在ActionScript与JavaScript之间实现相互调用,并借此完成一些单靠任何一种语言都无法实现的...

    ActionScript与JavaScript在教学中的相互调用.pdf

    ActionScript与JavaScript在教学中的相互调用 ActionScript是Flash中的内置编程语言,而JavaScript是网页浏览器采用的网页文本编程语言。虽然这两种编程语言不同,但是如果在教学中将二者结合起来相互调用,却可以...

    javascript与flash相互调用

    一旦Flash加载完成,JavaScript可以使用`swfObject.getFlashById`获取Flash对象引用,然后调用`call`方法,传递要执行的ActionScript函数名和参数。 4. **Flash 调用 JavaScript**:在Flash ActionScript中,首先...

    javascript与actionscript的交互.[课件]

    它允许 ActionScript 代码直接调用 JavaScript 函数,并接收回调,反之亦然。这种方式支持 JSON 或其他数据格式的交换,使得数据共享更为方便。 - SWFObject:这是一个 JavaScript 库,用于动态插入 Flash 内容并...

    javascript与actionscript3.0通信实例.rar

    2. **在JavaScript中调用ActionScript函数**: 一旦AS3注册了回调函数,你可以在JavaScript中通过Flash对象调用它。通常,Flash对象是HTML页面中的`&lt;object&gt;`或`&lt;embed&gt;`标签。例如: ```javascript var flash...

    一个实现ActionScript 与JavaScript 进行相互通信的程序例子

    4. **接收JavaScript的回调**:同样,ActionScript也可以通过`ExternalInterface.call`调用JavaScript函数。例如,如果有一个名为`jsFunction`的JavaScript函数,可以在ActionScript中这样调用: ```actionscript ...

    js与as的相互调用Demo

    总结,"js与as的相互调用Demo"提供了一个基础的跨平台交互模型,它展示了如何在JavaScript和ActionScript之间无缝地传递信息和执行操作。这在需要结合两者优势的项目中尤其有用,比如创建具有互动性的多媒体内容或者...

    Flex与Javascript相互调用例子(附源码)

    使用`ExternalInterface.addCallback`方法注册一个ActionScript函数,使其可以被JavaScript调用,而`ExternalInterface.call`则用于从ActionScript调用JavaScript函数。 2. **FlashVars**:这是一种传递参数给嵌入...

    js调用as函数方法例子

    在JavaScript和Adobe Flex(一种基于ActionScript的富互联网应用程序开发框架)的交互中,常常需要在JavaScript中调用Flex中的ActionScript函数。这样的需求通常出现在Web应用中,当需要利用Flex的强大图形处理能力...

    SWF(ActionScript3.0)与JavaScipt(JS)通信示例

    今天花了一些时间整理出来了Swf 文件与JavaScript通信的示例,在此贴出供大家参考。 在ActionScript3.0与JavaScipt通信的时候需要用到...ActionScript函数可以返回一个值,JavaScript会立即接收它作为该调用的返回值。

    javascript和actionscript之间通信实例

    7. **Adobe AIR Native Extensions (ANE)**: 对于桌面应用程序,Adobe AIR允许创建Native Extensions,将ActionScript与操作系统级别的API连接起来,JavaScript可以通过ANE与ActionScript交互。 8. **PostMessage ...

    js与as相互调用

    JavaScript(JS)与ActionScript(AS)是两种不同的脚本语言,它们在Web开发和富互联网应用程序(RIA)中都发挥着重要作用。JS主要用于浏览器端的交互和动态效果,而AS主要与Adobe Flash平台相关,用于创建动画和...

    FlashPlayer组件调用FLASH函数接口

    FlashPlayer组件调用FLASH函数接口是网页开发中的一个重要技术,尤其在富互联网应用程序(RIA)领域,它使得JavaScript与SWF文件(Flash内容)之间的交互成为可能。FlashPlayer作为一个广泛使用的浏览器插件,曾经是...

    as与js方法的相互调用

    在跨平台应用开发中,经常会遇到ActionScript (AS)与JavaScript (JS)之间的交互需求,尤其是在Flex(一种基于Adobe Flash的开发框架)的应用中。Flex是使用ActionScript编写,而网页环境通常由HTML和JavaScript控制...

    Flex与Flash相互调用实例

    通过ExternalInterface,Flash可以调用JavaScript函数,而JavaScript也可以调用Flash中的方法。 在提供的压缩包文件中,包含了两个工程目录:一个为Flash程序,另一个为Flex工程。这表明你需要分别在Flash ...

    Flash(AS3)和C#之间的相互函数调用(例子)

    通过以上步骤,我们可以实现Flash AS3与C#之间的函数调用。这种技术在多种场景下都非常有用,比如桌面应用与嵌入式Flash组件的交互,或是游戏中的自定义UI交互。理解并熟练掌握这种通信方式将极大地扩展你的开发能力...

    as2/3与js相互调用实例 源码

    而在JavaScript端,可以像调用普通对象的方法一样调用AS2中的函数。 2. **AS3与JS的交互**: AS3中,与JavaScript的交互更为完善和安全,它同样使用`ExternalInterface`类。AS3的`addCallback`方法和`call`方法...

Global site tag (gtag.js) - Google Analytics