以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.com/bbs/index.asp)
--  专家坐堂  (http://foxtable.com/bbs/list.asp?boardid=2)
----  [求助]关于网页加载后执行代码  (http://foxtable.com/bbs/dispbbs.asp?boardid=2&id=160658)

--  作者:zto001
--  发布时间:2021/2/10 4:45:00
--  [求助]关于网页加载后执行代码
[求助]关于网页加载后执行代码
我有一段代码,是获取网页上的信息,网页加载速度影响获取网页信息。怎么改代码改成加载网页后再获取信息?
If Forms("售后记录").Opened Then
    Dim brw As WinForm.WebBrowser =  forms("售后记录").Controls("WebBrowser1")
    brw.Address = "http://www.kuaidi100.com/chaxun?com="& 快递 &"&nu=" & 单号
    


    
\'获取网页信息代码
    Dim web As System.Windows.Forms.WebBrowser = forms("售后记录").controls("webbrowser1").Basecontrol
    Dim elems As object = web.Document.GetElementsByTagName("td")
end if

--  作者:有点蓝
--  发布时间:2021/2/16 10:41:00
--  
参考:http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&id=49278

http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&id=32808

--  作者:zto001
--  发布时间:2021/2/17 12:02:00
--  
Public Sub WebBrowser1_DocumentCompleted(ByVal sender As System.Object, ByVal e As System.Windows.Forms.WebBrowserDocumentCompletedEventArgs)
If Isgo Then \'判断一下ISGO是否需要执行操作 如果是TRUE说明可以继续执行操作, 如果是FALSE说明已经执行完毕,或者点击了停止.
    Dim web As System.Windows.Forms.WebBrowser = sender \'把触发该事件的Sender转换为WebBrowser
    If web.ReadyState=System.Windows.Forms.WebBrowserReadyState.Complete\'由于加载完成事件会触发多次,分别为页面数据加载完成,DOM树加载完成.所以这里要判断一下.确保所有东西都加载完成再执行下面的操作

应该是这几段代码判断出来的吧。我要怎么改才能改到按钮里面?

--  作者:有点蓝
--  发布时间:2021/2/18 9:25:00
--  
那就看2楼第一个链接的用法
--  作者:zto001
--  发布时间:2021/2/18 16:22:00
--  
那个方法用不了,每次物流记录没加载出来就执行了后面的代码。
--  作者:有点蓝
--  发布时间:2021/2/18 16:45:00
--  
如果3楼的用法可以判断,2楼第一个链接的用法肯定也可以。写了什么代码?
--  作者:zto001
--  发布时间:2021/2/19 22:37:00
--  
            Dim web As New System.Windows.Forms.WebBrowser()
            web.ScriptErrorsSuppressed = True \'禁止弹出脚本错误对话框
            web.Navigate("http://www.kuaidi100.com/chaxun?com="& 快递 &"&nu=" & 单号)
            Do Until web.ReadyState = 4
                Application.DoEvents
            Loop
            Dim sdt As Date = Date.Now
            While Date.Now < sdt.AddSeconds(2)
                Application.DoEvents
            End While
            
            Dim elems As object = web.Document.GetElementsByTagName("td")
            Dim A1,A2,A3 As String
            For Each elem As object In elems
........

延迟2秒执行这个是目前效果稍微好一点的。最多只能执行5次,后面就都没加载完全就执行了后面的代码

执行网页如下
http://www.kuaidi100.com/chaxun?com=youzhengguonei&nu=9864325573222
我获取物流记录

--  作者:有点蓝
--  发布时间:2021/2/20 9:32:00
--  
这种没有办法,对方网站可能做了防护处理,使用了内置框架或者ajax延迟处理。