转自 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", new MyJSClass());

  这里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交互的更多相关文章

  1. 关于JS交互--调用h5页面,点击页面的按钮,分享到微信朋友圈,好友

    关于js交互,在iOS中自然就想到了调用代理方法 另外就是下面的,直接上代码了: 如果你的后台需要知道你的分享结果,那么,就在回调里面调用上传到服务器结果的请求即可

  2. webView和js交互

    与 js 交互 OC 调用 JS // 执行 js - (void)webViewDidFinishLoad:(UIWebView *)webView { NSString *title = [web ...

  3. 李洪强iOS经典面试题147-WebView与JS交互

    李洪强iOS经典面试题147-WebView与JS交互   WebView与JS交互 iOS中调用HTML 1. 加载网页 NSURL *url = [[NSBundle mainBundle] UR ...

  4. WebView---Android与js交互实例

    Android 中可以通过webview来实现和js的交互,在程序中调用js代码,只需要将webview控件的支持js的属性设置为true 原文地址:http://blog.csdn.net/it10 ...

  5. iOS与JS交互实战篇(ObjC版)

    前言 ObjectiveC与Js交互是常见的需求,可对于新手或者所谓的高手而言,其实并不是那么简单明了.这里只介绍iOS7.0后出来的JavaScriptCore framework. 关于JavaS ...

  6. Android WebView加载本地html并实现Java与JS交互

    最近做的一个项目中,用到自定义地图,将自定义地图转换成html页面,现在需要做的是如何将本地的html加载到android中,并可以实现交互. 相关讲解: 其实webview加载资源的速度并不慢,但是 ...

  7. WinForm程序执行JS代码的多种方法以及使用WebBrowser与JS交互

    方法一 使用微软官方组件Interop.MSScriptControl 1.msscript.ocx下载的地址   http://www.microsoft.com/downloads/details ...

  8. WKWebView新特性及JS交互

    引言 一直听说WKWebView比UIWebView强大许多,可是一直没有使用到,今天花了点时间看写了个例子,对其API的使用有所了解,为了日后能少走弯路,也为了让大家更容易学习上手,这里写下这篇文章 ...

  9. 【转】第7篇:Xilium CefGlue 关于 CLR Object 与 JS 交互类库封装报告:全自动注册与反射方法分析

    作者: 牛A与牛C之间 时间: 2013-12-12 分类: 技术文章 | 2条评论 | 编辑文章 主页 » 技术文章 » 第7篇:Xilium CefGlue 关于 CLR Object 与 JS ...

随机推荐

  1. Codeforces Round #168 (Div. 2)

    A. Lights Out 模拟. B. Convex Shape 考虑每个黑色格子作为起点,拐弯次数为0的格子构成十字形,拐弯1次的则是从这些格子出发直走达到的点,显然需要遍历到所有黑色黑色格子. ...

  2. [C# WPF]MoeEroViewer Developing Log

    [C# WPF]MoeEroViewer Developing Log 1st - Base Document run on Https://github.com/Amarillys/MoeEroVi ...

  3. Linux 命令行模式 你需要知道的那些事

    注: 安装软件 pip install + 软件名  例如: pip install xadmin 卸载软件 pip uninstall + 软件名 例如 pip uninstall xadmin 安 ...

  4. ado.net五大对象

    五大对象分别是: 1. Connection:与数据源建立连接. 2. Command:对数据源执行SQL命令并返回结果. 3. DataReader:读取数据源的数据,只允许对将数据源以只读.顺向的 ...

  5. Hibernate的save()和persist()的区别

    hibernate之所以提供与save()功能几乎完全类似的persist()方法,一方面是为了照顾JPA的用法习惯.另一方面,save()和 persist()方法还有一个区别:使用 save() ...

  6. Torch 日志文件的保存 logroll

    Torch 日志文件的保存 logroll 怎样将 Torch 在终端显示的信息,保存到 log 文件中 ?   现在介绍一种方法:利用 logroll 的方式.  参考 https://github ...

  7. SQLServer 自增主键创建, 指定自增主键列值插入数据,插入主键

    http://blog.csdn.net/zh2qiang/article/details/5323981 SQLServer 中含自增主键的表,通常不能直接指定ID值插入,可以采用以下方法插入. 1 ...

  8. fedora wine qq

    http://blog.lilydjwg.me/2015/10/26/run-tencent-qq-lite-with-wine.186640.html

  9. Install Houdini 12.5 x64 in CentOS 7

    Thanks for Must(QQ ID)'s big help for installing Houdini in CentOS7. - download HOUDINI_FX_V12.5.371 ...

  10. 对c语言中malloc和free函数的理解

    最近在复习c语言的时候再次用到了malloc函数和free函数,此处着讲解一下自己对这两个函数的理解和认识. 一. malloc函数和free函数的基本概念和基本的用法 对于malloc函数: 1.  ...