Flex程序和web页面的通信

Flex通常作为一个web项目的一部分嵌入到一个web页中,因此Flex程序和web页面的通信就变得非常重要。
1) Flex提供了多种方法实现Flex程序和封装页面的交互,主要有:flashVars属性,查询字符串参数,navigateToURL()方法,以及flash.external.ExternalInterface类。
2) Flex程序 获取环境信息:Application.application.url获取封装页面的URL,以及使用@ContextRoot();以及可以通国 flash.system.Capacities获取到有关系统的一些信息,比如版本、语言、操作系统等;
3) flashVars用来从外部封装页面向Flex程序传送数据:
在封装页面传入参数值:AC_FL_RunContent(flashVars, “para1=value1&…&paran=valuen”)或者
<Object>
<param name=”movie” value=”wrapper.swf? para1=value1 />
<embed src=”wrapper.swf?para1=value1/>
</Object>
然后flex程序里通过 Application.application.parameters.para1获取参数值;
4) ExternalInterface提供方法使Flex程序和外部的封装页面可以相互调用对方的方法,外部接口类要受到域安全性设置(allowScriptAccess, allowNetworking)的约束。
先判断ExternalInterface是否可用:
ExternalInterface.available;
flex调用js:
ExternalInterface.call(funName, funPara1, …, funParaN);
js调用flex:
首先flex里面用ExternalInterface.addCallback(“jsFunName”,asFun),将AS里面定义的函数赋予一个js里面调用的函数的名字jsFunName;
然后在js里面用mySwf.jsFunName()调用flex里面提供的函数asFun;
ExternalInterface安全性:
一般来说js和flex的访问局限于同一个域之内。
可以设置<Object>和<Embed>的allowScriptAccess=”value”(value取值:never, always, sameDomain默认)来设置flex访问js的权限。
至于js对于flex方法的访问只有flex里面通过addCallback的js才可以访问,对于跨域,可以试用allowDomain()函数设置。
5) navigateToURL() 可以用来打开一个新的浏览器窗口,也可以用来flex和js之间的通信。比如:
打开一个新窗口:
var url:URLRequest = new URLRequest(http://blog.csdn.net);
navigateToURL(url, _blank);
这个函数也可以用来执行js,例如:
var url:URLRequest = new URLRequest(“javascript:window.close()”); 或者:
var urlLURLRequest = new URLRequest(“javascript:myFun(para1…paran)”)
myFun()函数是html页面的script部分定义的,函数参数一定要有引号!
navigateToURL(url, _self);
也可以用来发送email:
var urlURLRequest = new URLRequest(mailto:zoushun@hotmail.com);
navigateToURL(url, _blank);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,我们需要了解一下Flex布局的基本概念和属性。Flex布局是一种基于容器和项目的布局模型,它可以自适应不同的屏幕尺寸,并且可以轻松地实现水平和垂直居中等效果。以下是一个简单的Flex布局的代码示例: HTML代码: ```html <div class="container"> <div class="item">Item 1</div> <div class="item">Item 2</div> <div class="item">Item 3</div> </div> ``` CSS代码: ```css .container { display: flex; justify-content: space-between; align-items: center; } .item { width: 100px; height: 100px; background-color: #ccc; } ``` 在上面的代码中,我们使用了`display:flex`来定义容器的布局模式。`justify-content`属性可以定义项目在主轴方向上的对齐方式,这里我们选择了`space-between`,表示项目之间平均分配空间。`align-items`属性可以定义项目在交叉轴方向上的对齐方式,这里我们选择了`center`,表示项目在交叉轴方向上居中对齐。 接下来,我们来实现一个产品页面的布局。假设我们的产品页面包含一个顶部导航栏、一个左侧菜单栏、一个主要内容区域和一个底部信息栏。以下是一个简单的Flex布局的代码示例: HTML代码: ```html <div class="container"> <div class="header">Header</div> <div class="sidebar">Sidebar</div> <div class="content">Content</div> <div class="footer">Footer</div> </div> ``` CSS代码: ```css .container { display: flex; flex-direction: column; height: 100vh; } .header { height: 60px; background-color: #f5f5f5; } .sidebar { width: 200px; background-color: #eee; } .content { flex: 1; background-color: #fff; } .footer { height: 40px; background-color: #f5f5f5; } ``` 在上面的代码中,我们使用了`flex-direction:column`来定义容器的布局方向为纵向布局。`height: 100vh`用于设置容器的高度为视口的高度。`header`和`footer`分别设置了固定高度,`sidebar`设置了固定宽度,`content`的`flex:1`表示它会自动填满剩余的空间。 这样,我们就完成了一个简单的产品页面的布局。当然,实际应用中还需要更多的样式和细节处理,但Flex布局可以让我们轻松地实现各种复杂的布局效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值