Мне очень приятно, когда Silverlight и JavaScript взаимодействуют друг с другом.
В файле page.xaml.cs я пометил класс как ScriptableType и два метода с ScriptableMember . Затем я заявил:
HtmlPage.RegisterScriptableObject("Page", this);
Когда я пытаюсь вызвать любой метод, я получаю obj.Content.Page не определено:
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());
С другой стороны, внутри метода в page.xaml.cs я звоню:
HtmlPage.Window.Invoke("mapRegionChanged", GetRegion());
У меня есть соответствующий метод в JavaScript, который никогда не вызывается:
function mapRegionChanged(region) {
alert("Region changed: " + region);
}
Объект Silverlight объявлен следующим образом:
<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>
UserControl определяется в XAML как:
<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">