在Silverlight嵌入到HTML之windowless属性及运用AjaxControlToolKit时出现虚线边框的问题里谈一些Silverlight在浏览器上运行时会出现虚线边框的问题,当时主要考虑了IE7和FireFox,却没想到在IE6 sp2上还是会出现虚线边框,必须鼠标点击一次让其获得焦点虚线边框才消失。
经过测试,发现如果用<asp:Silverlight />引入silverlight来取代直接使用<object>可以避免虚线边框的出现。实际上直接使用<object>的代码可以完全移植到<asp:Silverlight />里,<asp:Silverlight />是动态生成了object标签的,只不过其中的很多js我还没有看得很明白。
需要注意的一点,直接使用<object>对应的代码可以写成这样:
<div id="silverlightHost" style="width:275px; height:324px;background-color:transparent;float:left"> type="application/x-silverlight-2" style="width:100%;height:100%;position:absolute"> alt="Get Microsoft Silverlight" style="border-style: none"/> |
在对应的onSilverlightLoaded事件中可以获得<object>元素及包含他的<div>:
function onSilverlightHomePeoplePickerLoaded(sender, args) { |
使用<asp:Silverlight />控件实际上生成的也是<object>,只不过在<object>标签外面加了一个<span>,大致等价于:
<span> |
<div id="silverlightHost" style="height:100%;"> MinimumVersion="2.0.31005.0" Width="100%" Height="100%" OnPluginLoaded="onSilverlightLoaded" /> |
对应的javascript代码要稍做修改:
function onSilverlightHomePeoplePickerLoaded(sender, args) { |
【编辑推荐】