SWFObject2.0: 基于Javascript的Flash媒体版本检测与嵌入模块

作者:lihui 来源:163 UED Team 时间:2009-08-19 13:24:00 

1、通过探测Flash Player的版本,来决定显示Flash内容还是替换内容,避免了过时的Flash插件影响Flash内容的正常显示。

2、提供了恢复到替换内容的功能:当Flash内容因为过时的Flash Player而无法正常显示时,SWFObject通过DOM操作用替换内容代替Flash内容。(注意:如果Flash Player没有被安装,HTML object元素会自动被替换内容所替代。)

3、提供了一个选择来使用Adobe Express Install下载最新版本的Flash Player。

4、通过使用专有的embed元素的办法,解决了老版的Webkit引擎会忽略嵌套在object元素中的param元素的问题。(注意:这是唯一一个使用了专有HTML标签的地方,并且在今后的版本中会被逐步淘汰。)

5、提供了一个详尽的JavaScript API来完成一些常见的与Flash Player和Flash内容相关的操作。


二、使用说明:

SWFObject2.0现提供两个主要调用flash方法。

1、静态发表方法用符合标准的标签来嵌入Flash内容和替换内容,并且用JavaScript来解决一些仅依靠标签无法解决的问题。
优势:
(1)、如果你安装了Flash插件,但是JavaScript被禁用了或者浏览器并不支持JavaScript,你仍然能够看到你的Flash内容。
(2)、Flash将能够在那些对JavaScript支持较弱的设备上运行,例如Sony PSP。
(3)、像RSS阅读器这样的自动化的工具能够读取Flash内容。

示例代码如下:
swfobject.registerObject(flashContentId, flashVersion,expressInstallUrl);
flashContentId为Flash的ID,必须;
flashVersion为播放SWF的Player版本,必须;
expressInstallUrl为Flash Player更新安装的swf调用地址;如果当前版本低于flashVersion将自动更新,可选。

2、动态发表方法基于用标准标签插入替换内容,如果浏览器安装了最低版本需求的Flash插件并且拥有足够的JavaScript支持,SWFObject会用JavaScript将替换内容替换成Flash内容(与以前版本的SWFObject以及UFO很相似)。
优势:
(1)、它避免了通过点击激活的机制来激活Internet Explorer 6/7和Opera 9+中的Flash内容。值得注意的是微软正在逐步淘汰IE中的点击激活机制。(Internet Explorer 6/7的点击激活机制已经在2008/4的更新中被移除)
(2)、它能很好的与基于脚本的应用整合。

示例代码如下:
swfobject.embedSWF(swfUrl, id, width, height, version, expressInstallSwfurl, flashvars, params, attributes)有5个必须的参数和4个可选的参数:

swfUrl(String,必须的)指定SWF的URL。
id(String,必须的)指定将会被Flash内容替换的HTML元素(包含你的替换内容)的id。
width(String,必须的)指定SWF的宽。
height(String,必须的)指定SWF的高。
version(String,必须的)指定你发布的SWF对应的Flash Player版本(格式为:major.minor.release)。
expressInstallSwfurl(String,可选的)指定express install SWF的URL并激活Adobe express install [ http://www.adobe.com/cfusion/knowledgebase/index.cfm?id=6a253b75 ]。
flashvars(String,可选的)用name:value对指定你的flashvars。
params(String,可选的)用name:value对指定你的嵌套object元素的params。
attributes(String,可选的)用name:value对指定object的属性。
例如:

<script type=”text/javascript” src=”swfobject.js”></script>
<script type=”text/javascript”>
swfobject.embedSWF(”myflash.swf”, “myflash”, “300″, “120″, “9.0.0″);
swfobject.embedSWF(”myflash.swf”, “myflash”, “300″, “120″, “9.0.0″, null, null, {wmode: ‘transparent’});
</script>
<div id=”myflash”>这里是当flash不能正常显示时显示的内容</div>

配置的Flash内容
你可以为你的object元素添加下面这些常用的可选属性(attributes)[ http://www.w3schools.com/tags/tag_object.asp ]:
id
name
styleclass(不使用class,因为class也是ECMA4的保留关键字)
align
你可以使用下面这些专用于Flash的可选param元素[ http://www.adobe.com/cfusion/knowledgebase/index.cfm?id=tn_12701 ]:
play
loop
menu
quality
scale
salign
wmode
bgcolor
base
swliveconnect
flahvars
devicefont [ http://www.adobe.com/cfusion/knowledgebase/index.cfm?id=tn_13331 ]
allowscriptaccess [ http://www.adobe.com/cfusion/knowledgebase/index.cfm?id=tn_16494 ]
seamlesstabbing [ http://www.adobe.com/support/doc ... 7/releasenotes.html ]
allowfullscreen [ http://www.adobe.com/devnet/flas ... ll_screen_mode.html ]
allownetworking [ http://livedocs.adobe.com/flash/9.0/main/00001079.html ]
怎样用JavaScript对象来定义你的flashvars、params和attributes?
你最好用对象的字面量(Object literal notation)来定义JavaScrpt对象,例如这样:

<script type=“text/javascript“>
var flashvars = {};
var params = {};
var attributes = {};
swfobject.embedSWF(“myContent.swf“, “myContent“, “300“, “120“, “9.0.0“, “expressInstall.swf“, flashvars, params, attributes);

</script>
你可以在定义对象的时候添加你的name:value对(注意:请确保不要再对象中的最后一个name:value对后面加上逗号):

<script type=“text/javascript“>

var flashvars = {
name1: “hello“,
name2: “world“,
name3: “foobar“
};
var params = {
menu: “false“
};
var attributes = {
id: “myDynamicContent“,
name: “myDynamicContent“
};

swfobject.embedSWF(“myContent.swf“, “myContent“, “300“, “120“, “9.0.0“,“expressInstall.swf“, flashvars, params, attributes);

</script>
或者在对象创建之后用点号添加属性(properties)和值:

<script type=“text/javascript“>
var flashvars = {};
flashvars.name1 = “hello“;
flashvars.name2 = “world“;
flashvars.name3 = “foobar“;
var params = {};
params.menu = “false“;

var attributes = {};
attributes.id = “myDynamicContent“;
attributes.name = “myDynamicContent“;

swfobject.embedSWF(“myContent.swf“, “myContent“, “300“, “120“, “9.0.0“,“expressInstall.swf“, flashvars, params, attributes);

</script>
上面的代码也可以这样写:

<script type=“text/javascript“>
swfobject.embedSWF(“myContent.swf“, “myContent“, “300“, “120“, “9.0.0“,“expressInstall.swf“, {name1:“hello“,name2:“world“,name3:“foobar“}, {menu:“false“}, {id:“myDynamicContent“,name:“myDynamicContent“});
</script>

如果你不想使用一个参数,你可以将它定义为false或者一个空对象:
<script type=“text/javascript“>
var flashvars = false;
var params = {};
var attributes = {
id: “myDynamicContent“,
name: “myDynamicContent“
};

swfobject.embedSWF(“myContent.swf“, “myContent“, “300“, “120“, “9.0.0“,“expressInstall.swf“, flashvars, params, attributes);

</script>
flashvars对象是一个为了增加易用性而设计的作为快捷方式的参数,所以你可以先忽略它,然后在params对象中指定你的flashvars:

<script type=“text/javascript“>
var flashvars = false;
var params = {
menu: “false“,
flashvars: “name1=hello&name2=world&name3=foobar“
};
var attributes = {
id: “myDynamicContent“,
name: “myDynamicContent“
};
swfobject.embedSWF(“myContent.swf“, “myContent“, “300“, “120“, “9.0.0“,“expressInstall.swf“, flashvars, params, attributes);

标签:JavaScript,SWFObject,flash,模块
0
投稿

猜你喜欢

  • php可应用于面包屑导航的迭代寻找家谱树实现方法

    2024-05-13 09:24:41
  • SQL Server的触发器你了解多少

    2024-01-14 21:15:57
  • PYTHON 中使用 GLOBAL引发的一系列问题

    2023-07-08 16:24:21
  • python 通过logging写入日志到文件和控制台的实例

    2021-04-26 00:04:38
  • 浅谈javascript中的作用域

    2024-05-11 09:31:22
  • PHP实现判断二叉树是否对称的方法

    2023-06-28 13:24:10
  • python之模拟鼠标键盘动作具体实现

    2022-12-23 10:51:29
  • 深入浅出分析Python装饰器用法

    2022-10-25 16:49:02
  • OpenCV+python实现膨胀和腐蚀的示例

    2021-06-12 10:35:00
  • Python-opencv实现红绿两色识别操作

    2021-05-04 18:35:51
  • python中with用法讲解

    2022-11-29 23:59:37
  • JavaScript自定义浏览器滚动条兼容IE、 火狐和chrome

    2024-04-16 09:37:25
  • 在Pycharm的Project Files下建立多个项目的操作

    2022-02-20 16:27:49
  • 你需要知道的CSS3 动画技术[译]

    2009-12-30 17:02:00
  • ASP中不用模板生成HTML静态页面的方法

    2011-03-06 10:49:00
  • 什么是XML?

    2007-10-29 12:53:00
  • Python基于Tensorflow2.X实现汽车油耗预测

    2021-05-05 05:25:22
  • 网页设计技巧:相对路径与绝对路径的区别问题

    2008-03-04 10:12:00
  • Python7个爬虫小案例详解(附源码)下篇

    2023-11-23 03:47:38
  • 如何安装绿色版MySQL Community Server 5.7.16并实现远程登录

    2024-01-14 13:02:03
  • asp之家 网络编程 m.aspxhome.com