转自:http://www.cnblogs.com/ListenFly/archive/2011/12/07/2269532.html
Silverlight虽然是以插件形式来显示的,但是它和JS以及HTML的交互还是很方便的,下面一一道来
Silverlight得到浏览器的信息:
browserinformation b = HtmlPage.browserinformation; lblInfo.Text = "Name: " + b.Name; lblInfo.Text += "\nbrowser Version: " + b.browserVersion.ToString(); lblInfo.Text += "\nPlatform: " + b.Platform; lblInfo.Text += "\nCookies Enabled: " + b.CookiesEnabled; lblInfo.Text += "\nUser Agent: " + b.UserAgent;
Name,得到浏览器名称
browserVersion得到浏览器版本
Platform,得到运行平台信息
CookiesEnabled,得到一个值标识是否启用Cookie
UserAgent得到当前代理信息
HtmlPage.PopupWindow,打开一个窗口,可以指定HtmlPopupWindowOptions参数,
HtmlPopupWindowOptions options = new HtmlPopupWindowOptions(); options.Height = 200; options.Width = 200; options.Toolbar = false; options.Status = false; options.Resizeable = false; options.Location = false; HtmlPage.PopupWindow(new Uri("http://www.baidu.com"),null,options);
HtmlPopupWindowOptions 可以指定页面的属性,高度、宽度地址栏之类的属性,其实PopupWindow的原理就是调用了js的Window.Open方法.
切记,PopopWindow只能在事件(触发)中起作用,也就意味着不能一开始就显示,另外其中的Url必须是绝对路径。
HtmlDocument,表示一个完整的 Html的 Document对象,可以使用HtmlPage.Document得到
主要属性:
QueryString:得到传递的参数
DocumentElement:得到HtmlDocument对象
Body:得到Body节点(HtmlElement类型)
Cookies:Cookie的支持,很有用
CreateElement():创建一个HtmlElement节点(一个Html的标签元素)
AttachEvent():给Html元素附加脚本事件
DetachEvent():删除脚本事件
Submit():提交页面,如果Silverlight在aspx页面很有用,可以执行服务器代码
操作HtmlElement:
AppendChild():追加HtmlElement对象
RemoveChild():移除HtmlElement
Focus():使HtmlElement元素获得焦点
GetAttribute(),
SetAttribute(),and
RemoveAttribute(): 得到或者设置或移除HtmlElement的属性(本身Html DOM 存在的,不是自己指定的)
GetStyleAttribute(),0)">SetStyleAttribute(),0)">RemoveStyleAttribute():得到或者设置或移除HtmlElement的样式属性
Getproperty() and
Setproperty():得到或者设置HtmlElement的属性(自己添加的或者是作为了HtmlElement的一部分的属性比如 innerHTML)
AttachEvent() and
DetachEvent():附加和移除JS脚本事件
HTML DOM 的事件:
onchange 值改变的时候触发
onclick 单击事件
onmouSEOver 鼠标悬浮事件
onmouSEOut 鼠标离开事件
onkeydown 键盘按下事件
onkeyup 键盘放开事件
onselect 当Select被选择时候
onfocus 获得焦点
onblur 失去焦点
onerror 发生错误时候
onload 页面加载事件
onunload 页面关闭(或者通过超链跳转,新页面显示之前执行)
现有JS函数如下:
function changeParagraph(newText) { var element = document.getElementById("ptest"); element.innerHTML = newText; }
使用ScriptObject对象实现调用,通过HtmlPage.Window.GetProperty("changeParagraph")得到Object对象,其中的参数就是JS方法的名称
然后使用ScriptObject调用InvokeSelf方法,参数就是JS方法的参数(如果有参数就传递,否则就不传递)
ScriptObject script = (ScriptObject)HtmlPage.Window.GetProperty("changeParagraph"); script.InvokeSelf("Changed through JavaScript");
第二种方法:
现有JS函数如下:
这个JS方法使用了对象的方式,并且还赋予了属性为一个Function
myHello = function(message) { this.Message = message; }
myHello.prototype.display = function() { var resultSpan = $get("result"); resultSpan.innerText = "Hello " + this.Message; }
可以看到获取ScriptObject的方式变化了,因为这个JS使用了对象的方式在使用,同时他的属性prototype有一个display的属性(一个Function),
然后使用ScriptObject对象的Invoke方法参数为prototype的属性名称。
ScriptObject script=HtmlPage.Window.CreateInstance("myHello",this.input.Text);
object result = script.Invoke("display");//执行这个方法之后既会执行myHello方法也会执行display方法
在JS中访问Silverlight中的函数:
①脚本化的类必须是 public 的
②需要脚本化的属性、方法、事件要标记为 [ScriptableMember]
③如果类(XAML页面)被标记为 [ScriptableType],则意味着其属性、方法、事件都是可被访问的
④使用HtmlPage.RegisterScriptableObject()或者HtmlPage.RegisterCreateableType()进行注册,
⑤给我们的obejct标签添加一个唯一的ID(在JS中通过这个插件来访问Silverlight注册的函数)
看看类的代码实现:
Class Scriptable { [ScriptableMember] public string Hello(string name) { return string.Format("Hello: {0}",name); } }
//sriptableMemberAttribute实例化要本化的类 Sriptable s = new Scriptable() { CurrentTime = DateTime.Now }; //将 Scriptable 对象注册到客户端中,所对应的客户端的对象名为 scriptable HtmlPage.RegisterScriptableObject("scriptable",s);
在JS中访问:
var slPlugin = $get('Xaml1'); //其中的scriptable为注册在客户端的脚本化对象的名字 var obj = document.getElementById("xaml1").content.scriptable; //调用脚本化类得方法,其中Hello为类中的方法 output.innerHTML += obj.Hello("webabcd");
[ScriptableType()] public partial class ScriptableSilverlight: UserControl { public ScriptableSilverlight() { InitializeComponent(); HtmlPage.RegisterScriptableObject("Page",this); } [ScriptableMember()] public void ChangeText(string newText) { lbl.Text = newText; } }
JS中的调用
function updateSilverlightText() { var control = document.getElementById("silverlightControl"); control.content.Page.ChangeText( "This TextBlock has been updated through JavaScript."); }
和刚才的方式一摸一样
上边的例子是使用 HtmlPage.RegisterScriptableObject的方式注册一个对象,接下来使用HtmlPage.RegisterCreateableType注册一个类型:
[ScriptableType()] public class RandomNumbers { private Random random = new Random(); [ScriptableMember()] public int GetRandomNumberInRange(int from,int to) { return random.Next(from,to+1); } }
在XAML中进行注册:
第一个参数只是对象的名字称号,第二个就是类型
HtmlPage.RegisterCreateableType("RandomNumbers",typeof(RandomNumbers));
在JS中访问这个类中的这个GetRandomNumberInRange方法:
看到和上边的区别了吧,没错上边是“document.getElementById("xaml1").content.scriptable;”而这里是使用content.services.createObject()方法,
参数就是在XAML中使用“HtmlPage.RegisterCreateableType”注册的第一个参数,得到一个注册的对象,然后使用对象访问GetRandomNumberInRange
方法,如果有参数则传递。
function getRandom1To6() { var control = document.getElementById("silverlightControl"); var random = control.content.services.createObject("RandomNumbers"); alert("Your number is: " + random.GetRandomNumberInRange(1,6)); }
HTML和Silverlight交互的安全性,下边这两个配置可以保护:
<param name="enableHtmlAccess" value="false" />设置为false之后则无法使用Document,Window,Plugin,browserinformation ,但是可以使用HtmlPage.PopupWindow();
<param name="allowHtmlPopupwindow" value="false" />如果为false,则无法使用HtmlPage.PopupWindow();
好了,Silverlight和HTML的交互就到这里吧,希望大家指出错误的地方。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。