js調用Flex中的方法并向flex中傳參及flex調用js示例
更新時間:2013年07月09日 17:43:50 作者:
本文為大家詳細介紹喜愛js調用Flex中的方法以及向flex中傳參與flex調用js,具體示例如下,感興趣的朋友不妨參考下,希望對大家有所幫助
首先,有了一個swf文件,test.swf,同時也有一個自動生成的html文件,test.html。
然后,在另外一個文件,test.jsp中,通過iframe,引入了test.html,即引入了swf。
現(xiàn)在想要在test.jsp中,向flex傳參,并調用flex中的方法,我采用的方法是:
首先,在jsp中寫一個調用flex的方法,如下
function initSWF(){
//得到swf的object
var obj = window.frames["rightframe"].ReverseQuery; //rightframe是iframe的名字,ReverseQuery是在test.html中,引入swf做object的id。
//調用它的方法
var start = "<%=startPoint%>";
var end = "<%=endPoint%>";
obj.showParams(start,end);
}
在html中,有方法
/*在flex中只能調用本頁面的js方法*/
function initSWF(){
parent.initSWF();
}
在flex,有如下方法:
public function showParams(start:String,end:String):void{
Alert.show(start);
Alert.show(end);
}
這時,需要建立一個打開他們之間通信的橋梁了,在flex的初始化時,要使用
ExternalInterface.addCallback("showParams",showParams); //前者是它暴露給js的方法名,后者是它在flex中的方法名。
這樣,理論上就可以實現(xiàn)調用了。將initSWF方法放在頁面的onload方法中即可實現(xiàn)。
但是產(chǎn)生一個問題,如果flex在頁面中沒有加載成功時,會報找不到對象的錯誤。因此,需要我們在確保swf文件加載完成后,再調用swf中的方法。
但監(jiān)聽它加載完成顯然有點浪費感情,于是,我們采用的策略是,等它加載完,再調用js的initSWF方法,即可將環(huán)節(jié)全部打通。
因此,在flex的初始化時,加入
//調用載入頁面的initSWF方法
ExternalInterface.call("initSWF"); //要將它放在注冊對外方法之后進行。
大功告成。
有需要注意的地方:
在flex當中調用js的方法,這個方法只能寫在引入swf的文件中,但我在jsp中引入了html,所以只能是在html中的js,是調用父頁面的js方法。
而在jsp中對于swf文件的引用,要借助window.frames["rightframe"]
然后,在另外一個文件,test.jsp中,通過iframe,引入了test.html,即引入了swf。
現(xiàn)在想要在test.jsp中,向flex傳參,并調用flex中的方法,我采用的方法是:
首先,在jsp中寫一個調用flex的方法,如下
復制代碼 代碼如下:
function initSWF(){
//得到swf的object
var obj = window.frames["rightframe"].ReverseQuery; //rightframe是iframe的名字,ReverseQuery是在test.html中,引入swf做object的id。
//調用它的方法
var start = "<%=startPoint%>";
var end = "<%=endPoint%>";
obj.showParams(start,end);
}
在html中,有方法
/*在flex中只能調用本頁面的js方法*/
function initSWF(){
parent.initSWF();
}
在flex,有如下方法:
public function showParams(start:String,end:String):void{
Alert.show(start);
Alert.show(end);
}
這時,需要建立一個打開他們之間通信的橋梁了,在flex的初始化時,要使用
ExternalInterface.addCallback("showParams",showParams); //前者是它暴露給js的方法名,后者是它在flex中的方法名。
這樣,理論上就可以實現(xiàn)調用了。將initSWF方法放在頁面的onload方法中即可實現(xiàn)。
但是產(chǎn)生一個問題,如果flex在頁面中沒有加載成功時,會報找不到對象的錯誤。因此,需要我們在確保swf文件加載完成后,再調用swf中的方法。
但監(jiān)聽它加載完成顯然有點浪費感情,于是,我們采用的策略是,等它加載完,再調用js的initSWF方法,即可將環(huán)節(jié)全部打通。
因此,在flex的初始化時,加入
//調用載入頁面的initSWF方法
ExternalInterface.call("initSWF"); //要將它放在注冊對外方法之后進行。
大功告成。
有需要注意的地方:
在flex當中調用js的方法,這個方法只能寫在引入swf的文件中,但我在jsp中引入了html,所以只能是在html中的js,是調用父頁面的js方法。
而在jsp中對于swf文件的引用,要借助window.frames["rightframe"]
相關文章
Flex播放器(實現(xiàn)播放、緩沖進度條和音頻曲線顯示)
這篇文章主要介紹了Flex播放器(實現(xiàn)播放、緩沖進度條和音頻曲線顯示),需要的朋友可以參考下2014-07-07flex利用webservice上傳照片實現(xiàn)代碼
這篇文章主要介紹了flex利用webservice上傳照片實現(xiàn)代碼,需要的朋友可以參考下2014-05-05flex中使用RadioButtonGroup時取出所選項的值的方法
flex中的RadioButtonGroup想必大家并不陌生吧,在本文將為大家介紹下在使用RadioButtonGroup時如何取出所選項的值,感興趣的朋友可以參考下2013-12-12