繁体   English   中英

如何从 TWebBrowser 获取 HTML 源代码

[英]How can I get HTML source code from TWebBrowser

如何从 WebBrowser 组件获取源代码?

我想获取 WebBrowser 组件上活动页面的源代码并将其写入 Memo 组件。

谢谢。

您可以使用IPersistStreamInit接口和save方法将 Webbrowser 的内容存储在 Stream 中。

Uses 
  ActiveX;

function GetWebBrowserHTML(const WebBrowser: TWebBrowser): String;
var
  LStream: TStringStream;
  Stream : IStream;
  LPersistStreamInit : IPersistStreamInit;
begin
  if not Assigned(WebBrowser.Document) then exit;
  LStream := TStringStream.Create('');
  try
    LPersistStreamInit := WebBrowser.Document as IPersistStreamInit;
    Stream := TStreamAdapter.Create(LStream,soReference);
    LPersistStreamInit.Save(Stream,true);
    result := LStream.DataString;
  finally
    LStream.Free();
  end;
end;

这也很管用:

    uses MSHTML;

    function GetHTML(w: TWebBrowser): String;
    Var
      e: IHTMLElement;
    begin
      Result := '';
      if Assigned(w.Document) then
      begin
         e := (w.Document as IHTMLDocument2).body;
    
         while e.parentElement <> nil do
         begin
           e := e.parentElement;
         end;
    
         Result := e.outerHTML;
      end;
    end;

这已在 Embarcadero 论坛中被多次询问和回答,并发布了大量代码示例。 搜索档案。

它的要点是您Navigate()到所需的 URL 并等待OnDocumentComplete事件触发,然后QueryInterface() IPersistStreamInit接口的Document属性并调用其save()方法。 创建一个TStream object 实例,例如TMemoryStream ,将其包装在TStreamAdapter object 中,然后将适配器传递给save() 然后,您可以根据需要将TStream加载到TMemo中。

为什么不快速而肮脏:

OnNavigateComplete2()

Form1.RichEdit1.Text:=(WebBrowser1.OleObject.Document.documentElement.outerhtml);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM