Изменение размера div контейнера Silverlight позволяет перезагрузить Silverlight в Firefox - PullRequest
3 голосов
/ 02 августа 2011

интересно, нашел ли кто-нибудь легкое решение для этого. Похоже, что вы не можете контролировать размер вашего Silverlight, используя ширину / высоту 100% для объекта Silverlight и затем анимируя высоту и ширину div контейнера в FIrefox. Мне было интересно, если кто-нибудь нашел обходной путь для этого. Довольно разочаровывает, следующее прекрасно работает во всех браузерах, кроме Firefox.

Когда вы нажимаете кнопку test в Firefox, вы видите, что элемент управления Silverlight исчезает, и объект Silverlight должен сам себя перезагрузить. В других браузерах его не нужно перезагружать, а просто оживляет нормально. Почему Firefox, почему? Теперь я должен тебя ненавидеть.

UserControl x:Class="testFirefox.MainPage"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d"
    d:DesignHeight="300" d:DesignWidth="400">
    <Border BorderThickness="4" BorderBrush="Black">
        <Grid x:Name="LayoutRoot" Background="White" HorizontalAlignment="Center" VerticalAlignment="Center">
            <TextBlock Text="Center" FontSize="30"></TextBlock>
        </Grid>
    </Border>
</UserControl>

<%@ Page Language="C#" AutoEventWireup="true" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>testFirefox</title>
    <script type="text/javascript" src="Silverlight.js"></script>
    <script src="jquery-1.6.2.min.js" type="text/javascript"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            $("#testSilverlight").click(function () {
                $("#silverlightControlHost").animate({ width: 700 }, 2000, 'swing');
            });
        });
    </script>
</head>
<body>
    <form id="form1" runat="server" style="height:100%">
    <div id="silverlightControlHost" style="height:300px; width: 300px;">
        <object data="data:application/x-silverlight-2," type="application/x-silverlight-2" width="100%" height="100%">
          <param name="source" value="ClientBin/testFirefox.xap"/>
          <param name="onError" value="onSilverlightError" />
          <param name="background" value="white" />
          <param name="minRuntimeVersion" value="4.0.50826.0" />
          <param name="autoUpgrade" value="true" />
          <a href="http://go.microsoft.com/fwlink/?LinkID=149156&v=4.0.50826.0" style="text-decoration:none">
              <img src="http://go.microsoft.com/fwlink/?LinkId=161376" alt="Get Microsoft Silverlight" style="border-style:none"/>
          </a>
        </object><iframe id="_sl_historyFrame" style="visibility:hidden;height:0px;width:0px;border:0px"></iframe></div>
        <div id="testSilverlight" style="height:50px; width:50px; border: 1px solid black;">
         TEST
      </div>
    </form>
</body>
</html>

1 Ответ

1 голос
/ 26 сентября 2011

Это происходит потому, что jQuery animate изменяет переполнение контейнера, вызывая перезагрузку серебряного света. Нечто подобное может произойти, если вы измените отображение или положение контейнера в Firefox. Я решил эту проблему, комментируя строку 8266 из jQuery 1.6.4 (строка может быть рядом с другими версиями после 1.5) несжатой версии, которая говорит
this.style.overflow = "скрытый";
Надеюсь, это поможет.
Маркос.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...