在flex组件中嵌入html代码,可以利用flex iframe。这个在很多时候会用到的,有时候flex必须得这样做,如果你不这样做还真不行……

flex而且可以和html进行JavaScript交互操作,flex调用到html中的JavaScript方法以及获取调用后的返回值。

 

1、flex iframe下载地址:https://github.com/downloads/flex-users/flex-iframe/flex-iframe-1.5.1.zip

下载完成后目录如下

 

asdoc就是文档doc了

bin有需要用到的flex库 swc

examples就是示例

sources源代码

 

欢迎关注我的博客:http://hoojo.cnblogs.com

http://blog.csdn.net/IBM_hoojo

 

2、将bin目录中的swc引入到你的flex工程中,并加入代码片段如下

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

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

                xmlns:flexiframe="http://code.google.com/p/flex-iframe/"

                horizontalAlign="center" verticalAlign="middle" xmlns:s="library://ns.adobe.com/flex/spark">

    

    <mx:Script>

        <![CDATA[

            import mx.controls.Alert;

            protected function sayHelloHandler(event:MouseEvent):void {

                // 调用当前iframe嵌入页面中的sayHello 的JavaScript方法

                iFrameBySource.callIFrameFunction("sayHello");

            }

            

            protected function sayHandler(event:MouseEvent):void {

                // 调用当前iframe嵌入页面中的say的JavaScript方法,并传入一个参数

                iFrameBySource.callIFrameFunction("say", ["hello world!"]);

            }

            protected function sayHiHandler(event:MouseEvent):void {

                // 调用当前iframe嵌入页面中的sayHi的JavaScript方法,并传入2个参数。sayHi方法会返回一个字符串,最后一个回调就是输出值的函数

                iFrameBySource.callIFrameFunction("sayHi", ["hello world", "李四"], function (data:*): void {

                    Alert.show(data);

                });

            }

        ]]>

    </mx:Script>

    

    <!-- HTML content stored in a String -->

    <mx:String id="iFrameHTMLContent">

        <![CDATA[

        <html>

            <head>

                <title>About</title>

            </head>

            <body>

                <div>About</div>

                <p>Simple HTML Test application. This test app loads a page of html locally.</p>

                <div>Credits</div>

                <p> </p>

                <p>IFrame.as is based on the work of</p>

                <ul>

                <li><a href="http://coenraets.org/" target="_top">Christophe Coenraets</a></li>

                <li><a href="http://www.deitte.com/" target="_top">Brian Deitte</a></li>

                </ul>

            </body>

        </html>

        ]]>

    </mx:String>

    

    <mx:Panel width="80%" height="80%" title="使用source本地远程页面">

        <flexiframe:IFrame id="iFrameBySource" width="100%" height="100%" source="frame.html"/>

        <s:Button label="sayHello" click="sayHelloHandler(event)"/>

        <s:Button label="say-param" click="sayHandler(event)"/>

        <s:Button label="sayHi" click="sayHiHandler(event)"/>

    </mx:Panel>

    

    <mx:Panel width="80%" height="80%" title="使用source加载远程页面">

        <flexiframe:IFrame id="iFrameByRemoteSource" width="100%" height="100%" source="http://www.baidu.com" visible="true"

                           overlayDetection="true" />

    </mx:Panel>

    

    <mx:Panel width="80%" height="80%" title="使用content属性 加载本地html文本内容">

        <flexiframe:IFrame id="iFrameByContent" width="100%" height="100%" content="{iFrameHTMLContent}"/>

    </mx:Panel>

    

</mx:Application>

 

frame.html 页面内容

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

  <head>

    <title>frame.html</title>

    <meta http-equiv="pragma" content="no-cache">

    <meta http-equiv="cache-control" content="no-cache">

    <meta http-equiv="expires" content="0">

    <script type="text/javascript">

        // 无参数

        function sayHello() {

            alert("hello......");

        }

    

        // 1个参数

        function say(message) {

            alert("your say: " + message);

        }

    

        // 多个参数 并返回值

        function sayHi(message, name) {

            alert("your say: " + message + ", name: " + name);

            return "your say: " + message + ", name: " + name;

        }

    </script>    

 

  </head>

  

  <body>

    flex frame example html page!

    <input type="button" value="say" onclick="sayHello()"/>

  </body>

</html>

要注意的是:你的flex项目工程需要发表到http的应用服务器(如tomcat、jboss、iis)这些服务器中,用http请求方式才能调用到页面内容和JavaScript方法。如果不发布到应用服务器中,那样只能在iframe中嵌套远程的http请求的页面,本地静态页面是无法显示的。

在Flex (Flash)中嵌入HTML 代码或页面—Flex IFrame的更多相关文章

  1. 在Flex (Flash)中嵌入HTML 代码或页面—Flex IFrame

    在flex组件中嵌入html代码,可以利用flex iframe.这个在很多时候会用到的,有时候flex必须得这样做,如果你不这样做还真不行…… flex而且可以和html进行JavaScript交互 ...

  2. linux内核分析作业4:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

    系统调用:库函数封装了系统调用,通过库函数和系统调用打交道 用户态:低级别执行状态,代码的掌控范围会受到限制. 内核态:高执行级别,代码可移植性特权指令,访问任意物理地址 为什么划分级别:如果全部特权 ...

  3. JSP中嵌入java代码方式以及指令

    JSP中嵌入java代码的三种方式: (1)声明变量或方法 :  <%! 声明; %> :慎重使用,因为此方法定义的是全局变量 (2)java片段(scriptlet):  <% j ...

  4. Delphi代码中嵌入ASM代码

    前言 Delphi作为一个快速高效的开发平台,使用的人越来越多,但熟悉在Delphi代码中嵌入ASM代码的程序员我想不多,因为这方面的资料太少了,另一方面,它还需要有基本的汇编语言知识,关於汇编语言的 ...

  5. Delphi代码中嵌入ASM代码(简单明了)

    前言 Delphi作为一个快速高效的开发平台,使用的人越来越多,但熟悉在Delphi代码中嵌入ASM代码的程序员我想不多,因为这方面的资料太少了,另一方面,它还需要有基本的汇编语言知识,关於汇编语言的 ...

  6. 实验--使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用(杨光)

    使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用 攥写人:杨光  学号:20135233 ( *原创作品转载请注明出处*) ( 学习课程:<Linux内核分析>MOOC课程 ...

  7. LInux内核分析--使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

    实验者:江军 ID:fuchen1994 实验描述: 选择一个系统调用(13号系统调用time除外),系统调用列表参见http://codelab.shiyanlou.com/xref/linux-3 ...

  8. 实验四——使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

    实验目的: 使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用 实验过程: 查看系统调用列表 get pid 函数 #include <stdio.h> #include & ...

  9. Linux内核设计第四周学习总结 使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

    陈巧然原创作品 转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 实验目的: 使用库函数A ...

随机推荐

  1. 网易视频云技术分享:linux软raid的bitmap分析

    网易视频云是网易倾力打造的一款基于云计算的分布式多媒体处理集群和专业音视频技术,提供稳定流畅.低时延.高并发的视频直播.录制.存储.转码及点播等音视频的PAAS服务,在线教育.远程医疗.娱乐秀场.在线 ...

  2. php插入排序

    //php版插入排序 $arr=array('','5','3','7','6','4','8','2');     for($i=2;$i<count($arr);$i++)     {   ...

  3. [php-src]理解Php内核中的函数与INI

    内容均以php-5.6.14为例. 一. 函数结构 内核中定义一个php函数使用 PHP_FUNCTION 宏 包装,扩展也不例外,该宏在 ./main/php.h:343 有着一系列类似以 PHP ...

  4. UVAL1277_Cops and Thieves

    单源点汇点无向图,要阻隔某个点的流量,必须在一个点上消耗一定的价值,问你能否在消耗价值不超过k的前提下,阻隔源点到汇点的流量. 直接对于有权值的点拆点,拆后边容量即为点权.其余的点的容量无穷,最大流即 ...

  5. NOIP2013 题解

    转圈游戏 题解:快速幂 #include <cstdio> int n, m, k, x; inline long long QuickPow(int a, int k, int MOD) ...

  6. 有关big.LITTLE,你需要知道的十件事情

    来源 问题 1:该技术能够同时打开所有核心吗?   在早期的 big.LITTLE 软件模型中(集群迁移和 CPU 迁移),软件在核心之间切换,不能同时打开所有核心.在更新的软件模型“全局任务调度”中 ...

  7. centos下安装iftop

    CentOS 下iftop 的安装 安装方法一:编译安装(安装成功) wget http://ex-parrot.com/~pdw/iftop/download/iftop-0.17pre3.tar. ...

  8. 日期运算 jsf日期组建

    SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd"); Date date; try { d ...

  9. 我使用中的Linux命令和快捷键(For Ubuntu)

    虽然自己工作一直都在MS的平台体系,自然很多的工作都需要在windows上完成,自己的电脑也一直使用windows操作系统,但是笔记本配置不是很好,导致装windows 8后,笔记本卡的难以忍受.想想 ...

  10. Dynamic CRM 2013学习笔记(七)追踪、监控及性能优化

    本文将介绍CRM的三个内容追踪.监控及性能优化.追踪是CRM里一个很有用的功能,它能为我们的CRM调试或解决错误.警告提供有价值的信息:我们可以用window的性能监控工具来了解CRM的性能状况:最后 ...