Flex和JavaScript互操作


======================================================
注:本文源代码点此下载
======================================================

flex最终会生成swf文件以activex的方式部署网页上(html,jsp,asp,aspx等),由于activex是一个独立体它并不能直接获取页面的元素数据,同样asp,aspx等服务端代码也不对它进行操作,这样flex的信息交互就变得很孤立。在web用户程序中不同页的信息交换是非常重要,通常这些信息明确下一个页面应该做什么;如果flex得不到这些信息那么flex在实际应用中就大打折扣!于是到网上找一下资料,发现自己的担心是多余的。flex提供相关对象可以灵活地和当前网页的javascript相互进行灵活的调用。那就是说可以通过javascript调用flex内部的方法,同样在flex时也可以直接调用页面上相关的javascript方法。

flex提供了externalinterface对象用于和javascript进行互操作。对象分别提供了addcallback和cell方法:

addcallback方法

用于注册一个内部方法用于给javascript调用。

function callme(name:string):string {

return name+":" + txtusername.text;

}

实际上javascript是不能直接调用flex的内部方法的,那如何使javascript能够调用呢?

首先通过externalinterface.addcallback("myfunction", callme);的方法进行注册,可以把方法放在applicaion. initialize的事件中。

方法第一个参数是:外部调用名称就是javascript调用的方法名称。

方法第二个参数是:代理执行flex的内部函数。

javascript通过以下方式调用:

function button1_onclick() {

alert(document.all('相关activex控件名称').myfunction('bbq'));

}

call方法

用于调用当前页面里的javascript方法.

script id="clienteventhandlersjs" language="javascript">

function getuserid()

{

return 'henry';

}

script>

在flex里可以通过以下方式调用getuserid()方法。

var id:string= externalinterface.call("getuserid");

alert.show(id);

flex在和javascript整合这方面做得非常好,你并不需要花费太多的工作就能够实现和页面数据元素进行数据交换;同样也可以调用已经有的ajax功能。

接下来学习的是不同页面的flex应用实例如何共享信息。

最后还是老话一句,有兴趣的朋友多了解一下flex.

flex的sdk帮助文件写得还挺详细的,基本上能找到使用的方法。


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值