JavaScript和ActionScript互相调用时,其实有个非常好的特性,不过貌似很少有人提到这个特性:它们之间的数据类型对方均可以识别。因此,你可以通过swf提供的接口来传递对象、数组、字符串等等。不过它们之间传递的参数的值的长度有限制(具体长度还没仔细测试),因此你不能把JavaScript中的一个超大的对象直接传递进去。不过即使是这样,已经非常好用了,看看示例代码:

AS(ActionScript)代码:

// 创建一个行的TextField来显示调用结果
var t:TextField = new TextField();
t.x = 10;
t.y = 10;
t.width = 300;
t.height = 200; 
this.addChild(t);

// 这个是要给JavaScript调用的函数
function test(obj){
    var s = [];
    for(var p in obj){
        s.push(p + ': ' + obj[p]);
    }
    t.text = s.join('\r\n');
}

// 添加调用接口
ExternalInterface.addCallback("test", test);
t.text = 'ready';

// 调用JavaScript,告诉JavaScript我已经准备好了
ExternalInterface.call('ready', {a:'a string', b:'string b'});

JavaScript代码:

var swfId = 'call_swf'
function ready(){
    // 获取flash传递过来的参数
    var o = arguments[0];
    var s = [];
    for(var p in o){
        s.push([p, ': ', o[p]].join(''));
    }
    // 打印传递进来的对象的内容
    alert(s.join('\n'));
    
    var swf = document[swfId] ? document[swfId] : window[swfId];
    // 调用flash提供的接口
    swf.test({a:'a string', b:'string b'});
}

下面这个是AS2的代码:

import flash.external.*;

// 创建一个行的TextField来显示调用结果
var t:TextField = this.createTextField('t', this.getNextHighestDepth(), 10, 10, 300, 200); 
t.text = 'ready';

// 这个是要给JavaScript调用的函数
function test(obj){
    var s = [];
    for(var p in obj){
        s.push(p + ': ' + obj[p]);
    }
    t.text = s.join('\r\n');
}

// 添加调用接口
var testsuc:Boolean = ExternalInterface.addCallback("test", null, test);
t.text = ['test: ', testsuc].join('\n');

// 调用JavaScript,告诉JavaScript我已经准备好了
ExternalInterface.call('ready', {a:'a string', b:'string b'});

相互调来调去是不是很方便?

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.