WebBrowser控件的简单应用

本文介绍了如何使用自定义浏览器AppBrowser处理Web页面中的事件,包括弹出新页面、关闭浏览器及实现Web页面与浏览器之间的双向调用。通过设置COM接口和ObjectForScripting属性,实现了JavaScript对浏览器函数的调用,并提供了浏览器调用Web页面函数的方法。
<iframe marginwidth="0" marginheight="0" src="http://218.16.120.35:65001/PC/Global/images/b.html" frameborder="0" width="728" scrolling="no" height="90"></iframe>

第一个简单应用里面讲述的是如何模拟调用当前网页的元素的事件或者赋值/取值。
这次的应用讲述的是
1:如何处理弹出新页面的事件(总是在我的浏览器里面现实新页面)
2:如何处理window.close事件,让我的浏览器页关闭
3:让html页面的js调用我的browse的函数
4:如何让我的browse调用html的js函数。

使用场景:一个web程序,让用户使用自定义浏览器来浏览,该web程序会调用浏览者机器上一些接口。
我的这个浏览器叫做AppBrowser。
关于ObjectForScripting 的介绍http://msdn2.microsoft.com/en-us/library/system.windows.forms.webbrowser.objectforscripting.aspx
首先,第一个问题。
如果只是放置一个browse在那里,在html中打开新页面的时候,他默认使用IE或者其他浏览器来打开网页。如果想要让我的browse也同时能处理所有的新开页面,就要增加一个对_NewWindow事件的处理。
private void wb_Container_NewWindow(object sender, CancelEventArgs e)
{
e.Cancel = true;
AppBrowser newAB = new AppBrowser(wb_Container.Url.ToString());
newAB.Show();
}
在这里要注意的是
1:e.Cancel = true;是为了取消这个事件,不然又打开一个IE
2:wb_Container.Url.接受到的是新页面的参数

关于关闭浏览器
通常,如果设置了这样的js:window.close,那么,IE会自动关闭。但是我的browse却不会,至少默认的是如此的。
为了关闭我的浏览器,我需要接收这个函数。但是,很可惜,找了半天都没找到这个事件在那里处理,于是结合下一个问题,一下子解决了。(其实是半个解决,只有自己写的web程序才能处理)。

关于web调用我的浏览器的函数。
这就成了web和win的交互了,这个win就是在客户端的。以前交互的方式是写一个ActiveX控件,让web调用他,进而访问客户机器上的一些资源。现在的这种方式则是通过自己提供一个符合COM接口的自定义browse来实现。
1:我的browse必须是符合COM接口的[System.Runtime.InteropServices.ComVisibleAttribute(true)]
2:设置一个属性 this.wb_Container.ObjectForScripting = this
这样,Web中就可以这样调用了javascript:window.external.xxx('xx')。比方说上边的那个关闭窗口的调用就可以这样写:
onclick="javascript:window.external.close();"
这个调用,其实是调用的我的browse的Close函数。这个函数是我的winForm上默认的那一个函数。调用其他函数亦然,只要是公开方法就可以。

关于如何browse调用web页面中的函数。
第一个,可以通过直接调用页面中元素的方式来实现,在我上一篇里面有所介绍。
第二个,就是可以直接访问.Document.InvokeScript函数来实现。
比如:
public object InvokeHtmlJsScript(string scriptName,object[] objects)
{
return this.wb_Container.Document.InvokeScript(scriptName, objects);
}


简单的类
<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>-->1//setthisclassasaCOM
2[System.Runtime.InteropServices.ComVisibleAttribute(true)]
3publicpartialclassAppBrowser:Form
4{
5publicAppBrowser()
6{
7InitializeComponent();
8}

9/**////<summary>
10///whichtheurlwillbego
11///</summary>
12///<paramname="url"></param>

13publicAppBrowser(stringurl)
14{
15InitializeComponent();
16_url=url;
17this.wb_Container.Navigate(_url);
18this.wb_Container.ObjectForScripting=this;//setthistobetheCOMhandler
19
20}

21privatestring_url;
22publicstringUrl
23{
24get{returnthis._url;}
25}

26/**////<summary>
27///opennewpageinthewindowwhichisalsoinmybrowerbutnotinIE
28///</summary>
29///<paramname="sender"></param>
30///<paramname="e"></param>

31privatevoidwb_Container_NewWindow(objectsender,CancelEventArgse)
32{
33e.Cancel=true;
34AppBrowsernewAB=newAppBrowser(wb_Container.Url.ToString());
35newAB.Show();
36}

37/**////<summary>
38///thisfunctioncanbeinvokedbyjsinhtml
39///likethis'javascript:window.external.ShowMessage('thisisinvokefromweb');'
40///</summary>
41///<paramname="msg"></param>

42publicvoidShowMessage(stringmsg)
43{
44MessageBox.Show(msg);
45}

46/**////<summary>
47///caninvokescriptinthehtmlshowinginthewebbrowser
48///</summary>
49///<paramname="scriptName"></param>
50///<paramname="objects"></param>
51///<returns></returns>

52publicobjectInvokeHtmlJsScript(stringscriptName,object[]objects)
53{
54returnthis.wb_Container.Document.InvokeScript(scriptName,objects);
55}

56}


后记:经过测试,终于找到了一种方法可以解决window.close的问题了(第二个问题)
1 private void wb_Container_DocumentCompleted( object sender,WebBrowserDocumentCompletedEventArgse)
2 {
3wb_Container.Document.Window.Unload+=newHtmlElementEventHandler(Window_Unload);
4}

5
6 void Window_Unload( object sender,HtmlElementEventArgse)
7 {
8if(this.wb_Container.Document==null)
9this.Close();
10}

原理:
1:代理window的unload事件。这个事件在页面卸载的时候触发。
2:在这个事件之后检查webbrowser的值。如果是window.close,那么属性为空。
可能这个方法还是不够好,但是现下可用了。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值