借助 TWebBrowser 可以把软件做的更漂亮、更灵活, 很多软件已经或者早就这样做了.
尽管 HTML DOM 内容繁杂(涉及到 HTML、JavaScript、CSS), 但也都属于 TWebBrowser 的功能范围.
使用 TWebBrowser 时, 如果配合上 MSHTML, 将会有很好的代码提示; 不然也可以, 就是写代码困难.
HTML DOM 中的一切都是源于一个叫 window 对象, 为了和 JS 中的 DOM 一致起来, 本次先获取这个对象.
TWebBrowser 是调用 SHDocVw.dll 的功能并继承与 TOleControl 类, 会用到 SHDocVw 和 OleCtrls 单元.
另外 window 是 IHTMLWindow2 接口类型的, 此接口定义在 MSHTML 单元.
本例效果图:

代码文件:
unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, OleCtrls, SHDocVw, StdCtrls; type TForm1 = class(TForm) WebBrowser1: TWebBrowser; Button1: TButton; Button2: TButton; procedure FormCreate(Sender: TObject); procedure Button1Click(Sender: TObject); procedure Button2Click(Sender: TObject); end; var Form1: TForm1; implementation {$R *.dfm} uses MSHTML; var window: IHTMLWindow2; {打开一个页面} procedure TForm1.Button1Click(Sender: TObject); begin WebBrowser1.Navigate('http://del.cnblogs.com'); end; {获取并试用 window 对象} procedure TForm1.Button2Click(Sender: TObject); begin window := (WebBrowser1.Document as IHTMLDocument2).parentWindow; window.document.body.innerHTML := '<hr>万一的 Delphi 博客<hr>'; window.alert('JavaScript 的提示: 修改成功!'); end; {初始化} procedure TForm1.FormCreate(Sender: TObject); begin Position := poScreenCenter; WebBrowser1.Align := alTop; Button1.Caption := '打开'; Button2.Caption := '改写'; end; end.
窗体文件:
object Form1: TForm1 Left = 0 Top = 0 Caption = 'Form1' ClientHeight = 167 ClientWidth = 318 Color = clBtnFace Font.Charset = DEFAULT_CHARSET Font.Color = clWindowText Font.Height = -11 Font.Name = 'Tahoma' Font.Style = [] OldCreateOrder = False OnCreate = FormCreate PixelsPerInch = 96 TextHeight = 13 object WebBrowser1: TWebBrowser Left = 8 Top = 8 Width = 300 Height = 121 TabOrder = 0 ControlData = { 4C000000021F0000810C00000000000000000000000000000000000000000000 000000004C000000000000000000000001000000E0D057007335CF11AE690800 2B2E126208000000000000004C0000000114020000000000C000000000000046 8000000000000000000000000000000000000000000000000000000000000000 00000000000000000100000000000000000000000000000000000000} end object Button1: TButton Left = 154 Top = 135 Width = 75 Height = 25 Caption = 'Button1' TabOrder = 1 OnClick = Button1Click end object Button2: TButton Left = 235 Top = 135 Width = 75 Height = 25 Caption = 'Button2' TabOrder = 2 OnClick = Button2Click end end
从一个外部的 IE 窗口获取 window 对象也可以:
uses MSHTML, ComObj; var IE: Variant; window: IHTMLWindow2; procedure TForm1.Button1Click(Sender: TObject); begin IE := CreateOleObject('InternetExplorer.Application'); IE.Visible := True; IE.Navigate('http://del.cnblogs.com'); end; procedure TForm1.Button2Click(Sender: TObject); begin window := (IDispatch(IE.document) as IHTMLDocument2).parentWindow; window.document.body.innerHTML := '<hr>万一的 Delphi 博客<hr>'; end;
分类:
TWebBrowser
, HTML 与 CSS
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
2008-03-12 学习 TTreeView [7] - Insert、Delete
2008-03-12 学习 TTreeView [6] - SaveToFile、LoadFromStream、SaveToStream、LoadFromFile
2008-03-12 学习 TTreeView [5] - TTreeNode.Level 属性
2008-03-12 判断一个对象是否存在, 谁更快?
2008-03-12 学习 TTreeView [4] - TTreeNode 类的常用属性与 TTreeView 类的 OnChange 事件