如何让flash不遮挡html div元素的技巧
2016-07-01来源:易贤网

今天在写一个flash广告代码的时候,因为flash自带的链接,容易被当成弹出广告,所以做了一个div层放到flash上面,这样链接都是a触发的不会被拦截,但发现flash一直处于div层上面,原来flash需要加个参数才可以。

让flash置于div层之下的方法,让flash不挡住飘浮层或下拉菜单,让flash不档住浮动对象或层的关键参数:wmode=opaque。

方法如下:

针对ie 在<object></object>内加上参数<param name=wmode value=opaque />

针对ff 在<embed />内加上参数wmode=opaque

使用代码:

xml/html code

<!doctype html public -//w3c//dtd xhtml 1.0 transitional//en >

<html xmlns=>

<head>

<meta http-equiv=content-type content=text/html; charset=gb2312 />

<title>22cn</title>

<style type=text/css>

<!--

body {

position:relative;

z-index:0;

margin:0; padding:0

}

body,td,th {

color: #333333;

}

*{margin:0; padding:0}

img{ border:0}

#jb51{ position:relative; width:300px; height:250px}

#div1 {

position:absolute;

left:0;

top:0;

width:300px;

height:250px; z-index:-1

}

#div2 {

position:absolute;

left:0;

top:0;

width:300px;

height:250px;

z-index:99999;

}

-->

</style></head>

<body>

<div id=jb51>

<div id=div1>

<script type=text/javascript>

document.write('<object classid=clsid:d27cdb6e-ae6d-11cf-96b8-444553540000 codebase= width=300 height=250>');

document.write('<param name=movie value= />');

document.write('<param name=quality value=high /><param name=wmode value=opaque />');

document.write('<embed src= quality=high pluginspage= type=application/x-shockwave-flash width=300 height=250 wmode=opaque></embed>');

document.write('</object>');

</script>

</div>

<div id=div2>

<a href= target=_blank><img src= width=300 height=250/></a>

</div>

</div>

</body>

</html>

标准的的flash插入

xml/html code

<!-- 标准的的flash插入

设置高度与宽度:

width=400 height=400

设置路径:

data=style/flash/001.swf 与 value=style/flash/001.swf

替代文本或替代图片:

<a href= title=><img src= alt= /></a> 也可以不要这段

-->

<object type=application/x-shockwave-flash data=style/flash/001.swf width=400 height=400>

<param name=movie value=style/flash/001.swf />

<a href=style/flash/001.swf><img src=style/img/001.jpg alt=flash动画 /></a>

</object>

不会遮住层的flash

xml/html code

<!-- 不会遮住层的flash

让flash不档住浮动对象或层的关键属性:

<param name=wmode value=opaque />

<embed wmode=opaque></embed>

-->

<object type=application/x-shockwave-flash data=style/flash/001.swf width=400 height=400>

<param name=movie value=style/flash/001.swf />

<param name=wmode value=opaque />

<embed wmode=opaque></embed>

<a href=style/flash/001.swf><img src=style/img/001.jpg alt=flash动画 /></a>

</object>

透明的flash

xml/html code

<!-- 透明的flash

让flash透明的关键属性:

<param name=wmode value=transparent>

-->

<object type=application/x-shockwave-flash data=style/flash/001.swf width=400 height=400>

<param name=movie value=style/flash/001.swf />

<param name=wmode value=transparent>

<a href=style/flash/001.swf><img src=style/img/001.jpg alt=flash动画 /></a>

</object>

wmode 属性/参数值 window | opaque | transparent

模板变量:$wm,(可选)允许使用 internet explorer 4.0 中的透明 flash 内容、绝对定位和分层显示功能。此标记/属性仅在带有 flash player activex 控件的 windows 中有效。

window在 web 页上用影片自己的矩形窗口来播放应用程序。window表明此 flash 应用程序与 html 层没有任何交互,并且始终位于最顶层。

opaque 使应用程序隐藏页面上位于它后面的所有内容。

transparent使 html 页的背景可以透过应用程序的所有透明部分显示出来,并且可能会降低动画性能。

opaque windowless和transparent windowless都可与 html 层交互,从而允许 swf 文件上方的层遮蔽应用程序。这两种选项之间的差异在于transparent允许透明,因此,如果 swf 文件的某一部分是透明的,则 swf 文件下方的 html 层可以透过该部分显示出来,而opaque则不会显示。

如果忽略此属性,默认值为 window。仅适用于 object。

推荐信息