常有网友提问,如何让网页中嵌入的Flash标签也符合web标准。目前还没有一个完美的解决办法,这篇文章中,我们将Flash嵌入标签写入js文件中,通过变量传递参数的办法往返避不符合标准的标签。
请注重,这只是一个变通的方法,换汤不换药,并未能最终解决存在的问题,通过验证只是一种表象,这样的思路是不是可取,在实际操作中请大家自行斟酌。
首先建立一个JS文件flash.js。写入如下代码
function swf(file,w,h) {
document.write('%26lt;object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=7,0,19,0" width="'+w+'" height="'+h+'"%26gt; ');
document.write('%26lt;param name="movie" value="' + file + '"%26gt;');
document.write('%26lt;param name="quality" value="high"%26gt; ');
document.write('%26lt;param name="wmode" value="transparent"%26gt; ');
document.write('%26lt;param name="menu" value="false"%26gt; ');
document.write('%26lt;embed src="' + file + '" quality="high" pluginspage="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash" width="'+w+'" height="'+h+'"%26gt;%26lt;/embed%26gt; ');
document.write('%26lt;/object%26gt; ');
}
上面的js脚本定义了一个函数swf,并设置三个变量,它们分别是flile文件链接,w宽度,h高度。在XHTML中向这个函数传递变量即可实现flash的嵌入。如下代码
%26lt;div id="flash"%26gt;
%26lt;script type="text/javascript" language="javascript"%26gt;swf('designyesky.swf','500','220');%26lt;/script%26gt;
%26lt;/div%26gt;
建立id为flash的div作为一容器,在其内部嵌入js脚本,变量依次为文件路径、宽度、高度。
看下面的全部代码
%26lt;!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"%26gt;
%26lt;html xmlns="http://www.w3.org/1999/xhtml"%26gt;
%26lt;head%26gt;
%26lt;meta http-equiv="Content-Type" content="text/html; charset=gb2312" /%26gt;
%26lt;title%26gt;符合web标准的嵌入Flash的方法%26lt;/title%26gt;
%26lt;script type="text/javascript" language="javascript" src="flash.js"%26gt;%26lt;/script%26gt;
%26lt;style type="text/css"%26gt;
#flash { width:500px; margin:50px auto; border:5px solid #03c;}
%26lt;/style%26gt;
%26lt;/head%26gt;
%26lt;body%26gt;
%26lt;div id="flash"%26gt;
%26lt;script type="text/javascript" language="javascript"%26gt;swf(designyesky.swf','500','220');%26lt;/script%26gt;
%26lt;/div%26gt;
%26lt;/body%26gt;
%26lt;/html%26gt;
