Js与flash交互:在html页面中用js与MyReport插件交互

news/2024/5/19 18:18:44 标签: Flash, HTML, JavaScript, FLEX, MyReport

 

Html页面与flash的加载

如下图,flashhtml页面的一个插件节点。

jsflash进行交互,首先要处理好html页面和swf的加载问题。

Swf调用外部js方法,要确保js方法已存在,该条件一般都满足,因为swf加载比页面js慢。

Js访问swf的接口时,要确保swf已经加载完成,该条件则需要做特殊的处理。

如何做?

可以想到的是,只有flash插件本身才知道自己是否加载完成,所以,需要flash插件在加载完成后要主动的通知外部html页面:“我加载完啦!”,外部html页面收到这个通知后再进行后续的操作。

更复杂的情况是,页面有2次加载数据的场合:要同时保证,页面、flash、数据都加载完成后,在进行后续操作。

 

ExternalInterface

ExternalInterface类是实现flash外部调用的关键类,其中:

ExternalInterface.available:判断是否允许进行外部调用。

ExternalInterface.addCallback:注册外部访问flash的方法(js 2 flash)。

ExternalInterface.callflash内部调用外部方法(flash2 js)。

关于该类的更多信息请查看帮助文档。

 

MyReport插件增加js访问的接口

MyReportApp.swf在加载完成后会主动调用页面的js方法onMyReportInitialized;关闭时主动调用js方法onMyReportClosed;打印时主动调用js方法onMyReportPrinted

注册了一个loadReport方法可以让页面js进行调用。

以下是MyReportAppflex代码

<?xmlversion="1.0" encoding="utf-8"?>

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"

                           xmlns:myreport="myreport.*"

                           minWidth="800" minHeight="600" backgroundColor="0xffffff" creationComplete="Init()"

                           fontFamily="Simsun" layout="horizontal" paddingBottom="0" paddingLeft="0"

                           paddingRight="0" paddingTop="0">

       <mx:Stylesource="Index.css"/>

       <mx:Script>

              <![CDATA[

                     import mx.collections.ArrayCollection;

                     import mx.events.CloseEvent;

                     import myreport.MyReportEvent;

                     import myreport.ReportEngine;

                     import myreport.ReportViewer;

                     import myreport.export.ExportEvent;

 

                     private function Init():void

                     {

                           //注册关闭事件

                           _Report.addEventListener(CloseEvent.CLOSE, OnClose);

                           //注册导出事件

                           _Report.addEventListener(ExportEvent.EXPORT, OnExport);

                           //注册打印事件

                           ReportEngine.AddEventListener(myreport.MyReportEvent.PRINT, OnPrint);

                           AddExtInterface();

                           OnMyReportInitialized();

                     }

                     private function OnClose(event:CloseEvent):void

                     {

                           //处理关闭事件

                           OnMyReportClosed();

                     }

                     private function OnPrint(event:MyReportEvent):void

                     {

                           //处理打印事件

                           OnMyReportPrinted();

                     }

                     private function OnExport(event:ExportEvent):void

                     {

                           varfile:FileReference;

                           if(event.FileType == ExportEvent.FILE_TYPE_PDF)

                           {

                                  file = new FileReference();

                                  //保存到本地,该方法要Flash player 10以上

                                  file.save(event.Bytes, "Export1.pdf");

                           }

                           else if(event.FileType == ExportEvent.FILE_TYPE_XLS)

                           {

                                  file = new FileReference();

                                  //保存到本地,该方法要Flash player 10以上

                                  file.save(event.Bytes, "Export1.xls");

                           }

                     }

                     private function AddExtInterface():void

                     {

                           if(ExternalInterface.available)

                           {

                                  ExternalInterface.addCallback("loadReport", LoadReport);

                           }

                     }

                     //==============定义外部访问接口====================

                     /**

                      * 加载完成时调用,通知外部初始化加载已完成

                      * (主动调用)

                      */

                     private function OnMyReportInitialized():Object

                     {

                           if(!ExternalInterface.available)

                                  return 0;

                           return ExternalInterface.call("onMyReportInitialized");

                     }

                     /**

                      * 关闭时调用,通知外部点击了关闭按钮

                      * (主动调用)

                      */

                     private function OnMyReportClosed():Object

                     {

                           if(!ExternalInterface.available)

                                  return 0;

                           return ExternalInterface.call("onMyReportClosed");

                     }

                     /**

                      * 打印时调用,通知外部执行了打印功能

                      * (主动调用)

                      */

                     private function OnMyReportPrinted():Object

                     {

                           if(!ExternalInterface.available)

                                  return 0;

                           return ExternalInterface.call("onMyReportPrinted");

                     }

                     /**

                      * 加载报表和数据

                      * (被动调用,必须在onMyReportInitialized执行后调用)

                      */

                     private function LoadReport(url:String, params:Object,table:Array):void

                     {

                           _Report.Load(url, new ArrayCollection(table), params);

                     }

              ]]>

       </mx:Script>

       <myreport:ReportViewerid="_Report" width="100%"height="100%">

       </myreport:ReportViewer>

</mx:Application>

 

html页面中与MyReportApp.swf交互

MyReportEmbedDemo.html的代码,引入了swfobject.js向页面动态添加flash插件MyReportApp.swf。用jquery控制页面的加载,页面加载后调用onPageLoad方法。

<!DOCTYPEhtml PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

    <title>jsflash交互:嵌入MyReport插件示例</title>

    <script type="text/javascript"src="swfobject.js"></script>

    <script type="text/javascript"src="myreport.js"></script>

    <script src="jquery-1.9.1.min.js" type="text/javascript"></script>

    <script type="text/javascript">

        varswfVersionStr = "11.1.0";

        varxiSwfUrlStr = "playerProductInstall.swf";

        varflashvars = {};

        varparams = {};

        params.quality = "high";

        params.bgcolor = "#ffffff";

        params.allowscriptaccess = "sameDomain";

        params.allowScriptAccess = "always";

        params.allowfullscreen = "true";

        varattributes = {};

       attributes.id = "MyReportApp";

       attributes.name = "MyReportApp";

        attributes.align = "middle";

        swfobject.embedSWF("MyReportApp.swf","flashContent","955px", "600px",swfVersionStr, xiSwfUrlStr,flashvars, params,attributes);

    </script>

    <script type="text/javascript">

       $(document).ready(function() {

           onPageLoad();//该方法在myreport.js实现

        });

    </script>

</head>

 

<body>

<p style=" text-align:center">该示例演示在页面嵌入MyReport插件,使用jsflash插件进行交互</p>

<div id="flashContent">

    <p>

        Toview this page ensure that Adobe Flash Player version

        11.1.0or greater is installed.

    </p>

    <script type="text/javascript">

        varpageHost = ((document.location.protocol== "https:") ? "https://" : "http://");

        document.write("<a href='http://www.adobe.com/go/getflashplayer'><imgsrc='"

               + pageHost + "www.adobe.com/images/shared/download_buttons/get_flash_player.gif'alt='Get Adobe Flash player' /></a>" );

    </script>

</div>

</body>

</html>

 

myreport.js的代码,关键位置加粗显示,页面加载后调用loadReport1调用加载报表方法,传入静态测试数据。

var myReportAPI;//定义MyReport接口对象

var myReportInit = false; //定义MyReport初始化变量

 

//页面加载完成时调用

function onPageLoad(){

    myReportAPI = document.getElementById("MyReportApp");

    loadReport1();

}

function onMyReportInitialized(){

    myReportInit= true;

    //以下是自定义代码

    alert("MyReport初始化。");

    loadReport1();

}

function onMyReportClosed() {

    //以下是自定义代码

    alert("MyReport关闭。");

}

function onMyReportPrinted() {

    //以下是自定义代码

    //alert("MyReport打印。");

}

function myReportLoad(url, params, table) {

    if (!myReportAPI ||!myReportInit)

        return;

    myReportAPI.loadReport(url, params,table);

}

 

//自定义加载方法1

function loadReport1() {

    if (!myReportInit)// 要先判断插件是否初始化

        return;

    var url = "xml/ReportStyle1.xml"; //报表路径

    //报表参数数据,这里为了测试方便使用了静态的数据,实际使用时应该向服务端动态请求数据。

    var params = {};

    params["单据编号"] = "KA06417033944";

    params["单据日期"] = newDate();

    params["主标题"]= "销售单";

    params["公司名称"] = "XXXX贸易公司";

    params["经手人"]= "某某";

    params["公司地址"] = "广州市天河区天河路xx xx大厦 xx";

    params["公司电话"] = "66866888";

    params["公司"]= { "地址":"广州市天河区天河路xx xx大厦 xx", "电话": "66866888"};

//报表表格数据,这里为了测试方便使用了静态的数据,实际使用时应该向服务端动态请求数据。

vartable = new Array();

    for (var i = 0; i < 25; i++){

        table.push({ID: i, 名称: "商品信息XXX 规格XXX 型号XXX", 数量:i+1, 金额: (i+1)*10, 日期: new Date()});

}

    myReportLoad(url, params, table);

}

 

运行效果图

 

 

如何获取MyReport

MyReport报表引擎下载链接和相关文章索引

 

相关文章

MyReport专栏

 


http://www.niftyadmin.cn/n/1574508.html

相关文章

入行大数据开发的一些经验

总结了一些经验送给对大数据行业有兴趣的朋友。 ☟☟☟ 本人以前某五百强高级数据开发工程师一枚五年工作经验&#xff0c;一年多面试官经验。面试中经常会遇到这种情况&#xff1a;之前专心写web的Java码农突然转型想做大数据了&#xff0c;然后写几个大数据的项目经验跑来面…

对比MySQL,一文看透HBase的能力及使用场景

MySQL HBase 是我们日常应用中常用的两个数据库&#xff0c;分别解决应用的在线事务问题和大数据场景的海量存储问题。 本文内容适合初次理解HBase的读者&#xff0c;包括技术、功能及场景&#xff0c;也欢迎老司机们补充和温故。

MyReport报表引擎2.7.5.0主要新功能

新增图片控件能够通过url地址字符串加载图片新增仪表盘图表控件标题单元格、表格单元格支持前缀属性设置能够在同一个单元格显示前缀标签和数据&#xff0c;较少设计时的单元格占用数量。报表设计器功能的改善支持UNDO、REDO操作&#xff0c;设计时更方便。相关链接MyReport演示…

利用 dom4j 把 xml 字符串转成 Map 对象

2019独角兽企业重金招聘Python工程师标准>>> 利用 dom4j 把 xml 字符串转成 Map 对象 开发过程中遇到过个需求&#xff0c;自己动手写一个&#xff0c;分享一下。 程序的入口方法 /*** [author](https://my.oschina.net/arthor) ChangJian* [data](https://my.osch…

初探大数据处理 on Kubernetes

自2003年Google的三大核心技术GFS(03)、MapReduce(04)、和BigTable(06)的论文陆续发表至今&#xff0c;以Hadoop为代表的大数据处理框架&#xff0c;开始登上历史的舞台&#xff0c;迎来了一个黄金时代。Apache Hadoop是其中最为成功的开源项目&#xff0c;让企业级的大数据处理…

MyReport.TD套打引擎1.0.4.0主要新功能

新增条形码控件支持常用的条码显示和打印新增横线、垂线、矩形控件能够设置套打格式的边框和内边线预览效果报表设计器功能的改善支持UNDO、REDO操作&#xff0c;设计时更方便新增快捷键功能"复制(CtrlC)","粘贴(CtrlV)","全选(CtrlA)"新增右键菜…

基于http的通信协议――SHCP

概述SHCP――Simple HTTPCommunication Protocol&#xff0c;简单的HTTP通信协议。本文章提供一种设计思路&#xff0c;能够设计基于http协议的通信层&#xff0c;从安全性、灵活性与数据传输性能上提供一种设计的参考。在以下场合&#xff0c;本文能提供较好的参考价值&#x…

大数据技术+行业知识+业务知识=大数据应用

大数据技术行业知识业务知识大数据应用 一般来看&#xff0c;一个产业的成长轨迹都是源于技术、成于产品、终于应用。大数据产业也不例外&#xff0c;整个产业是由于云计算、大数据技术而出现的&#xff0c;各个厂商开发出比较成熟的产品并推向市场&#xff0c;最终在应用中带…