Sto avendo un momento divertente che consente a Silverlight e JavaScript di comunicare tra loro.Comunicazione Silverlight e JavaScript
Nel file page.xaml.cs, ho segnato la classe come ScriptableType e due metodi con ScriptableMember. Poi dichiarato:
HtmlPage.RegisterScriptableObject("Page", this);
Quando si tenta di richiamare un metodo, ottengo obj.Content.Page non definita:
var obj = document.getElementById('silverlightControl');
alert(obj); // [object HtmlObjectElement]
alert(obj.Content); // Content
alert(obj.Content.Page); // obj.Content.Page is undefined
alert(obj.Content.Page.GetRegion());
Dall'altro lato, all'interno di un metodo in Page.xaml. cs, sto chiamando:
HtmlPage.Window.Invoke("mapRegionChanged", GetRegion());
ho un relativo metodo in JavaScript, che non viene mai chiamato:
function mapRegionChanged(region) {
alert("Region changed: " + region);
}
L'oggetto Silverlight è dichiarato come segue:
<object data="data:application/x-silverlight-2," type="application/x-silverlight-2"
width="151px" height="77px" id="silverlightControl">
<param name="onload" value="regionsLoaded" />
<param name="source" value="<%= Url.Content("~/ClientBin/Worldmap.xap") %>" />
<param name="onerror" value="onSilverlightError" />
<param name="background" value="white" />
<param name="minRuntimeVersion" value="2.0.31005.0" />
<param name="autoUpgrade" value="true" />
<param name="enableHtmlAccess" value="true" />
<a href="http://go.microsoft.com/fwlink/?LinkID=124807" style="text-decoration: none;">
<img src="http://go.microsoft.com/fwlink/?LinkId=108181" alt="Get Microsoft Silverlight" style="border-style: none" />
</a>
</object>
L'UserControl è definito in XAML come:
<UserControl
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
x:Class="Worldmap.Page"
Width="151" Height="77" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" mc:Ignorable="d">
<Grid x:Name="LayoutRoot" Background="White" Width="151" Height="77" Cursor="Hand" MouseMove="OnMouseMove" MouseLeftButtonUp="OnMouseUp" MouseLeave="OnMouseLeave">
Beh, a quanto pare funziona in IE7, non solo in Firefox 3.0.5. Pensavo che avessimo superato le guerre tra browser con Silverlight? –
Si vede un errore nella console javascript? – russau
No, nessun errore nella console degli errori. –