VB操作IE浏览器完全控制

本文将一步步介绍如何通过VB调用IE的对象库来对IE进行控制。
本文使用的编程工具是VB6英文企业版,浏览器是IE5,以下的代码只能在IE4及以上版本下运行。另外为了能深入了解程序代码,最好能安装MSDN。文中的所有对象、函数、事件在其中都可以查到。[@more@]
相信现在绝大多数计算机上使用的是IE浏览器。如何通过编程控制IE的操作呢,

一、如何获得Windows中所有打开的浏览器窗口

首先打开VB,建立一个新工程,点击菜单 Projects | References 项,在Available References 列表中选择

Microsoft Internet Controls项将Internet对象引用介入到工程中。添加一个ListBox到Form1,然后在Form1中添

加如下代码:

Dim dWinFolder As New ShellWindows


Private Sub Form_Load()

Dim objIE As Object


For Each objIE In dWinFolder

If InStr(1, objIE.FullName, "IEXPLORE.EXE", vbTextCompare) <> 0 Then

List1.AddItem objIE.LocationURL

End If

Next

End Sub

打开几个浏览器窗口,然后运行程序,可以看到所有浏览窗口中的URL地址都在List1中列了出来。

上面程序中的ShellWindows对象是描述当前所有打开的“浏览窗口”对象集合的对象,利用For...Each语句可以

获得其中所有的浏览窗口对象。这是一个WebBrowser对象,在MSDN索引中通过“WebBrowser Object”中可以找到该

对象的详细介绍

在ShellWindows中的浏览窗口对象不仅包含IE,还包含Explore窗口(向资源管理器或者“我的电脑”窗口就是

Explore)。只不过它们的宿主程序一个是IEXPLORE.EXE,一个是EXPLORE.EXE。所以对每一个对象首先根据其FulName

属性来判断窗口是IE浏览器,如果是,则将该窗口的URL地址列出来。

通过WebBrowser对象可以获得和设置浏览器窗口中的很多属性,例如窗口大小、工具栏、状态栏状态以及控制

窗口的浏览等,大家通过MSDN都可以查到。


二、如何得到每一个浏览窗口的内容

在上面程序的Form1中再添加一个TextBox控件,将MultiLine属性设置为True,然后在List1的Click事件中添加如

下代码:

Dim objDoc As Object

Dim objIE As Object


For Each objIE In dWinFolder

If objIE.LocationURL = List1.List(List1.ListIndex) Then

Set objDoc = objIE.Document


For i = 1 To objDoc.All.length - 1

If objDoc.All(i).tagname = "BODY" Then

Text1.Text = objDoc.All(i).innerText

End If

Next

Exit For

End If

Next

运行程序,点击ListBox中的一个列表,所对应的浏览器窗口中的文本内容就会显示在TextBox中。

在上面的程序中,首先根据ListBox中选择的URL获得Webrowser对象,然后根据Document属性获得文档对象。我们知道

一个页面中包括HEAD、TITLE、BODY部分,页面中还可能包括Applet、Script、连接、表单等,这些在文档中都是一个对象

在程序中就是循环文档对象下的所有对象,如果对象的名称是“BODY”,说明对象代表HTML文档的正文部分,那么访问对象

的innerText属性获得文档正文。关于Document对象更详细的信息,大家可以参考MSDN中Webbrowser object帮助中的

Document属性连接。


三、响应IE事件

上面的部分只是介绍了如何访问Webbrowser对象的属性,下面介绍如何监控IE事件。

在Form1中再添加一个CommandButton。在代码窗口的 [Gengeral]-[Declaration]添加下面的定义:

Dim WithEvents eventIE As WebBrowser_V1

这样就在Form1中新添加了一个对象,然后在Command1的Click事件中添加如下代码:

Dim objIE As Object


For Each objIE In dWinFolder

If objIE.LocationURL = List1.List(List1.ListIndex) Then

Set eventIE = objIE

Command1.Enabled = False

Text1.Text = ""

Exit For

End If

Next

在eventIE的NavigateComplete事件中添加如下代码:

Text1.Text = Text1.Text + Chr(13) + Chr(10) + URL

在Form的UnLoad事件中添加下面一句代码:

Set dWinFolder = Nothing

运行程序,在ListBox中选择一个URL后点击Command1,然后转到与所选项向对应的浏览窗口输入网站地址进行浏览,可以

看到所浏览过的站点地址在TextBox中一一列出。

上面的程序实现起来也很简单。首先定义一个可响应事件的Webbrowser对象,然后将它与在ListBox中选择的Webbrowser对

象联系起来,当浏览器发生变化时,eventIE对象就能响应相应的事件。

根据IE版本的不同,Webbrowser对象也不同,作者的浏览器是IE5.0,在上面将eventIE定义为WebBrowser_V1运行通过,如

果你的浏览器版本为4.0的话,可能在执行 Set eventIE = objIE 时,可能产生 Type mistake 错误,这时你可以尝试将

eventIE定义为:Dim WithEvents eventIE As WebBrowser

--------------------------------------------------------------------------------

-- 作者:hongjuan
-- 发布时间:2004-2-12 21:04:00

--
自己的IE——用VB制作浏览器


  程序的主角是一个ActiveX控件:WebBrowser。当然,缺省状态下VB的工具箱中并没

有它,我们得手工加入,方法是:右击工具箱,在出现的快捷菜单中选择“部件...”,

确保在弹出的对话框中选中“控件”标签,找到Microsoft Internet Controls,在它前

面的小框中打钩,然后确定。此时你会发现工具箱中多了两个小图标,其中,地球图标代

表的控件正是我们需要的WebBrowser。

  由于许多人对WebBrowser控件不是很熟悉,VB的帮助中也没有有关它的内容(反正

我没有找到),因此有必要介绍一下它的属性、方法和事件,限于篇幅,我们只涉及程

序中用到的:

  属性:LocationURL 返回控件显示WEB页面的URL。

  方法:Navigate 转移到指定的URL或打开指定HTML文件。

  事件:1.DownloadBegin 下载操作开时触发。

  2.DownloadComplete 下载操作完成、终止或失败时触发。

  3.ProgressChange WebBrowser控件跟踪下载操作的过程,并定期触发此事件。

其语法为:Sub WebBrowser_ProgressChange (ByVal Progress As Long, ByVal

ProgressMax As Long)。Progress变元是当前已下载的数据总量,ProgressMax变元

是将要下载的数据总量。

  4.TitleChange 当前文档标题改变时触发

  除了WebBrowser控件外,程序还需要一个Label控件:Label1;一个ComboBox控件:

combo1,用来显示URL地址;一个StatusBar控件:StatusBar1;一个ProgressBar控件:

ProgressBar1,用来显示下载进度(StatusBar控件和ProgressBar控件是ActiveX控件

Microsoft Windows Common Controls5.0的成员,加入工具箱的方法同WebBrowser控件),

这些控件的属性值都用缺省值。

  以下是程序清单:

  Option Explicit

  

  Private Sub Form_Load()

  Me.Caption =“My Explorer”

  Label1.Caption = “URL”

  Combo1.Text = “”

  Combo1.Top = Label1.Height

  Combo1.Left = 0

  WebBrowser1.Top = Combo1.Top + Combo1.Height

  WebBrowser1.Left = 0

  Form_Resize

  StatusBar1.Style = sbrSimple

  ProgressBar1.ZOrder

  End Sub

  

  Private Sub Form_Resize()

  On Error GoTo a

  Combo1.Width = Form1.Width - 100

  WebBrowser1.Width = Combo1.Width

  WebBrowser1.Height = Form1.Height - Combo1.Height - 1000

  ProgressBar1.Top = Me.Height - StatusBar1.Height - 330

  ProgressBar1.Left = 0.25 * StatusBar1.Width

  ProgressBar1.Width = 0.75 * Me.Width - 250

  a:

  End Sub

  

  Private Sub Combo1_Click()

  '转到指定网址

  WebBrowser1.Navigate Combo1.Text

  End Sub

  

  Private Sub Combo1_KeyDown(KeyCode As Integer, Shift As Integer)

  Dim i As Long

  Dim existed As Boolean

  If KeyCode = 13 Then

  If Left(Combo1.Text, 7) <> “http://”Then

  Combo1.Text = “http://”+ Combo1.Text

  End If

  WebBrowser1.Navigate Combo1.Text

  For i = 0 To Combo1.ListCount - 1

  If Combo1.List(i) = Combo1.Text Then

  existed = True

  Exit For

  Else

  existed = False

  End If

  Next

  If Not existed Then

  Combo1.AddItem (Combo1.Text)

  End If

  End If

  End Sub

  

  Private Sub WebBrowser1_DownloadBegin()

  '下载开始时状态栏显示“Now Linking...”

  StatusBar1.SimpleText = “Now Linking...”

  End Sub

  

  Private Sub WebBrowser1_DownloadComplete()

  '下载完成时状态栏显示“Link Finished”

  StatusBar1.SimpleText = “Link Finished”

  ProgressBar1.value = 0

  End Sub

  

  Private Sub WebBrowser1_ProgressChange(ByVal Progress As Long,

ByVal ProgressMax As Long)

  '下载进行时进度条变化

  If ProgressMax = 0 Then Exit Sub

  ProgressBar1.Max = ProgressMax

  If Progress <> -1 And Progress <= ProgressMax Then

  ProgressBar1.value = Progress

  End If

  End Sub

  

  Private Sub WebBrowser1_TitleChange(ByVal Text As String)

  Combo1.Text = WebBrowser1.LocationURL

  End Sub
Dim dWinFolder As New ShellWindows 'IE窗口
需要打www.sohu.com后再使用此函数
private sub Getbody()
Dim objDoc As Object
Dim objIE As Object
For Each objIE In dWinFolder
If objIE.LocationURL = "www.sohu.com" Then
Set objDoc = objIE.Document
For i = 1 To objDoc.All.Length - 1
If objDoc.All(i).tagname = "BODY" Then
Text1(0).Text = objDoc.All(i).innerText
End If

Next
end if
next
End Sub

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/82387/viewspace-902983/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/82387/viewspace-902983/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值