(转)Silverlight 与 JS交互
转自 http://www.cnblogs.com/wt616/archive/2011/10/08/2201987.html
1、Silverlight直接调用JS的函数:
这个很简单,只要在HTML中定义好JS函数,然后在Silverlight中调用:HtmlPage.Window.Invoke("函数名",para1,para2...);即可。
其中第一个参数为string型的函数名,与JS中的函数要一致,后面的为参数,取决于JS中函数的定义。
2、JS中引用Siverlight的对象(C#对象),并获取对象的属性、调用对象的函数:
思路为:定义C#对象——》实例化对象——》将实例以某一个ID作为Key注册到JS中——》JS载入时需要获取Silverlight的Host,其中包含了所有由C#注册的对象实例,凭借ID获取即可。
注意:需要对JS暴露的函数或者属性前,要标记[ScriptableMemberAttribute]属性,如果想偷懒,可以直接在类头标记[ScriptableType]属性
例:
1、定义C#对象:

[ScriptableType]
public class MyJSClass
{
private string[] list;
public MyJSClass()
{
list = new string[];
for (int i = ; i < list.Length; i++) {
list[i] = "wangtao" + i;
}
} //[ScriptableMemberAttribute]
public int Length
{
get
{
return list.Length;
}
} [ScriptableMemberAttribute]
public string getStr(int index)
{
return list[index];
}
}

2、实例化,并注册:
| HtmlPage.RegisterScriptableObject("abc", newMyJSClass()); | 
这里abc就是ID,在JS代码中必须根据这个ID来找到对象实例。
3、JS载入时需要获取Silverlight的Host
在JS中定义一个全局变量:
var control = null;这个是对Silverlight宿主的引用,因为可能多个JS函数都要用到它,所以作为全局变量。
在HTML中,找到<object></object>标记对,添加一个param:
(自己试验是在aspx页面添加才好使)
<param name="onLoad" value="plugInLoaded"/>
并在JS部分添加对应的载入函数:

 function plugInLoaded(sender, args) {
            control = sender.getHost();//获取宿主
            try {
                var i = 0;
                var len = control.Content.abc.Length;
                var result = null;
                var str = "";
                for (i = 0; i < len; i++ ) {
                    result = control.Content.abc.getStr(i);
                    str += result + "\n";
                }
                alert(str);
            }
            catch (e) {
                alert(e);
            }
        }

这个例子中,我在载入页面后,获取了宿主,并立刻调用了C#对象实例,一般情况下,只需保留 “control = sender.getHost();//获取宿主” 即可,至于C#对象则等到需要调用的JS函数中使用即可。
这样,通过上述的方法,可以无缝实现Silverlight调用JS和JS调用C#对象了,许多JS有而Silverlight没有的功能就可以利用这点来实现了。
(转)Silverlight 与 JS交互的更多相关文章
- 关于JS交互--调用h5页面,点击页面的按钮,分享到微信朋友圈,好友
		关于js交互,在iOS中自然就想到了调用代理方法 另外就是下面的,直接上代码了: 如果你的后台需要知道你的分享结果,那么,就在回调里面调用上传到服务器结果的请求即可 
- webView和js交互
		与 js 交互 OC 调用 JS // 执行 js - (void)webViewDidFinishLoad:(UIWebView *)webView { NSString *title = [web ... 
- 李洪强iOS经典面试题147-WebView与JS交互
		李洪强iOS经典面试题147-WebView与JS交互 WebView与JS交互 iOS中调用HTML 1. 加载网页 NSURL *url = [[NSBundle mainBundle] UR ... 
- WebView---Android与js交互实例
		Android 中可以通过webview来实现和js的交互,在程序中调用js代码,只需要将webview控件的支持js的属性设置为true 原文地址:http://blog.csdn.net/it10 ... 
- iOS与JS交互实战篇(ObjC版)
		前言 ObjectiveC与Js交互是常见的需求,可对于新手或者所谓的高手而言,其实并不是那么简单明了.这里只介绍iOS7.0后出来的JavaScriptCore framework. 关于JavaS ... 
- Android WebView加载本地html并实现Java与JS交互
		最近做的一个项目中,用到自定义地图,将自定义地图转换成html页面,现在需要做的是如何将本地的html加载到android中,并可以实现交互. 相关讲解: 其实webview加载资源的速度并不慢,但是 ... 
- WinForm程序执行JS代码的多种方法以及使用WebBrowser与JS交互
		方法一 使用微软官方组件Interop.MSScriptControl 1.msscript.ocx下载的地址 http://www.microsoft.com/downloads/details ... 
- WKWebView新特性及JS交互
		引言 一直听说WKWebView比UIWebView强大许多,可是一直没有使用到,今天花了点时间看写了个例子,对其API的使用有所了解,为了日后能少走弯路,也为了让大家更容易学习上手,这里写下这篇文章 ... 
- 【转】第7篇:Xilium CefGlue 关于 CLR Object 与 JS 交互类库封装报告:全自动注册与反射方法分析
		作者: 牛A与牛C之间 时间: 2013-12-12 分类: 技术文章 | 2条评论 | 编辑文章 主页 » 技术文章 » 第7篇:Xilium CefGlue 关于 CLR Object 与 JS ... 
随机推荐
- php-长文章分页函数
			<?php function ff_page($content,$page) { global $expert_id; $PageLength = 2000; //每页字数 $CLength = ... 
- 一个大数据的demo
			package test.admin; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.Fil ... 
- ubantu svn 安装、卸载、配置hooks
			1.安装之前先看是否已经安装了 svn -version 若已经安装会有以下提示,若没有安装,进行下一步 若想卸载了执行命令 ( sudo apt-get remove --purge subvers ... 
- 浅谈P NP NPC
			P问题:多项式时间内可以找到解的问题,这个解可以在多项式时间内验证. NP问题:有多项式时间内可以验证的解的问题,而并不能保证可以在多项式时间内找到这个解. 比如汉密尔顿回路,如果找到,在多项式时间内 ... 
- UVA 1395 (kruskal)
			/* 最大路与最小路的问题: 这道题看似简单,但是若不知道思路将无法写出. 思路:最小生成树很容易求出,但是最大值与最小值只差很难保证是最小的, 比如:1 5 5 6 100 101 很明显101 - ... 
- 解释器模式(Interpreter Pattern)
			定义:给定一种语言,定义他的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中句子. 抽象解释器:声明一个所有具体表达式都要实现的抽象接口(或者抽象类),接口中主要是一个interpre ... 
- mac电脑的使用
			1. control + command + a 截图 2. shift + command + g 前往 3.在 Mac OS X 中怎样获取当前文件夹的路径 原文网址:https://www.zh ... 
- tomcat  building
			https://tomcat.apache.org/tomcat-7.0-doc/building.html https://tomcat.apache.org/tomcat-7.0-doc/BUIL ... 
- maven3.2.3+eclipse4.4+JDK1.8+win8.1_64bit环境搭建
			--------------------------------------- 博文作者:迦壹 博客标题:win8.1_64bit+eclipse4.4+maven3.2.3+JDK1.8环境搭建 博 ... 
- kylin(二): Calcite
			Apache Calcite是面向Hadoop新的查询引擎,它提供了标准的SQL语言.多种查询优化和连接各种数据源的能力,除此之外,Calcite还提供了OLAP和流处理的查询引擎.Calcite之前 ... 
