msdn上给出了非常详细的例子来告诉我们如何使用这些脚本方法,有一点需要注意,使用Silverlight.js文件时一定要与当前Silverlight版本相一致,否则可能会有脚本错误,对应的Silverlight.js文件可以在微软的站点上下载,你会发现其实有很多个可用的版本,其中还包括支持调试的版本哦。
createObject方法参数在使用的时候有几个问题需要注意下:
1. 参数按顺序指定,如果有不需要传递的参数可用null代替。
2. parent element参数必须指定,也就是object标记的父元素,可直接将元素的id当做对象传入,但是在Firefox中不支持,此时可以使用document.getElementById('elementId')语句代替该参数即可。
3. param列表通过数组传递,参数名称与在object标记中使用的名称保持一致即可。
4. 事件列表如果没有对应的页面脚本则传null值,否则会报脚本错误。
5. 最后一个参数context如果不需要可以省去,不用传null或空值。
你应该注意到了,在使用createObject方法时我们可以顺便给Silverlight指定nonSilverlight效果,这个是通过param列表中的altHtml参数来指定的,实施上,我们在页面上直接使用object标记呈现Silverlight时也可以使用alt属性来指定nonSilverlight效果,这个与在object标记中直接插入html代码的效果相同。
通过使用createObject方法,我们完全可以自定义lowSilverlight效果了,下面是一个例子:
复制代码 代码如下:
<div>
<script type="text/javascript">
if (Silverlight.isInstalled("4.0.50303.0")){
Silverlight.createObject("ClientBin/SilverlightApplication1.xap",
document.getElementById('divSilverlightContent'),
null,
{ width: "532px", height: "380px", background: "white", version:"4.0.50303.0", windowless:"true" },
null,
"param1=value1,param2=value2");
}
else {
document.write('<img src="https://www.jb51.net/images/NonSilverlight.jpg" usemap="#SLMap3D_NonSilverlight" />'
+ '<map>'
+ '<area shape="RECT" coords="154,87,362,183" title="Get Microsoft Silverlight" href="https://www.microsoft.com/silverlight/resources/install.aspx" target="_blank" />'
+ '</map>');
}
</script>
<iframe></iframe>
</div>
使用Silverlight.isInstalled()方法可以判断客户端浏览器是否已经安装了指定版本的Silverlight插件,如果已经安装了,则使用Silverlight.createObject方法创建Silverlight对象,否则输出自定义的内容。
这里还有一篇文章个人觉得很有用,给大家分享下吧!