Internet Explorer 编程简述(一)WebBrowser还是WebBrowser_V1

——谨以怀念研究Internet Explorer编程的青春岁月

Posted by eagleboost on September 6, 2004

本文转载自我2004年在csdn发布的博客

你的机器上总是存在着“两”个WebBrowser,一个叫WebBrowser,另一个叫WebBrowser_V1,其CLASSID如下:

1
2
  CLASS_WebBrowser: TGUID = '{8856F961-340A-11D0-A96B-00C04FD705A2}';  
  CLASS_WebBrowser_V1: TGUID = '{EAB22AC3-30C1-11CF-A7EB-0000C05BAE0B}';

它们分别对应的接口是IWebBrowser2IWebBrowser。问题是我们该用哪一个呢?按照微软的推荐,应该尽量使用前者,因为后者是为兼容Internet Explorer 3.x而保留的(尽管它能够响应来自Internet Explorer 3.x、4.x、5.x、6.x的事件),相应的IWebBrowserIWebBrowserApp接口也应抛弃。 由于Internet Explorer 3.x年代久远,导致WebBrowser_V1提供的事件少得可怜,但值得一提的是它提供的两个事件OnNewWindowOnFrameBeforeNavigate有着与OnBeforeNavigate几乎相同的参数:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
OnBeforeNavigate(  
  BSTR URL,   
  long Flags,   
  BSTR TargetFrameName,   
  VARIANT* PostData,   
  BSTR Headers,   
  BOOL FAR* Cancel)

OnNewWindow(  
  BSTR URL,   
  long Flags,   
  BSTR TargetFrameName,   
  VARIANT* PostData,   
  BSTR Headers,   
  BOOL FAR* Processed)
  
OnFrameBeforeNavigate(  
  BSTR URL,   
  long Flags,   
  BSTR TargetFrameName,   
  VARIANT* PostData,   
  BSTR Headers,   
  BOOL FAR* Cancel)

所以使用WebBrowser_V1使得我们的浏览器在有新窗口打开时能够轻易捕捉到其URL及相关的数据,如果将Processed设置为TRUE,则可取消新窗口的弹出。同样,处理Frame也比在WebBrowser中来得容易。

WebBrowser_V1的致命弱点是它不支持高级接口,如IDocHostUIHandler,即便我们实现了IDocHostUIHandler接口,也不会被WebBrowser_V1调用。所以希望在自己的浏览器中实现XP的界面主题、扩展IE的DOM(Document Object Model)等高级控制的话,就肯定不能选择WebBrowser_V1了。

处理新窗口实在是很麻烦的一件事,不知道微软为什么在新版本的OnNewWindow2事件中去掉了URL这样的参数,而且OnNewWindow2事件不能完全捕捉到所有的新窗口打开。但如果安装了Windows XP SP2的话,好处又回来了。

Windows XP SP2对Internet Explorer 6作了升级,并且提供了一个新的事件OnNewWindow3,它在OnNewWindow2事件之前发生,也包含了让我们能够加以过滤处理的新窗口的URL等参数,再加上INewWindowManager接口,就是实现Windows XP SP2中过滤广告窗口功能的基础。