(转)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", 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交互的更多相关文章
- 关于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
1.PHP(外文名: Hypertext Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言. 2.echo,print和print_r的区别: echo和print都可以做 ...
- codeforces Magnets
link:http://codeforces.com/contest/344/problem/A 这道题目很简单. 把输入的01 和10 当做整数,如果相邻两个数字相等的话,那么就属于同一组,否则,就 ...
- C++转义字符
R"()"括号中间的字符串可以去掉转义字符
- 给linux 授权一个可以远程登录的账户
创建用户:grant all on *.* to '; 授权:flush privileges;
- Opencv-Python 学习
加载一个灰度图,显示图片,按下’s’键保存后退出,或者按下 ESC 键退出不保存. import numpy as np import cv2 img = cv2.imread('linux.png' ...
- java多线程基础
多线程基础 读书练习照猫画虎 package Threadtest; import java.util.Date; import java.util.concurrent.ArrayBlockingQ ...
- Linux-awk直接修改原文件
#注意:重定向符号后面的文件名需要加双引号 awk '{print > "file"}' file
- 安装sql2008的时候选择的是Windows身份验证,现在我想用sql server身份验证,我应该到哪儿设置呢
本文档整理自网络,存粹用作笔记. 安装过程中,SQL Server 数据库引擎可以设置为 Windows 身份验证模式或 SQL Server 和 Windows 身份验证模式. 本文介绍如何在安装后 ...
- php 函数汇总
extract 从数组中将变量导入到当前的符号表 $arr['age'] = 30; $arr['name'] = 'bluesky'; $arr['sex'] = 'male'; var_dump( ...
- 在ESXi 5.x 和 ESXi 6.0.x 中如何安装第三方供应商开发的驱动程序
在 VMware ESXi 5.x 和 ESXi 6.0.x 中如何下载并安装异步驱动程序 (2076262) Symptoms 免责声明:本文为 How to download and inst ...