加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

利用swfobject将swf嵌入到jsp页面

发布时间:2020-12-15 06:44:57 所属栏目:百科 来源:网络整理
导读:用途: 用于在HTML中方面插入Adobe Flash媒体资源(*.swf文件)的独立、敏捷的JavaScript模块,该模块中的JavaScript脚本能够自动检测PC、Mac机器上各种主流浏览器对Flash插件的支持情况。目前最新的版本是2.2,这里可以下载最新版的SWFObject: http://code.

用途:

用于在HTML中方面插入Adobe Flash媒体资源(*.swf文件)的独立、敏捷的JavaScript模块,该模块中的JavaScript脚本能够自动检测PC、Mac机器上各种主流浏览器对Flash插件的支持情况。目前最新的版本是2.2,这里可以下载最新版的SWFObject:
http://code.google.com/p/swfobject/

?

优点:

1.IE中没有讨厌的虚框问题了。
2.提供了完善的版本检测功能,如果版本不够则显示其他东西,比如图片或文字。
3.易于使用,只要在页面头加载一个 .js 文件,然后 HTML 写一个容器,里面放普通的文本或图片(用于无法显示 Flash 时显示),最后用脚本来替换这个元素里面的内容为 Flash。
4.使得插入Flash媒体资源尽量简捷、安全。而且它是非常符合搜索引擎优化的原则的。
5.能够避免HTML、XHTML中出现object、embed等非标准标签,从而符合更加标准。

?

范例:

<script type="text/javascript" src='#'" /script>
?
<div id="flashcontent">
?This text is replaced by the Flash movie.
</div>

?

<script type="text/javascript">
? var so = new SWFObject("movie.swf","mymovie","200","100","7","#336699");
? so.write("flashcontent");
</script>

注释:

1、<div id="flashcontent">[...]</div>首先,我们要为SWF资源预留一个HTML结点。这个HTML结点内的所有内容都会在客户端被Flash资源替换,当客户端没有安装Flash播放器的时候,这些内容会显示出来。这一特色在SEO以及对用户体验方面非常有必要。

2、var so = new SWFObject(swf,id,width,height,version,background-color [,quality,xiRedirectUrl,redirectUrl,detectKey]);创建一个新的SWFObject实例,并且传入一下参数:?

swf - SWF文件路径
id - 您为这个SWF文件分配的id值,它将用于给embed与object标签设定name属性,以便于可以支持swliveconnect的功能,如动态传入变量
width - 宽度
height - 高度
version - FlashPlayer需要的版本号,它可以详细到 "主版本号.小版本号.细节",例如:"6.0.65"。一般地,我们只需传入主版本即可,例如:"6"。
background-color - Flash资源的背景色,16进制格式

?

此外,还有如下可选参数:?

quality - 画面质量,默认为"high"。
xiRedirectUrl - 详见ExpressInstall相关
redirectUrl - 没有安装相应版本的播放器后自动跳转的目标地址
detectKey - 这是当忽略检测时,SWFObject将去url地址中查找的变量,默认值为“detectflash”,后续有详细介绍
so.write("flashcontent");将Flash资源应用到DOM里,在浏览器显示出来。

?

其它参数:

SWFObject在?

<script type="text/javascript">
</script>?

之间加入多个参数来实现各个效果,参数很多,但是实际只要一点点。我们可以看下这样的代码:

?

?<script type="text/javascript" src='#'" /script>
?<script type="text/javascript">
?? var so = new SWFObject("movie.swf","400","100%","8","#336699");
?? so.addParam("quality","low");
?? so.addParam("wmode","transparent");
?? so.addParam("salign","t");
?? so.addVariable("variable1","value1");
?? so.addVariable("variable2","value2");
?? so.addVariable("variable3","value3");
?? so.addVariable("variable1",getQueryParamValue("variable1"));
?? so.addVariable("variable2",getQueryParamValue("variable2"));
?? so.write("flashcontent");
</script>

?

这段代码给出了SWFObject的常用参数:

?

?? var so = new SWFObject(swf,detectKey]);
?? so.addParam("Param1","Param2");
?? so.addParam("Param3","Param4");
?? so.addParam("Param5","Param6");
?? so.addVariable("variable1",getQueryParamValue("variable2"));
?? so.write("content");

?

解释一下这些参数的作用:

?

?? var so = new SWFObject(swf,detectKey]);???????? //这段是SWFObject必须的基本参数,所有SWFObject都必须包含的。
?? so.addParam("Param1","Param2");?? //这里是给Flash添加内联参数,可以实现诸如背景透明之类的效果。依照需求添加就可以了,参数和emded/object标签是一样的代码,下同。
?? so.addParam("Param3","value1");??? //这里是给Flash添加FlashVar,这是以FlashVar的方式给Flash的Root添加变量,对于Number型变量在Flash端需要做类型转换。
?? so.addVariable("variable2",getQueryParamValue("variable1"));?? //Flash获取URL变量对于url?arg1=test1&arg2=test2这样用GET方式传递变量的URL,我们可以用getQueryParamValue方法来获取变量。
?? so.addVariable("variable2",getQueryParamValue("variable2"));
?? so.write("content");??? //这里是至关重要的一个地方,他是用一段特定内容取代Flash无法显示时的内容。可以事先在CSS里定义好样式,在文档里使用div标签写出来。这里在调用过来。

?

在flex页面中接受jsp传递的参数:this.loaderInfo.parameters.xml;xml与jsp添加时的名字一样就可以取到

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读