SilverLight浏览器交互之:SilverLight程序调用外部Html中的Javascript方法(附源码)

SilverLight浏览器交互之:SilverLight程序调用外部Html中的Javascript方法(附源码)

概述

WebBrowser

从 Silverlight 3 开始,您将可以创建在浏览器宿主环境外运行的 Silverlight 应用程序。

通过 WebBrowser 控件,您可以在此宿主环境中显示 HTML 内容。

您可以在 XAML 或代码中添加 WebBrowser 控件。默认情况下,WebBrowser 控件不具有大小。

因此,您必须指定 Height 和 Width 以使控件显示在应用程序中。当 WebBrowser 显示在运行在浏览器中的应用程序时,将显示具有指定高度和宽度的一个矩形,以便代替该控件。

您将 HTML 内容设置为以若干方式显示在 WebBrowser 控件中。

  • 调用 NavigateToString 方法并传递一个包含您要显示的 XAML 内容的字符串。

  • 将 Source 属性设置为完全限定 URI 或相对 URI。

  • 调用 Navigate 方法并将一个完全限定的或相对的 URI 传递给您要显示的 HTML 内容。

  

WebBrowser.InvokeScript 方法

执行在当前加载的 HTML 中定义的脚本函数。

名称
说明

InvokeScript(String):执行在当前加载的 HTML 中定义的指定脚本。

InvokeScript(String, array<String>[]):使用指定的参数执行在当前加载的 HTML 中定义的指定脚本函数。

 

WebBrowser.LoadCompleted 事件

当顶级导航完成且内容加载到 WebBrowser 控件中时发生,或在加载期间发生错误时发生。

 

效果:

QQ拼音截图未命名

xaml代码:

复制代码
    <Grid x:Name="LayoutRoot">
        <Grid.Background>
            <LinearGradientBrush StartPoint="0,0" EndPoint="0,1">
                <GradientStop Color="#FF0055DD" Offset="0" />
                <GradientStop Color="#FF00DDFF" Offset="1" />
            </LinearGradientBrush>
        </Grid.Background>

        <!--可以在此空间中显示 HTML 内容。
        Source 为Web中ClientBin中的一个页面-->
        <WebBrowser x:Name="web" Source="/script-page.htm" Margin="15" />
    </Grid>
复制代码

cs代码:

复制代码
        public MainPage()
        {
            InitializeComponent();
            //当顶级导航完成且内容加载到 WebBrowser 控件中时发生,或在加载期间发生错误时发生。
            web.LoadCompleted +=
                new LoadCompletedEventHandler(web_LoadCompleted);
        }


        void web_LoadCompleted(object sender, NavigationEventArgs e)
        {
            //执行在当前加载的 HTML 中定义的脚本函数。
            //不含参数的Javascript方法 SayHello()
            web.InvokeScript("SayHello");
            //有一个参数的Javascript方法 GreetMe(name)
            web.InvokeScript("GreetMe", "'SilverLight'");
        }
复制代码

html代码:

复制代码
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <script language="JavaScript">
        //为div1 添加内容
        //一个参数的方法
        function GreetMe(name) {
            div1.innerHTML += "<p>你好! " + name + "</p>";
        }
        //无参数的方法
        function SayHello() {
            div1.innerHTML += "<p>你好!</p>";
        }            
    </script>
</head>
<body>
    Hello world!<br />
    <div id="div1">
    </div>
</body>
</html>
复制代码

大功告成!

源码下载

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值