解决Flash挡住层用z-index无效的问题

在HTML中,如果嵌入Flash,默认会将flash放在页面的最上面。也就是说,即使用绝对定位,将z-index设的无穷高,页面里的任何元素还是无法将它盖住。这时候,有两种方法可以控制flash的z-index

1、在嵌入flash时,设置flash的wmode参数为opaque
2、在嵌入flash时,设置flash的wmode参数为transparent

对应的IE和FireFox的代码如下所示,

发现ie和FF加该参数的方式不同,遂针对处理了一下,这下都可以了。

让Flash不档住浮动对象或层的关键参数:wmode=opaque

方法:

针对IE 在<object></object>内加上参数<param name="wmode" value="opaque" />
针对FF 在<embed />内加上参数wmode="opaque"

方法一:

在网页中插入flash的代码如下:

 代码如下 复制代码

<object type=”application/x-shockwave-flash” data=”style/flash/001.swf” width=”400″ height=”400″> <param name=”movie” value=“001.swf” /> <param name=”wmode” value=”opaque” /> <embed wmode=”opaque”></embed> </object>

其中param有个name为wmode的属性,只要将其设置为opaque, 并确保包含<embed wmode=”opaque”></embed>即可。

注:代码中必须包含上代码中的2、3行。

方法二:设置透明的Flash

本方法是设置flash透明来达到所需的效果。具体做法是 将上代码中的name为wmode的属性设置为transparent, 即代码:<param name=”wmode” value=”transparent”>

原因:

flash嵌入的时候有几种模式:

1、窗口(window)
默认情况下的显示模式。在这种模式下flash player有自己的窗口句柄,这就意味着flash影片是存在于Windows中的一个显示实例,并且是在浏览器核心显示窗口之上的,所以flash只 是貌似显示在浏览器中,但这也是flash最快最有效率的渲染模式。由于他是独立于浏览器的HTML渲染表面,这就导致默认显示方式下flash总是会遮 住位置与他重合的所有DHTML层。但是大多数苹果电脑浏览器会允许DHTML层显示在flash之上,但当flash影片播放时会出现比较诡异的现象,比如DHTML层像被flash刮掉一块一样显示异常。

2、不透明无窗口(opaque)

这是一种无窗口模式,在这种情况下flash player没有自己的窗口句柄,这就需要浏览器需要告诉flash player在浏览器的渲染表面绘制的时间和位置。这时flash影片就不会在高于浏览器HTML渲染表面而是与其他元素一样在同一个页面上,因此你就可以使用z-index值来控制DHTML元素是遮盖flash或者被遮盖。
3、透明无窗口(transparent)

透明模式,在这种模式下flash player会将stage的背景色alpha值将为0并且只会绘制stage上真实可见的对象,同样你也可以使用z-index来控制flash影片的 深度值,但是与opaque模式不同的是这样做会降低flash影片的回放效果,而且在9.0.115之前的flash player版本设置wmode=”opaque”或”transparent”会导致全屏模式失效。

这三种模式分别表示着Flash在页面中的三种表现形式,根据这三种表现形式,我们就找到了解决这个问题的方法,就是将页面中的Flash模式 (wmode)设置为不透明无窗口(opaque)或者是透明无窗口(transparent),在这两种模式下页面中的Flash将与HTML结构是处 于同一级别的,所以就可以通过z-index来控制页面中的重叠部分到底是Flash显示在上还是HTML结构显示在上。

当我们需要在页面中加载一个弹出Flash广告时,并且不希望它被页面中的其它Flash所遮挡时,就可以使用这种方法来解决。同样的如果这个弹出 Flash是不规则形状的时候,就可以将模式(wmode)设置为透明无窗口(transparent),这样即可以除去Flash本身所带有的背景。

时间: 2024-08-19 22:25:28

解决Flash挡住层用z-index无效的问题的相关文章

flash 挡住层的解决方法_相关技巧

出现问题: 1. 使用层制作的下拉菜单下正好有FLASH动画,菜单被动画遮挡. 2. 页面中的层浮动广告当经过FLASH动画时,浮动层从动画画穿过,实际显示被遮挡. 解决方法: 按如下任一方法设置设置FLASH对象的属性 <param name="wmode" value="transparent"> FLASH将透明 <param name="wmode" value="Opaque"> FLASH仍

网页中层或菜单被Flash挡住的解决办法

菜单|解决|网页 网页中层或菜单被Flash挡住的解决办法 网页层或菜单经常被flash盖住部分看不到,影响美观,在flash代码中加入以下代码: <param name="wmode" value="Opaque"> 即可解决被flash遮挡看不到图层或菜单的问题了. 下面是代码例子,加入红色部分: OBJECT代码: <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000

解决DIV给flash挡住的问题

解决|问题 最近要更flash 打交道,不得不进修一下. <param name="wmode" value="opaque">这个用于解决DIV给flash挡住的问题 <!--以下是源码--> <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/s

最好的真正解决下拉菜单被flash挡住的解决方法

在给一个客户做项目的时候,发现下拉菜单总被flash挡住,很多人的解决方法是将flash设置为透明,但是这个不是最好的解决方法,因为有些打了补丁的机器会出现,下拉菜单点击两次才能正常访问的问题. 解决方法如下: 网站开发人员的应对办法: 一.下载后将压缩包内的"FLASH.js"文件放入站点任意文件夹中 点此下载 二.在网页<head></head>之间插入以下代码 <!--修正FLASH正确显示代码开始--> <script language

避免select控件和Flash挡住div层

1. 避免Flash挡住Div层的方式:增加 <param name="wmode" value="transparent">,另外增加<embed wmode="transparent" ...其他选项>2. select和flash挡住div,可以采取移除节点的方式防止挡住3. select和flash采用display:none的方式防止挡住4. 在select和flash上面加一层隐藏的iframe对象,因为ifr

flash挡住了下拉菜单问题解决办法

遇到了flash挡住了菜单的疑难问题. 在网上查了资料,大部分都说是加一个 <param name="wmode" value="transparent"> 或者这个 params.wmode="opaque"; 这个我也试过了. 我的是直接:params.wmode = "transparent";params.wmode="opaque"; 例子 本来在flash里加上<param n

InvalidArgument=“4”的值对于“index”无效。

问题描述 InvalidArgument="4"的值对于"index"无效. InvalidArgument="4"的值对于"index"无效.什么意思啊,求指导 解决方案 具体要对应的代码.然后来分析

解决Flash影片中的图片抖动锯齿

解决 Flash 影片的默认质量是高,其实还可以更高[也更耗资源]. AS 控制方法:_quality = "best"; 或者在发布向导中的HTML标签Quality项选择Best. 这样图片就不抖了 效果对比

anychart-AnyChart 解决flash层次优先级高于div的问题

问题描述 AnyChart 解决flash层次优先级高于div的问题 今天遇到一个问题,在IE浏览器环境下,AnyChart生成的图标,总是把弹出的div框遮住了. 在网上查了下原因,是需要将flash的wmode设置成opaque或者. 但是具体怎么设置,求解... 急,在线等. 解决方案 http://inotgaoshou.iteye.com/blog/1158487